aboutsummaryrefslogtreecommitdiffstats
path: root/sound/firewire/isight.c
diff options
context:
space:
mode:
authorClemens Ladisch <clemens@ladisch.de>2011-05-11 04:53:12 -0400
committerTakashi Iwai <tiwai@suse.de>2011-05-11 08:53:08 -0400
commitaee70400184b6a8d39243b02c244aed61259a46b (patch)
tree64c38230831c5ec11b07a03467baa25eb4cf9cd5 /sound/firewire/isight.c
parentac34dad26e6786257ef54d8df4f883825bea02eb (diff)
ALSA: isight: fix hang when unplugging a running device
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>
Diffstat (limited to 'sound/firewire/isight.c')
-rw-r--r--sound/firewire/isight.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/sound/firewire/isight.c b/sound/firewire/isight.c
index 4d2edcfdbbca..96267437d373 100644
--- a/sound/firewire/isight.c
+++ b/sound/firewire/isight.c
@@ -692,10 +692,9 @@ static int isight_remove(struct device *dev)
692{ 692{
693 struct isight *isight = dev_get_drvdata(dev); 693 struct isight *isight = dev_get_drvdata(dev);
694 694
695 snd_card_disconnect(isight->card);
696
697 mutex_lock(&isight->mutex); 695 mutex_lock(&isight->mutex);
698 isight_pcm_abort(isight); 696 isight_pcm_abort(isight);
697 snd_card_disconnect(isight->card);
699 isight_stop_streaming(isight); 698 isight_stop_streaming(isight);
700 mutex_unlock(&isight->mutex); 699 mutex_unlock(&isight->mutex);
701 700