On Wed, 13 Jan 2021 16:03:39 +0100, Bastien Nocera wrote: > > On Wed, 2021-01-13 at 15:49 +0100, Takashi Iwai wrote: > > On Wed, 13 Jan 2021 15:36:19 +0100, > > Bastien Nocera wrote: > > > > > > Hey, > > > > > > On Wed, 2020-12-09 at 14:30 +0100, Bastien Nocera wrote: > > > > Hey, > > > > > > > > I've recently bought a SteelSeries Arctis 1 wireless headset: > > > > https://steelseries.com/gaming-headsets/arctis-1-wireless-xbox > > > > and wanted to write a kernel driver to export a few features of > > > > the > > > > device, and needed some help getting started. > > > > > > > > The receiver shows up as a audio class USB device, with extra > > > > features > > > > on a separate USB interface.[1] > > > > > > > > The extra features that can be accessed are: > > > > - Presence detection. I wanted to use that so PulseAudio or > > > > Pipewire > > > > could make routing decisions based on whether the headset is > > > > available, > > > > or probably better, implementing a "jack detection" emulation for > > > > the > > > > main audio interface? > > > > - A slider to change the sidetone volume > > > > - Export the battery level > > > > > > > > The latter is the only one I know how to do, so I'd be happy with > > > > any > > > > pointers or examples about the first two items. > > > > > > > > > I sent this in December and didn't get any answers, and I would > > > appreciate any guidance/examples if you have any into implementing > > > this. > > > > Judging from the link, is it controlled through HID? If so, it's > > primarily done by a HID driver, and it doesn't belong to the sound > > card stuff, so far. > > Though.... > > > > > I would imagine that the new features would be implemented through > > > a > > > separate ALSA device with few features, which PulseAudio/Pipewire > > > could > > > merge with the existing USB audio device. > > > > ... given that it's implemented in a HID driver, the integration to > > the system is a different question. But unless it's implemented as a > > sound card device, the rest will become a totally different, > > e.g. another PA or PW module. > > I think that it might be good to have the sidetone configuration > implemented as a channel mixer, so it could be shown along with the > device volume in sound settings. > > I believe there's already a device group feature in PulseAudio that > could be used to merge the sidetone level with the rest of the USB > audio mixers. > > Is there an example of a mixer like that implemented in a hid or > another type of non-ALSA/sound driver? Nothing so far, and that's the problem. HID is managed in a completely different layer, hence the integration needs to be done in a higher level like PA, I suppose. In theory we might be able to extend UCM to handle the other external devices, though. Takashi