From: Vinod Koul Date: Thu, 28 Jan 2016 08:32:18 +0000 (+0530) Subject: amixer: skip showing asoc tlv byte controls X-Git-Tag: v1.1.1~21 X-Git-Url: https://git.alsa-project.org/?a=commitdiff_plain;h=18d5f52a61d0df7cf28456e264d7ab72c15984fb;p=alsa-utils.git amixer: skip showing asoc tlv byte controls ASoC TLV Byte controls are very large size controls so we should add new options for these. So skip dumping contents for these. $amixer -c0 cget numid=16 numid=16,iface=MIXER,name='mdl params' ; type=BYTES,access=-----RW-,values=30336 ; ASoC TLV Byte control, skipping bytes dump Signed-off-by: Vinod Koul Signed-off-by: Takashi Iwai --- diff --git a/amixer/amixer.c b/amixer/amixer.c index db18493..f9b09cb 100644 --- a/amixer/amixer.c +++ b/amixer/amixer.c @@ -682,6 +682,14 @@ static int show_control(const char *space, snd_hctl_elem_t *elem, __skip_read: if (!snd_ctl_elem_info_is_tlv_readable(info)) goto __skip_tlv; + /* skip ASoC ext bytes controls that may have huge binary TLV data */ + if (type == SND_CTL_ELEM_TYPE_BYTES && + !snd_ctl_elem_info_is_readable(info) && + !snd_ctl_elem_info_is_writable(info)) { + printf("%s; ASoC TLV Byte control, skipping bytes dump\n", space); + goto __skip_tlv; + } + tlv = malloc(4096); if ((err = snd_hctl_elem_tlv_read(elem, tlv, 4096)) < 0) { error("Control %s element TLV read error: %s\n", card, snd_strerror(err));