wait_queue_head_t shutdown_sleep;
struct work_struct free_workq; /* for free in workqueue */
struct device *dev;
+ struct class_device *parent_device;
#ifdef CONFIG_PM
unsigned int power_state; /* power state */
int err;
snd_assert(card != NULL, return -ENXIO);
- list_for_each(list, &card->devices) {
+ list_for_each_prev(list, &card->devices) {
dev = snd_device(list);
if (dev->state == SNDRV_DEV_BUILD && dev->ops->dev_register) {
if ((err = dev->ops->dev_register(dev)) < 0)
int minor;
struct snd_minor *preg;
struct device *device = NULL;
+ struct class_device *class_device = NULL;
snd_assert(name, return -EINVAL);
preg = kmalloc(sizeof(struct snd_minor) + strlen(name) + 1, GFP_KERNEL);
snd_minors[minor] = preg;
if (type != SNDRV_DEVICE_TYPE_CONTROL || preg->card >= cards_limit)
devfs_mk_cdev(MKDEV(major, minor), S_IFCHR | device_mode, "snd/%s", name);
- if (card)
+ if (card) {
device = card->dev;
- class_device_create(sound_class, NULL, MKDEV(major, minor), device, "%s", name);
+ class_device = card->parent_device;
+ }
+ class_device = class_device_create(sound_class, class_device,
+ MKDEV(major, minor), device,
+ "%s", name);
+ if (type == SNDRV_DEVICE_TYPE_CONTROL)
+ card->parent_device = class_device;
up(&sound_mutex);
return 0;