#include <linux/usb/audio.h>
#include <linux/usb/audio-v2.h>
#include <linux/module.h>
+#include <linux/switch.h>
#include <sound/control.h>
#include <sound/core.h>
static DEFINE_MUTEX(register_mutex);
static struct snd_usb_audio *usb_chip[SNDRV_CARDS];
static struct usb_driver usb_audio_driver;
+#ifdef CONFIG_SND_RK_SOC
+#define USB_AUDIO_CARD_NUM 2
+struct switch_dev *usb_audio_sdev;
+#endif
/*
* disconnect streams
snd_printk(KERN_ERR "unknown device speed %d\n", snd_usb_get_speed(dev));
return -ENXIO;
}
-
+#ifdef CONFIG_SND_RK_SOC
+ err = snd_card_create(USB_AUDIO_CARD_NUM, id[idx], THIS_MODULE, 0, &card);
+#else
err = snd_card_create(index[idx], id[idx], THIS_MODULE, 0, &card);
+#endif
if (err < 0) {
snd_printk(KERN_ERR "cannot create card instance %d\n", idx);
return err;
chip = snd_usb_audio_probe(interface_to_usbdev(intf), intf, id);
if (chip) {
usb_set_intfdata(intf, chip);
+#ifdef CONFIG_SND_RK_SOC
+ switch_set_state(usb_audio_sdev, 1);
+#endif
return 0;
} else
return -EIO;
static void usb_audio_disconnect(struct usb_interface *intf)
{
+#ifdef CONFIG_SND_RK_SOC
+ switch_set_state(usb_audio_sdev, 0);
+#endif
snd_usb_audio_disconnect(interface_to_usbdev(intf),
usb_get_intfdata(intf));
}
printk(KERN_WARNING "invalid nrpacks value.\n");
return -EINVAL;
}
+
+#ifdef CONFIG_SND_RK_SOC
+ usb_audio_sdev = kzalloc(sizeof(usb_audio_sdev), GFP_KERNEL);
+ usb_audio_sdev->name = "usb_audio";
+ switch_dev_register(usb_audio_sdev);
+ if (!usb_audio_sdev) {
+ printk(KERN_WARNING "usb-audio kmalloc fail!");
+ return -ENOMEM;
+ }
+#endif
+
return usb_register(&usb_audio_driver);
}
static void __exit snd_usb_audio_cleanup(void)
{
usb_deregister(&usb_audio_driver);
+#ifdef CONFIG_SND_RK_SOC
+ kfree(usb_audio_sdev);
+#endif
}
module_init(snd_usb_audio_init);