ALSA: isight: fix hang when unplugging a running device
authorClemens Ladisch <clemens@ladisch.de>
Wed, 11 May 2011 08:53:12 +0000 (10:53 +0200)
committerTakashi Iwai <tiwai@suse.de>
Wed, 11 May 2011 12:53:08 +0000 (14:53 +0200)
When aborting a PCM stream, the xrun is signaled only if the stream is
running.  When disconnecting a PCM stream, calling snd_card_disconnect()
too early would change the stream into a non-running state and thus
prevent the xrun from being noticed by user space.

To prevent this, move the snd_card_disconnect() call after the xrun.

Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/firewire/isight.c

index 4d2edcfdbbca67b26570a6b1d39c4cbc6e582554..96267437d373170236bf893c5f6f3bb338dd05d7 100644 (file)
@@ -692,10 +692,9 @@ static int isight_remove(struct device *dev)
 {
        struct isight *isight = dev_get_drvdata(dev);
 
-       snd_card_disconnect(isight->card);
-
        mutex_lock(&isight->mutex);
        isight_pcm_abort(isight);
+       snd_card_disconnect(isight->card);
        isight_stop_streaming(isight);
        mutex_unlock(&isight->mutex);