[Buildroot] [PATCH] alsa-utils: Add patch for amixer TLV output

Daniel Mack zonque at gmail.com
Mon Jul 11 15:43:40 UTC 2011


This patch is queued upstream, so it can be dropped once a new version
of alsa-utils is released.

Signed-off-by: Daniel Mack <zonque at gmail.com>
---
 .../alsa-utils/alsa-utils-amixer-tlv-fix.patch     |   32 ++++++++++++++++++++
 1 files changed, 32 insertions(+), 0 deletions(-)
 create mode 100644 package/multimedia/alsa-utils/alsa-utils-amixer-tlv-fix.patch

diff --git a/package/multimedia/alsa-utils/alsa-utils-amixer-tlv-fix.patch b/package/multimedia/alsa-utils/alsa-utils-amixer-tlv-fix.patch
new file mode 100644
index 0000000..1b5e9c5
--- /dev/null
+++ b/package/multimedia/alsa-utils/alsa-utils-amixer-tlv-fix.patch
@@ -0,0 +1,32 @@
+diff --git a/amixer/amixer.c b/amixer/amixer.c
+index a177288..3bc6743 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 * sizeof(unsigned int);
++			size -= 6 * sizeof(unsigned int);
+ 		}
+ 		break;
+ #endif
-- 
1.7.5.4




More information about the buildroot mailing list