Commit a789498e authored by Kailang Yang's avatar Kailang Yang Committed by Sasha Levin

ALSA: usb-audio: Skip volume controls triggers hangup on Dell USB Dock

[ Upstream commit adcdd0d5 ]

This is Dell usb dock audio workaround.
It was fixed the master volume keep lower.

[Some background: the patch essentially skips the controls of a couple
 of FU volumes.  Although the firmware exposes the dB and the value
 information via the usb descriptor, changing the values (we set the
 min volume as default) screws up the device.  Although this has been
 fixed in the newer firmware, the devices are shipped with the old
 firmware, thus we need the workaround in the driver side.  -- tiwai]
Signed-off-by: default avatarKailang Yang <kailang@realtek.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent 330d83a5
...@@ -348,6 +348,16 @@ static struct usbmix_name_map bose_companion5_map[] = { ...@@ -348,6 +348,16 @@ static struct usbmix_name_map bose_companion5_map[] = {
{ 0 } /* terminator */ { 0 } /* terminator */
}; };
/*
* Dell usb dock with ALC4020 codec had a firmware problem where it got
* screwed up when zero volume is passed; just skip it as a workaround
*/
static const struct usbmix_name_map dell_alc4020_map[] = {
{ 16, NULL },
{ 19, NULL },
{ 0 }
};
/* /*
* Control map entries * Control map entries
*/ */
...@@ -430,6 +440,10 @@ static struct usbmix_ctl_map usbmix_ctl_maps[] = { ...@@ -430,6 +440,10 @@ static struct usbmix_ctl_map usbmix_ctl_maps[] = {
.id = USB_ID(0x0ccd, 0x0028), .id = USB_ID(0x0ccd, 0x0028),
.map = aureon_51_2_map, .map = aureon_51_2_map,
}, },
{
.id = USB_ID(0x0bda, 0x4014),
.map = dell_alc4020_map,
},
{ {
.id = USB_ID(0x0dba, 0x1000), .id = USB_ID(0x0dba, 0x1000),
.map = mbox1_map, .map = mbox1_map,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment