[alsa-devel] [PATCH] alsa-utils: amixer: Fix SND_CTL_TLVT_DB_RANGE handling
Takashi Iwai
tiwai at suse.de
Thu Jun 16 14:58:29 CEST 2011
At Thu, 16 Jun 2011 14:19:18 +0200,
Lars-Peter Clausen wrote:
>
> Current support for handling SND_CTL_TLVT_DB_RANGE in amixer is completely
> broken. This patch fixes it.
>
> Reported-by: Daniel Mack <zonque at gmail.com>
> Signed-off-by: Lars-Peter Clausen <lars at metafoo.de>
Thanks, applied now.
Takashi
> ---
> amixer/amixer.c | 14 +++++++-------
> 1 files changed, 7 insertions(+), 7 deletions(-)
>
> diff --git a/amixer/amixer.c b/amixer/amixer.c
> index a177288..9d2855d 100644
> --- a/amixer/amixer.c
> +++ b/amixer/amixer.c
> @@ -517,20 +517,20 @@ static void decode_tlv(unsigned int spaces, unsigned int *tlv, unsigned int tlv_
> #ifdef SND_CTL_TLVT_DB_RANGE
> case SND_CTL_TLVT_DB_RANGE:
> printf("dBrange-\n");
> - if ((size / (6 * sizeof(unsigned int))) != 0) {
> + if ((size % (6 * sizeof(unsigned int))) != 0) {
> while (size > 0) {
> printf("0x%08x,", tlv[idx++]);
> size -= sizeof(unsigned int);
> }
> break;
> }
> - idx = 0;
> - while (idx < size) {
> + while (size > 0) {
> print_spaces(spaces + 2);
> - printf("rangemin=%i,", tlv[0]);
> - printf(",rangemax=%i\n", tlv[1]);
> - decode_tlv(spaces + 4, tlv + 2, 6 * sizeof(unsigned int));
> - idx += 6 * sizeof(unsigned int);
> + printf("rangemin=%i,", tlv[idx++]);
> + printf(",rangemax=%i\n", tlv[idx++]);
> + decode_tlv(spaces + 4, tlv + idx, 4 * sizeof(unsigned int));
> + idx += 4;
> + size -= 6 * sizeof(unsigned int);
> }
> break;
> #endif
> --
> 1.7.2.5
>
More information about the Alsa-devel
mailing list