* [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support
@ 2019-08-02 11:52 Ard van Breemen
2019-08-02 11:52 ` [PATCH 1/2] ALSA snd-usb-audio: Skip bSynchAddress endpoint check if it is invalid Ard van Breemen
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Ard van Breemen @ 2019-08-02 11:52 UTC (permalink / raw)
To: alsa-devel; +Cc: Ard van Breemen
The Pioneer lacks the UAC descriptors (added to quircks). It also needs
a fix in synchronisation handling for those cases that
bSynchAddress == 0
Ard van Breemen (2):
Skip bSynchAddress endpoint check if it is invalid.
Add Pioneer DDJ-SX3 PCM quirck.
sound/usb/pcm.c | 1 +
sound/usb/quirks-table.h | 57 ++++++++++++++++++++++++++++++++++++++++
2 files changed, 58 insertions(+)
--
2.17.1
^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH 1/2] ALSA snd-usb-audio: Skip bSynchAddress endpoint check if it is invalid.
2019-08-02 11:52 [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Ard van Breemen
@ 2019-08-02 11:52 ` Ard van Breemen
2019-08-02 11:52 ` [PATCH 2/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM quirck Ard van Breemen
2019-08-06 10:52 ` [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Takashi Iwai
2 siblings, 0 replies; 4+ messages in thread
From: Ard van Breemen @ 2019-08-02 11:52 UTC (permalink / raw)
To: alsa-devel; +Cc: Ard van Breemen
The Linux kernel assumes that get_endpoint(alts,0) and
get_endpoint(alts,1) are eachothers feedback endpoints.
To reassure that validity it will test bsynchaddress to comply with that
assumption. But if the bsyncaddress is 0 (invalid), it will flag that as
a wrong assumption and return an error.
Fix: Skip the test if bSynchAddress is 0.
Note: those with a valid bSynchAddress should have a code quirck added.
Signed-off-by: Ard van Breemen <ard@kwaak.net>
---
sound/usb/pcm.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c
index 75b96929f76c..51a8faf25ed8 100644
--- a/sound/usb/pcm.c
+++ b/sound/usb/pcm.c
@@ -456,6 +456,7 @@ static int set_sync_endpoint(struct snd_usb_substream *subs,
}
ep = get_endpoint(alts, 1)->bEndpointAddress;
if (get_endpoint(alts, 0)->bLength >= USB_DT_ENDPOINT_AUDIO_SIZE &&
+ get_endpoint(alts, 0)->bSynchAddress != 0 &&
((is_playback && ep != (unsigned int)(get_endpoint(alts, 0)->bSynchAddress | USB_DIR_IN)) ||
(!is_playback && ep != (unsigned int)(get_endpoint(alts, 0)->bSynchAddress & ~USB_DIR_IN)))) {
dev_err(&dev->dev,
--
2.17.1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH 2/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM quirck.
2019-08-02 11:52 [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Ard van Breemen
2019-08-02 11:52 ` [PATCH 1/2] ALSA snd-usb-audio: Skip bSynchAddress endpoint check if it is invalid Ard van Breemen
@ 2019-08-02 11:52 ` Ard van Breemen
2019-08-06 10:52 ` [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Takashi Iwai
2 siblings, 0 replies; 4+ messages in thread
From: Ard van Breemen @ 2019-08-02 11:52 UTC (permalink / raw)
To: alsa-devel; +Cc: Ard van Breemen
The Pioneer DDJ-SX3 is a plain 12 32bit channel out and 10 channel in
PCM/midi controller. The PCM part is "vendor specific".
It needs the "ignore invalid bsynchaddress" patch as it uses 0 for that.
Signed-off-by: Ard van Breemen <ard@kwaak.net>
---
sound/usb/quirks-table.h | 57 ++++++++++++++++++++++++++++++++++++++++
1 file changed, 57 insertions(+)
diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h
index 9e049f60e80e..858c6fb17b78 100644
--- a/sound/usb/quirks-table.h
+++ b/sound/usb/quirks-table.h
@@ -3534,5 +3534,62 @@ AU0828_DEVICE(0x2040, 0x7270, "Hauppauge", "HVR-950Q"),
}
}
},
+{
+ /*
+ * PIONEER DJ DDJ-SX3
+ * PCM is 12 channels out, 10 channels in @ 44.1 fixed
+ * interface 0, vendor class alt setting 1 for endpoints 5 and 0x86
+ * The feedback for the output is the input.
+ */
+ USB_DEVICE_VENDOR_SPEC(0x2b73, 0x0023),
+ .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_S32_LE,
+ .channels = 12,
+ .iface = 0,
+ .altsetting = 1,
+ .altset_idx = 1,
+ .endpoint = 0x05,
+ .ep_attr = USB_ENDPOINT_XFER_ISOC|
+ USB_ENDPOINT_SYNC_ASYNC,
+ .rates = SNDRV_PCM_RATE_44100,
+ .rate_min = 44100,
+ .rate_max = 44100,
+ .nr_rates = 1,
+ .rate_table = (unsigned int[]) { 44100 }
+ }
+ },
+ {
+ .ifnum = 0,
+ .type = QUIRK_AUDIO_FIXED_ENDPOINT,
+ .data = &(const struct audioformat) {
+ .formats = SNDRV_PCM_FMTBIT_S32_LE,
+ .channels = 10,
+ .iface = 0,
+ .altsetting = 1,
+ .altset_idx = 1,
+ .endpoint = 0x86,
+ .ep_attr = USB_ENDPOINT_XFER_ISOC|
+ USB_ENDPOINT_SYNC_ASYNC|
+ USB_ENDPOINT_USAGE_IMPLICIT_FB,
+ .rates = SNDRV_PCM_RATE_44100,
+ .rate_min = 44100,
+ .rate_max = 44100,
+ .nr_rates = 1,
+ .rate_table = (unsigned int[]) { 44100 }
+ }
+ },
+ {
+ .ifnum = -1
+ }
+ }
+ }
+},
#undef USB_DEVICE_VENDOR_SPEC
--
2.17.1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support
2019-08-02 11:52 [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Ard van Breemen
2019-08-02 11:52 ` [PATCH 1/2] ALSA snd-usb-audio: Skip bSynchAddress endpoint check if it is invalid Ard van Breemen
2019-08-02 11:52 ` [PATCH 2/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM quirck Ard van Breemen
@ 2019-08-06 10:52 ` Takashi Iwai
2 siblings, 0 replies; 4+ messages in thread
From: Takashi Iwai @ 2019-08-06 10:52 UTC (permalink / raw)
To: Ard van Breemen; +Cc: alsa-devel
On Fri, 02 Aug 2019 13:52:13 +0200,
Ard van Breemen wrote:
>
> The Pioneer lacks the UAC descriptors (added to quircks). It also needs
> a fix in synchronisation handling for those cases that
> bSynchAddress == 0
>
> Ard van Breemen (2):
> Skip bSynchAddress endpoint check if it is invalid.
> Add Pioneer DDJ-SX3 PCM quirck.
Applied both patches. Thanks.
Takashi
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2019-08-06 10:52 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-08-02 11:52 [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Ard van Breemen
2019-08-02 11:52 ` [PATCH 1/2] ALSA snd-usb-audio: Skip bSynchAddress endpoint check if it is invalid Ard van Breemen
2019-08-02 11:52 ` [PATCH 2/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM quirck Ard van Breemen
2019-08-06 10:52 ` [PATCH 0/2] ALSA snd-usb-audio: Add Pioneer DDJ-SX3 PCM support Takashi Iwai
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).