diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2011-09-04 16:13:09 -0400 |
---|---|---|
committer | Clemens Ladisch <clemens@ladisch.de> | 2013-10-20 16:07:57 -0400 |
commit | 4ed31f20bb5bb90f003c91734c6b9d18169ae27e (patch) | |
tree | 087b7c0e23a5c7eb8ce00e3d69c4d78186bc98f5 /sound | |
parent | e84d15f619c13e83b33023c84527ee35ef01b6b4 (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.c | 7 |
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); |