Re: [PATCH v30 00/30] Introduce QC USB SND audio offloading support

From: Cezary Rojewski
Date: Tue Dec 03 2024 - 12:42:23 EST


On 2024-12-01 4:14 AM, Pierre-Louis Bossart wrote:
Sorry to chime in late, I only look at email occasionally.


...

My Reviewed-by tags were added in the last updates. I am not sure if anyone else at Intel had the time to review this large patchset.

I believe Amadeusz was still against having the two card design, and wants the routing to automatically happen when playback happens on the sound card created by the USB SND layer. However, even with that kind of implementation, the major pieces brought in by this series should still be relevant, ie soc-usb and the vendor offload driver. The only thing that would really change is adding a path from the USB SND PCM ops to interact with the ASoC entities. Complexity-wise, this would obviously have a good amount of changes to the USB SND/ASoC core drivers. Some things I can think of that we'd need to introduce:

The notion of two cards was agreed inside Intel as far back as 2018, when Rakesh first looked at USB offload.


Well, I believe a lot has changed since then, not sure if USB Audio Offload (UAOL) was even stable on the Windows solution back then. Obviously we want to incorporate what we have learned during all that time into our solution before it lands on upstream.

UAOL is one of our priorities right now and some (e.g.: me) prefer to not pollute their mind with another approaches until what they have in mind is crystalized. In short, I'd vote for a approach where USB device has a ASoC representative in sound/soc/codecs/ just like it is the case for HDAudio. Either that or at least a ASoC-component representative, a dependency for UAOL-capable card to enumerate.

Currently struct snd_soc_usb does not represent any component at all. Lack of codec representative, component representative and, given my current understanding, mixed dependency of sound/usb on sound/soc/soc-usb does lead to hard-to-understand ASoC solution.


Having a single USB card in IMHO more complicated: what happens for example if you plug-in two or more USB devices? Which of the USB cards will expose an optimized path? The design with an ASoC-based card which exposes as many PCM devices as the SOC can support is simpler conceptually and scales well. This would allow e.g. to allocate these PCM devices with different policies (last plugged, preferred, etc).

Conceptually for the simple case with a single USB device, it does not really matter if there are two cards or not. What matters is that there is a clear mapping visible to userspace so that application can decide to use the optimized PCM device, when enabled, instead of the legacy one. And in the end, the application is *always* in control in terms of routing. It’s really similar to the compress offload path, some application changes will be required.


1. Exposing some of the ASoC PCM (soc-pcm) APIs to be able to be called by soc-usb (to mimic a FE open from ASoC), so we can trigger ASoC DAI ops when USB SND FE is opened.

2. Proper fallback mechanism in case offload path enablement fails to the legacy USB SND path.

3. Master kcontrol to disable offload logic for each USB SND device.

IMO, both the points you mentioned correspond to the same topic. If we go with having offload being operated on one FE, then there is no need for the kcontrol of PCM mapping. If we have two cards, then we will need the control for offload device mapping. Can't speak for Pierre, but at least with my discussions with him, I don't think he's against the two card design, just as long as we have the proper kcontrol that notifies userspace of how to utilize the offload path.

Even if there’s a single card you need to have a mapping between a ‘legacy’ PCM device and an ‘optimized’ one. This would be a scalar mapping instead of a (card, device) pair, but it’s a minor change.

-Pierre