Re: [PATCH] Sound: Add support for the Pioneer DJM 750MK2 Mixer/Soundcard
Olivia Mackintosh
livvy at base.nu
Sun Nov 28 22:50:02 CET 2021
On 10 October 2021 16:58:41 CEST, William Overton <willovertonuk at gmail.com> wrote:
>The kernel already has support for very similar Pioneer djm products and this work is based on that.
>
>Added device to quirks-table.h and added control info to mixer_quirks.c.
>
>Tested on my hardware and all working.
>
>Signed-off-by: William Overton <willovertonuk at gmail.com>
>---
> sound/usb/mixer_quirks.c | 34 +++++++++++++++++++++++
> sound/usb/quirks-table.h | 58 ++++++++++++++++++++++++++++++++++++++++
> 2 files changed, 92 insertions(+)
>
>diff --git a/sound/usb/mixer_quirks.c b/sound/usb/mixer_quirks.c
>index 46082dc57be0..d489c1de3bae 100644
>--- a/sound/usb/mixer_quirks.c
>+++ b/sound/usb/mixer_quirks.c
>@@ -2795,6 +2795,7 @@ static int snd_bbfpro_controls_create(struct usb_mixer_interface *mixer)
> #define SND_DJM_750_IDX 0x1
> #define SND_DJM_850_IDX 0x2
> #define SND_DJM_900NXS2_IDX 0x3
>+#define SND_DJM_750MK2_IDX 0x4
>
>
> #define SND_DJM_CTL(_name, suffix, _default_value, _windex) { \
>@@ -2984,10 +2985,40 @@ static const struct snd_djm_ctl snd_djm_ctls_900nxs2[] = {
> SND_DJM_CTL("Ch5 Input", 900nxs2_cap5, 3, SND_DJM_WINDEX_CAP)
> };
>
>+// DJM-750MK2
>+static const u16 snd_djm_opts_750mk2_cap1[] = {
>+ 0x0100, 0x0102, 0x0103, 0x0106, 0x0107, 0x0108, 0x0109, 0x010a };
>+static const u16 snd_djm_opts_750mk2_cap2[] = {
>+ 0x0200, 0x0202, 0x0203, 0x0206, 0x0207, 0x0208, 0x0209, 0x020a };
>+static const u16 snd_djm_opts_750mk2_cap3[] = {
>+ 0x0300, 0x0302, 0x0303, 0x0306, 0x0307, 0x0308, 0x0309, 0x030a };
>+static const u16 snd_djm_opts_750mk2_cap4[] = {
>+ 0x0400, 0x0402, 0x0403, 0x0406, 0x0407, 0x0408, 0x0409, 0x040a };
>+static const u16 snd_djm_opts_750mk2_cap5[] = {
>+ 0x0507, 0x0508, 0x0509, 0x050a, 0x0511, 0x0512, 0x0513, 0x0514 };
>+
>+static const u16 snd_djm_opts_750mk2_pb1[] = { 0x0100, 0x0101, 0x0104 };
>+static const u16 snd_djm_opts_750mk2_pb2[] = { 0x0200, 0x0201, 0x0204 };
>+static const u16 snd_djm_opts_750mk2_pb3[] = { 0x0300, 0x0301, 0x0304 };
>+
>+
>+static const struct snd_djm_ctl snd_djm_ctls_750mk2[] = {
>+ SND_DJM_CTL("Capture Level", cap_level, 0, SND_DJM_WINDEX_CAPLVL),
>+ SND_DJM_CTL("Ch1 Input", 750mk2_cap1, 2, SND_DJM_WINDEX_CAP),
>+ SND_DJM_CTL("Ch2 Input", 750mk2_cap2, 2, SND_DJM_WINDEX_CAP),
>+ SND_DJM_CTL("Ch3 Input", 750mk2_cap3, 2, SND_DJM_WINDEX_CAP),
>+ SND_DJM_CTL("Ch4 Input", 750mk2_cap4, 2, SND_DJM_WINDEX_CAP),
>+ SND_DJM_CTL("Ch5 Input", 750mk2_cap5, 3, SND_DJM_WINDEX_CAP),
>+ SND_DJM_CTL("Ch1 Output", 750mk2_pb1, 0, SND_DJM_WINDEX_PB),
>+ SND_DJM_CTL("Ch2 Output", 750mk2_pb2, 1, SND_DJM_WINDEX_PB),
>+ SND_DJM_CTL("Ch3 Output", 750mk2_pb3, 2, SND_DJM_WINDEX_PB)
>+};
>+
>
> static const struct snd_djm_device snd_djm_devices[] = {
> SND_DJM_DEVICE(250mk2),
> SND_DJM_DEVICE(750),
>+ SND_DJM_DEVICE(750mk2),
> SND_DJM_DEVICE(850),
> SND_DJM_DEVICE(900nxs2)
> };
>@@ -3235,6 +3266,9 @@ int snd_usb_mixer_apply_create_quirk(struct usb_mixer_interface *mixer)
> case USB_ID(0x08e4, 0x017f): /* Pioneer DJ DJM-750 */
> err = snd_djm_controls_create(mixer, SND_DJM_750_IDX);
> break;
>+ case USB_ID(0x2b73, 0x001b): /* Pioneer DJ DJM-750MK2 */
>+ err = snd_djm_controls_create(mixer, SND_DJM_750MK2_IDX);
>+ break;
> case USB_ID(0x08e4, 0x0163): /* Pioneer DJ DJM-850 */
> err = snd_djm_controls_create(mixer, SND_DJM_850_IDX);
> break;
>diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h
>index e03043f7dad3..bc0116273e94 100644
>--- a/sound/usb/quirks-table.h
>+++ b/sound/usb/quirks-table.h
>@@ -3850,6 +3850,64 @@ YAMAHA_DEVICE(0x7010, "UB99"),
> }
> }
> },
>+{
>+ /*
>+ * Pioneer DJ DJM-750MK2
>+ * 10 channels playback & 12 channels capture @ 48kHz S24LE
>+ */
>+ USB_DEVICE_VENDOR_SPEC(0x2b73, 0x001b),
>+ .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 = 10,
>+ .iface = 0,
>+ .altsetting = 1,
>+ .altset_idx = 1,
>+ .endpoint = 0x01,
>+ .ep_attr = USB_ENDPOINT_XFER_ISOC|
>+ USB_ENDPOINT_SYNC_ASYNC,
>+ .rates = SNDRV_PCM_RATE_48000,
>+ .rate_min = 48000,
>+ .rate_max = 48000,
>+ .nr_rates = 1,
>+ .rate_table = (unsigned int[]) {
>+ 48000
>+ }
>+ }
>+ },
>+ {
>+ .ifnum = 0,
>+ .type = QUIRK_AUDIO_FIXED_ENDPOINT,
>+ .data = &(const struct audioformat) {
>+ .formats = SNDRV_PCM_FMTBIT_S24_3LE,
>+ .channels = 12,
>+ .iface = 0,
>+ .altsetting = 1,
>+ .altset_idx = 1,
>+ .endpoint = 0x82,
>+ .ep_idx = 1,
>+ .ep_attr = USB_ENDPOINT_XFER_ISOC|
>+ USB_ENDPOINT_SYNC_ASYNC|
>+ USB_ENDPOINT_USAGE_IMPLICIT_FB,
>+ .rates = SNDRV_PCM_RATE_48000,
>+ .rate_min = 48000,
>+ .rate_max = 48000,
>+ .nr_rates = 1,
>+ .rate_table = (unsigned int[]) { 48000 }
>+ }
>+ },
>+ {
>+ .ifnum = -1
>+ }
>+ }
>+ }
>+},
> {
> /*
> * Pioneer DJ DJM-850
This patch has potentially introduced a bug in mixer controls for other devices. The device index should match the position in the array. Should add "SND_DJM_DEVICE(750mk2)," if the IDX is 0x4.
Will make a patch and add comment if I have the time.
Olivia
More information about the Alsa-devel
mailing list