aboutsummaryrefslogtreecommitdiffstats
path: root/sound
diff options
context:
space:
mode:
authorClemens Ladisch <clemens@ladisch.de>2011-09-04 16:13:09 -0400
committerClemens Ladisch <clemens@ladisch.de>2013-10-20 16:07:57 -0400
commit4ed31f20bb5bb90f003c91734c6b9d18169ae27e (patch)
tree087b7c0e23a5c7eb8ce00e3d69c4d78186bc98f5 /sound
parente84d15f619c13e83b33023c84527ee35ef01b6b4 (diff)
ALSA: dice: 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>
Diffstat (limited to 'sound')
-rw-r--r--sound/firewire/dice.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/sound/firewire/dice.c b/sound/firewire/dice.c
index 63446f86cdd7..d0575a96ea70 100644
--- a/sound/firewire/dice.c
+++ b/sound/firewire/dice.c
@@ -1000,12 +1000,15 @@ static void dice_remove(struct fw_unit *unit)
1000{ 1000{
1001 struct dice *dice = dev_get_drvdata(&unit->device); 1001 struct dice *dice = dev_get_drvdata(&unit->device);
1002 1002
1003 snd_card_disconnect(dice->card);
1004
1005 mutex_lock(&dice->mutex); 1003 mutex_lock(&dice->mutex);
1004
1006 amdtp_out_stream_pcm_abort(&dice->stream); 1005 amdtp_out_stream_pcm_abort(&dice->stream);
1006
1007 snd_card_disconnect(dice->card);
1008
1007 dice_stream_stop(dice); 1009 dice_stream_stop(dice);
1008 dice_owner_clear(dice); 1010 dice_owner_clear(dice);
1011
1009 mutex_unlock(&dice->mutex); 1012 mutex_unlock(&dice->mutex);
1010 1013
1011 snd_card_free_when_closed(dice->card); 1014 snd_card_free_when_closed(dice->card);