[alsa-devel] [PATCH 2/2] ALSA: snd-usb: add quirks handler for DSD streams
Daniel Mack
zonque at gmail.com
Sat Apr 6 13:48:45 CEST 2013
On 06.04.2013 13:44, Daniel Mack wrote:
> Unfortunately, none of the UAC standards provides a way to identify DSD
> (Direct Stream Digital) formats. Hence, this patch adds a quirks
> handler to identify USB interfaces that are capable of handling DSD.
>
> That quirks handler can augment the already parsed formats bit-field,
> typically by any of the new SNDRV_PCM_FMTBIT_DSD_DOP_{U8_U16}, and it
> currently does so for USB devices matching the 'Playback Design'
> vendor id.
Sorry - this identical message got sent twice unintentionally. Please
ignore one of the two ...
Daniel
> Signed-off-by: Daniel Mack <zonque at gmail.com>
> ---
> sound/usb/format.c | 3 +++
> sound/usb/quirks.c | 23 +++++++++++++++++++++++
> sound/usb/quirks.h | 4 ++++
> 3 files changed, 30 insertions(+)
>
> diff --git a/sound/usb/format.c b/sound/usb/format.c
> index a695caf..a73d67a 100644
> --- a/sound/usb/format.c
> +++ b/sound/usb/format.c
> @@ -136,6 +136,9 @@ static u64 parse_audio_format_i_type(struct snd_usb_audio *chip,
> snd_printk(KERN_INFO "%d:%u:%d : unsupported format bits %#x\n",
> chip->dev->devnum, fp->iface, fp->altsetting, format);
> }
> +
> + pcm_formats |= snd_usb_interface_dsd_format_quirks(chip, fp, sample_bytes);
> +
> return pcm_formats;
> }
>
> diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c
> index a2ac004..2fcc984 100644
> --- a/sound/usb/quirks.c
> +++ b/sound/usb/quirks.c
> @@ -905,3 +905,26 @@ void snd_usb_ctl_msg_quirk(struct usb_device *dev, unsigned int pipe,
> mdelay(20);
> }
>
> +/*
> + * snd_usb_interface_dsd_format_quirks() is called from format.c to
> + * augment the PCM format bit-field for DSD types. The UAC standards
> + * don't have a designated bit field to denote DSD-capable interfaces,
> + * hence all hardware that is known to support this format has to be
> + * listed here.
> + */
> +u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
> + struct audioformat *fp,
> + unsigned int sample_bytes)
> +{
> + if ((le16_to_cpu(chip->dev->descriptor.idVendor) == 0x23ba) &&
> + fp->altsetting > 1) {
> + switch (sample_bytes) {
> + case 1:
> + return SNDRV_PCM_FMTBIT_DSD_DOP_U8;
> + case 2:
> + return SNDRV_PCM_FMTBIT_DSD_DOP_U16;
> + }
> + }
> +
> + return 0;
> +}
> diff --git a/sound/usb/quirks.h b/sound/usb/quirks.h
> index 0ca9e91..f10d00e 100644
> --- a/sound/usb/quirks.h
> +++ b/sound/usb/quirks.h
> @@ -30,4 +30,8 @@ void snd_usb_ctl_msg_quirk(struct usb_device *dev, unsigned int pipe,
> __u8 request, __u8 requesttype, __u16 value,
> __u16 index, void *data, __u16 size);
>
> +u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
> + struct audioformat *fp,
> + unsigned int sample_bytes);
> +
> #endif /* __USBAUDIO_QUIRKS_H */
>
More information about the Alsa-devel
mailing list