From: Takashi Iwai <tiwai@suse.de>
To: Asahi Lina <lina@asahilina.net>
Cc: Takashi Iwai <tiwai@suse.de>, Jaroslav Kysela <perex@perex.cz>,
Takashi Iwai <tiwai@suse.com>, "Geoffrey D. Bennett" <g@b4.vu>,
Takashi Sakamoto <o-takashi@sakamocchi.jp>,
Mark Hills <mark@xwax.org>, Arun Raghavan <arun@arunraghavan.net>,
Cyan Nyan <cyan.vtb@gmail.com>,
linux-sound@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH 1/2] ALSA: usb-audio: Add quirk for RME Digiface USB
Date: Mon, 02 Sep 2024 10:16:14 +0200 [thread overview]
Message-ID: <87r0a2ii7l.wl-tiwai@suse.de> (raw)
In-Reply-To: <3980ad8b-d27c-482e-bbb7-3b243ecc8744@asahilina.net>
On Mon, 02 Sep 2024 10:12:18 +0200,
Asahi Lina wrote:
>
>
>
> On 9/2/24 3:10 PM, Takashi Iwai wrote:
> > On Sun, 01 Sep 2024 23:31:50 +0200,
> > Asahi Lina wrote:
> >>
> >> From: Cyan Nyan <cyan.vtb@gmail.com>
> >>
> >> Add trivial support for audio streaming on the RME Digiface USB. Binds
> >> only to the first interface to allow userspace to directly drive the
> >> complex I/O and matrix mixer controls.
> >>
> >> Signed-off-by: Cyan Nyan <cyan.vtb@gmail.com>
> >> [Lina: Added 2x/4x sample rate support & boot/format quirks]
> >> Co-developed-by: Asahi Lina <lina@asahilina.net>
> >> Signed-off-by: Asahi Lina <lina@asahilina.net>
> >> ---
> >> sound/usb/quirks-table.h | 190 ++++++++++++++++++++++++++++++++++++++++++++++-
> >> sound/usb/quirks.c | 58 +++++++++++++++
> >> 2 files changed, 247 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h
> >> index 73abc38a5400..47fd18791396 100644
> >> --- a/sound/usb/quirks-table.h
> >> +++ b/sound/usb/quirks-table.h
> >> @@ -4546,6 +4546,194 @@ YAMAHA_DEVICE(0x7010, "UB99"),
> >> }
> >> }
> >> },
> >> -
> >> +{
> >> + /* Only claim interface 0 */
> >> + .match_flags = USB_DEVICE_ID_MATCH_VENDOR |
> >> + USB_DEVICE_ID_MATCH_PRODUCT |
> >> + USB_DEVICE_ID_MATCH_INT_CLASS |
> >> + USB_DEVICE_ID_MATCH_INT_NUMBER,
> >> + .idVendor = 0x2a39,
> >> + .idProduct = 0x3f8c,
> >> + .bInterfaceClass = USB_CLASS_VENDOR_SPEC,
> >> + .bInterfaceNumber = 0,
> >> + .driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) {
> >> + .ifnum = QUIRK_ANY_INTERFACE,
> >> + .type = QUIRK_COMPOSITE,
> > (snip)
> >
> > Recently the quirk tables are rewritten with macros.
> > See the commit d79e13f8e8abb5cd3a2a0f9fc9bc3fc750c5b06f
> > ALSA: usb-audio: Replace complex quirk lines with macros
> > in for-next branch of sound.git tree.
> >
> > Could you try to apply to your new entries, too?
>
> Sure! Note that I open-coded the USB match because I need to add
> USB_DEVICE_ID_MATCH_INT_NUMBER (to stop the driver from binding to and
> claiming all interfaces, QUIRK_DATA_IGNORE() is not enough for that).
> Should I leave it like that (since it's the only case so far) or do you
> want me to introduce another macro for that case?
The open-code with match_flags is fine, you can keep that.
If we have other similar cases, we can introduce a macro for cleanup
later, too.
> I'll rewrite the quirk info stuff with the macros for v2. I'll also
> remove USB_ENDPOINT_USAGE_IMPLICIT_FB since I'm pretty sure that does
> nothing here (at first I thought I could get it to pick up the implicit
> FB with that but I ended up having to specify the sync/implicit_fb stuff
> explicitly).
Sounds good. Thanks!
Takashi
next prev parent reply other threads:[~2024-09-02 8:15 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-01 21:31 [PATCH 0/2] ALSA: usb-audio: Add basic support for RME Digiface USB Asahi Lina
2024-09-01 21:31 ` [PATCH 1/2] ALSA: usb-audio: Add quirk " Asahi Lina
2024-09-02 6:10 ` Takashi Iwai
2024-09-02 8:12 ` Asahi Lina
2024-09-02 8:16 ` Takashi Iwai [this message]
2024-09-01 21:31 ` [PATCH 2/2] ALSA: usb-audio: Add mixer " Asahi Lina
2024-09-02 7:29 ` kernel test robot
2024-09-02 7:53 ` Asahi Lina
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=87r0a2ii7l.wl-tiwai@suse.de \
--to=tiwai@suse.de \
--cc=arun@arunraghavan.net \
--cc=cyan.vtb@gmail.com \
--cc=g@b4.vu \
--cc=lina@asahilina.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-sound@vger.kernel.org \
--cc=mark@xwax.org \
--cc=o-takashi@sakamocchi.jp \
--cc=perex@perex.cz \
--cc=tiwai@suse.com \
/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