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