[alsa-devel] Sound UsbPre : minimal patch for support

Takashi Iwai tiwai at suse.de
Mon Dec 7 17:50:16 CET 2015


On Thu, 26 Nov 2015 21:28:57 +0100,
shal at free.fr wrote:
> 
> Hello,
> 
> I have a Sound UsbPre (the first not the UsbPRe2) sound card.
> There is no support for this card in alsa.
> I do a usb packet sniffing on Windows for detect problem.
> Some control quirk should be added at boot in order to use the card.
> 
> It works to play and record in 44100 khz.
> It works only with 44100khz (for example, if you play a 88200 file, it will be played too slow).
> This patch is not well tested, work on my desktop : Linux Ubuntu with 4.2.19-lowlatency kernel.
> 
> The button emulation is not done (by a control packet, you can change the card configuration, like phantom power activation).
> If somebody is interested, I can provide needed information.
> 
> If Alsa's developer is interested, I can provide support for test patches or develop a second version of this patch in order to integrate the support for this card in the linux kernel 

Yeah, sure it'd be great if you can polish and submit the patch.  Even
with a limited support, it's much better than nothing.


thanks,

Takashi

> 
> Regards,
> Olivier
> 
> 
> linux-source-4.2.0/sound/usb$ diff -rub quirks.c.ORIG quirks.c 
> --- quirks.c.ORIG	2015-11-24 22:43:16.878635155 +0100
> +++ quirks.c	2015-11-26 20:56:09.492126460 +0100
> @@ -601,6 +601,40 @@
>  	return 0;
>  }
>  
> +/* Add some control messages needed by Sound Devices UsbPre. 
> + * Values here are chosen based on sniffing USB traffic
> + * under Windows.*/
> +static int snd_usb_usbpre_boot_quirk(struct usb_device *dev)
> +{
> +    u8 buf = 1;
> +    u8 data1[1] = {0x81};
> +    u8 data2[1] = {0xc1};
> +    u8 data3[3] = {0x44,0xac,0x00};
> +
> +	snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), 1,
> +				USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
> +				0x00f0, 496, data1, 1);
> +	snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), 0x81 ,
> +			    USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
> +			    0x00f0, 0, &buf, 1);		
> +	if (buf == 0) {
> +		return -ENODEV;
> +	}
> +	snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), 1,
> +				USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
> +				0x00f0, 496, data2, 1);
> +	snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), 0x81 ,
> +			    USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
> +			    0x00f0, 0, &buf, 1);		
> +	if (buf == 0) {
> +		return -ENODEV;
> +	}
> +	snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), 1,
> +				USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_ENDPOINT,
> +				0x0100, 133, data3, 3);
> +	return 0;
> +}
> +
>  static int snd_usb_fasttrackpro_boot_quirk(struct usb_device *dev)
>  {
>  	int err;
> @@ -985,6 +1019,10 @@
>  		/* SB Audigy 2 NX needs its own boot-up magic, too */
>  		return snd_usb_audigy2nx_boot_quirk(dev);
>  
> +	case USB_ID(0x0926, 0x0100):
> +		/* Sound Devices UsbPre needs its own boot-up magic, too */
> +		return snd_usb_usbpre_boot_quirk(dev);
> +
>  	case USB_ID(0x10f5, 0x0200):
>  		/* C-Media CM106 / Turtle Beach Audio Advantage Roadie */
>  		return snd_usb_cm106_boot_quirk(dev);
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> 


More information about the Alsa-devel mailing list