alsa-devel.alsa-project.org archive mirror
 help / color / mirror / Atom feed
From: Takashi Iwai <tiwai@suse.de>
To: Olivia Mackintosh <livvy@base.nu>
Cc: alsa-devel@alsa-project.org
Subject: Re: [PATCH] ALSA: usb-audio: Add support for Pioneer DJM-750
Date: Mon, 18 Jan 2021 17:41:42 +0100	[thread overview]
Message-ID: <s5h4kjei4e1.wl-tiwai@suse.de> (raw)
In-Reply-To: <20210118130621.77miiie47wp7mump@base.nu>

On Mon, 18 Jan 2021 14:06:21 +0100,
Olivia Mackintosh wrote:
> 
> This adds the Pioneer DJ DJM-750 to the quirks table and ensures
> skip_pioneer_sync_ep() is (also) called: this device uses the vendor
> ID of 0x08e4 (I'm not sure why they use multiple vendor IDs but many
> just like to be awkward it seems).
> 
> Playback on all 8 channels works. I'll likely keep this working in the
> future and submit futher patches and improvements as necessary.
> 
> Signed-off-by: Olivia Mackintosh <livvy@base.nu>

Thanks, applied now to for-next branch, i.e. targeted for 5.12.
I'd take for 5.11 if it were a oneliner, but this is a bit too long as
a late merge material, unfortunately.


Takashi

> ---
>  sound/usb/implicit.c     |  3 +-
>  sound/usb/quirks-table.h | 60 ++++++++++++++++++++++++++++++++++++++++
>  2 files changed, 62 insertions(+), 1 deletion(-)
> 
> diff --git a/sound/usb/implicit.c b/sound/usb/implicit.c
> index 521cc846d9d9..e7216d0b860d 100644
> --- a/sound/usb/implicit.c
> +++ b/sound/usb/implicit.c
> @@ -302,7 +302,8 @@ static int audioformat_implicit_fb_quirk(struct snd_usb_audio *chip,
>  	/* Pioneer devices with vendor spec class */
>  	if (attr == USB_ENDPOINT_SYNC_ASYNC &&
>  	    alts->desc.bInterfaceClass == USB_CLASS_VENDOR_SPEC &&
> -	    USB_ID_VENDOR(chip->usb_id) == 0x2b73 /* Pioneer */) {
> +	    (USB_ID_VENDOR(chip->usb_id) == 0x2b73 || /* Pioneer */
> +	     USB_ID_VENDOR(chip->usb_id) == 0x08e4    /* Pioneer */)) {
>  		if (skip_pioneer_sync_ep(chip, fmt, alts))
>  			return 1;
>  	}
> diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h
> index c8a4bdf18207..98b31c3160ad 100644
> --- a/sound/usb/quirks-table.h
> +++ b/sound/usb/quirks-table.h
> @@ -3757,6 +3757,66 @@ AU0828_DEVICE(0x2040, 0x7270, "Hauppauge", "HVR-950Q"),
>  		}
>  	}
>  },
> +{
> +	/*
> +	 * Pioneer DJ DJM-750
> +	 * 8 channels playback & 8 channels capture @ 44.1/48/96kHz S24LE
> +	 */
> +	USB_DEVICE_VENDOR_SPEC(0x08e4, 0x017f),
> +	.driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
> +		.ifnum = QUIRK_ANY_INTERFACE,
> +		.type = QUIRK_COMPOSITE,
> +		.data = (const struct snd_usb_audio_quirk[]) {
> +			{
> +				.ifnum = 0,
> +				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
> +				.data = &(const struct audioformat) {
> +					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
> +					.channels = 8,
> +					.iface = 0,
> +					.altsetting = 1,
> +					.altset_idx = 1,
> +					.endpoint = 0x05,
> +					.ep_attr = USB_ENDPOINT_XFER_ISOC|
> +					    USB_ENDPOINT_SYNC_ASYNC,
> +					.rates = SNDRV_PCM_RATE_44100|
> +						SNDRV_PCM_RATE_48000|
> +						SNDRV_PCM_RATE_96000,
> +					.rate_min = 44100,
> +					.rate_max = 96000,
> +					.nr_rates = 3,
> +					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
> +				}
> +			},
> +			{
> +				.ifnum = 0,
> +				.type = QUIRK_AUDIO_FIXED_ENDPOINT,
> +				.data = &(const struct audioformat) {
> +					.formats = SNDRV_PCM_FMTBIT_S24_3LE,
> +					.channels = 8,
> +					.iface = 0,
> +					.altsetting = 1,
> +					.altset_idx = 1,
> +					.endpoint = 0x86,
> +					.ep_idx = 1,
> +					.ep_attr = USB_ENDPOINT_XFER_ISOC|
> +						USB_ENDPOINT_SYNC_ASYNC|
> +					        USB_ENDPOINT_USAGE_IMPLICIT_FB,
> +					.rates = SNDRV_PCM_RATE_44100|
> +						SNDRV_PCM_RATE_48000|
> +						SNDRV_PCM_RATE_96000,
> +					.rate_min = 44100,
> +					.rate_max = 96000,
> +					.nr_rates = 3,
> +					.rate_table = (unsigned int[]) { 44100, 48000, 96000 }
> +				}
> +			},
> +			{
> +				.ifnum = -1
> +			}
> +		}
> +	}
> +},
>  
>  #undef USB_DEVICE_VENDOR_SPEC
>  #undef USB_AUDIO_DEVICE
> -- 
> 2.30.0
> 

      reply	other threads:[~2021-01-18 16:42 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-01-18 13:06 [PATCH] ALSA: usb-audio: Add support for Pioneer DJM-750 Olivia Mackintosh
2021-01-18 16:41 ` Takashi Iwai [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=s5h4kjei4e1.wl-tiwai@suse.de \
    --to=tiwai@suse.de \
    --cc=alsa-devel@alsa-project.org \
    --cc=livvy@base.nu \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).