summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Ujfalusi <peter.ujfalusi@nokia.com>2010-07-20 10:34:52 +0300
committerTakashi Iwai <tiwai@suse.de>2010-07-20 12:55:41 +0200
commit16a2cad39b7ee29e34b92d39d72eebfc88f8dc22 (patch)
tree448c929e2be815a384c5ace5bca22c8d7a991a23
parent191c57805a791925ab5992f127a1cb5f4ab56c9c (diff)
downloadalsa-lib-16a2cad39b7ee29e34b92d39d72eebfc88f8dc22.tar.gz
tlv: Check out of range dB with SND_CTL_TLVT_DB_RANGE
When converting from dB value to raw value, the control's full range was not checked in case of SND_CTL_TLVT_DB_RANGE. Check out of range dB values, and return apropriate raw value for the caller. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@nokia.com> Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r--src/control/tlv.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/src/control/tlv.c b/src/control/tlv.c
index 0ff052ee..9f26f355 100644
--- a/src/control/tlv.c
+++ b/src/control/tlv.c
@@ -285,13 +285,23 @@ int snd_tlv_convert_from_dB(unsigned int *tlv, long rangemin, long rangemax,
{
switch (tlv[0]) {
case SND_CTL_TLVT_DB_RANGE: {
+ long dbmin, dbmax;
unsigned int pos, len;
len = int_index(tlv[1]);
if (len > MAX_TLV_RANGE_SIZE)
return -EINVAL;
+ if (snd_tlv_get_dB_range(tlv, rangemin, rangemax,
+ &dbmin, &dbmax))
+ return -EINVAL;
+ if (db_gain <= dbmin) {
+ *value = rangemin;
+ return 0;
+ } else if (db_gain >= dbmax) {
+ *value = rangemax;
+ return 0;
+ }
pos = 2;
while (pos + 4 <= len) {
- long dbmin, dbmax;
rangemin = (int)tlv[pos];
rangemax = (int)tlv[pos + 1];
if (!snd_tlv_get_dB_range(tlv + pos + 2,