[ALSA] Fix the race of card instance unregistration
Move the call of device_unregister() for the card instance in snd_card_disconnect() to avoid the race of sysfs card entry, which can be typically found on usb-audio reconnection. Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
20861fa7b2
commit
73d38b13ff
|
@ -360,6 +360,12 @@ int snd_card_disconnect(struct snd_card *card)
|
||||||
snd_printk(KERN_ERR "not all devices for card %i can be disconnected\n", card->number);
|
snd_printk(KERN_ERR "not all devices for card %i can be disconnected\n", card->number);
|
||||||
|
|
||||||
snd_info_card_disconnect(card);
|
snd_info_card_disconnect(card);
|
||||||
|
#ifndef CONFIG_SYSFS_DEPRECATED
|
||||||
|
if (card->card_dev) {
|
||||||
|
device_unregister(card->card_dev);
|
||||||
|
card->card_dev = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -401,10 +407,6 @@ static int snd_card_do_free(struct snd_card *card)
|
||||||
snd_printk(KERN_WARNING "unable to free card info\n");
|
snd_printk(KERN_WARNING "unable to free card info\n");
|
||||||
/* Not fatal error */
|
/* Not fatal error */
|
||||||
}
|
}
|
||||||
#ifndef CONFIG_SYSFS_DEPRECATED
|
|
||||||
if (card->card_dev)
|
|
||||||
device_unregister(card->card_dev);
|
|
||||||
#endif
|
|
||||||
kfree(card);
|
kfree(card);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue