Commit 352ca4dd authored by Takashi Iwai's avatar Takashi Iwai Committed by Sasha Levin

ALSA: usb-audio: Check Marantz/Denon USB DACs in a single place

[ Upstream commit 8b28c93f ]

There are three places doing the same check.  Let's make them
together.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent e3a3694d
...@@ -1111,17 +1111,24 @@ bool snd_usb_get_sample_rate_quirk(struct snd_usb_audio *chip) ...@@ -1111,17 +1111,24 @@ bool snd_usb_get_sample_rate_quirk(struct snd_usb_audio *chip)
/* Marantz/Denon USB DACs need a vendor cmd to switch /* Marantz/Denon USB DACs need a vendor cmd to switch
* between PCM and native DSD mode * between PCM and native DSD mode
*/ */
static bool is_marantz_denon_dac(unsigned int id)
{
switch (id) {
case USB_ID(0x154e, 0x1003): /* Denon DA-300USB */
case USB_ID(0x154e, 0x3005): /* Marantz HD-DAC1 */
case USB_ID(0x154e, 0x3006): /* Marantz SA-14S1 */
return true;
}
return false;
}
int snd_usb_select_mode_quirk(struct snd_usb_substream *subs, int snd_usb_select_mode_quirk(struct snd_usb_substream *subs,
struct audioformat *fmt) struct audioformat *fmt)
{ {
struct usb_device *dev = subs->dev; struct usb_device *dev = subs->dev;
int err; int err;
switch (subs->stream->chip->usb_id) { if (is_marantz_denon_dac(subs->stream->chip->usb_id)) {
case USB_ID(0x154e, 0x1003): /* Denon DA-300USB */
case USB_ID(0x154e, 0x3005): /* Marantz HD-DAC1 */
case USB_ID(0x154e, 0x3006): /* Marantz SA-14S1 */
/* First switch to alt set 0, otherwise the mode switch cmd /* First switch to alt set 0, otherwise the mode switch cmd
* will not be accepted by the DAC * will not be accepted by the DAC
*/ */
...@@ -1194,17 +1201,10 @@ void snd_usb_ctl_msg_quirk(struct usb_device *dev, unsigned int pipe, ...@@ -1194,17 +1201,10 @@ void snd_usb_ctl_msg_quirk(struct usb_device *dev, unsigned int pipe,
/* Marantz/Denon devices with USB DAC functionality need a delay /* Marantz/Denon devices with USB DAC functionality need a delay
* after each class compliant request * after each class compliant request
*/ */
if ((le16_to_cpu(dev->descriptor.idVendor) == 0x154e) && if (is_marantz_denon_dac(USB_ID(le16_to_cpu(dev->descriptor.idVendor),
(requesttype & USB_TYPE_MASK) == USB_TYPE_CLASS) { le16_to_cpu(dev->descriptor.idProduct)))
&& (requesttype & USB_TYPE_MASK) == USB_TYPE_CLASS)
switch (le16_to_cpu(dev->descriptor.idProduct)) {
case 0x1003: /* Denon DA300-USB */
case 0x3005: /* Marantz HD-DAC1 */
case 0x3006: /* Marantz SA-14S1 */
mdelay(20); mdelay(20);
break;
}
}
/* Zoom R16/24 needs a tiny delay here, otherwise requests like /* Zoom R16/24 needs a tiny delay here, otherwise requests like
* get/set frequency return as failed despite actually succeeding. * get/set frequency return as failed despite actually succeeding.
...@@ -1259,15 +1259,9 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip, ...@@ -1259,15 +1259,9 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
} }
/* Denon/Marantz devices with USB DAC functionality */ /* Denon/Marantz devices with USB DAC functionality */
switch (chip->usb_id) { if (is_marantz_denon_dac(chip->usb_id)) {
case USB_ID(0x154e, 0x1003): /* Denon DA300-USB */
case USB_ID(0x154e, 0x3005): /* Marantz HD-DAC1 */
case USB_ID(0x154e, 0x3006): /* Marantz SA-14S1 */
if (fp->altsetting == 2) if (fp->altsetting == 2)
return SNDRV_PCM_FMTBIT_DSD_U32_BE; return SNDRV_PCM_FMTBIT_DSD_U32_BE;
break;
default:
break;
} }
return 0; return 0;
......
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