diff options
author | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2011-08-27 10:45:28 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2011-10-04 01:16:31 -0400 |
commit | a0978e8039f1b1bfb9fbc68f682b14313bb4f9ad (patch) | |
tree | 1c255087a112e82598000df49d13e25a5c61b9e9 /sound/firewire | |
parent | bb690c9e2702e49af3be2fb6f03d9b60e0afcab7 (diff) |
ALSA: firewire-speakers: fix locking
There is a lock inversion between fwspk->mutex and pcm->open_mutex
reported by lockdep when fwspk_hw_free is called.
Fixed by copying the fix from the same former issue in the isight
sound driver (commit f3f7c1837f6bcae3601fc535b339426868bf1549
"ALSA: isight: fix locking").
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/firewire')
-rw-r--r-- | sound/firewire/speakers.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/sound/firewire/speakers.c b/sound/firewire/speakers.c index 3fc257da180c..cbe6bb9e53b6 100644 --- a/sound/firewire/speakers.c +++ b/sound/firewire/speakers.c | |||
@@ -778,9 +778,10 @@ static int __devexit fwspk_remove(struct device *dev) | |||
778 | { | 778 | { |
779 | struct fwspk *fwspk = dev_get_drvdata(dev); | 779 | struct fwspk *fwspk = dev_get_drvdata(dev); |
780 | 780 | ||
781 | mutex_lock(&fwspk->mutex); | ||
782 | amdtp_out_stream_pcm_abort(&fwspk->stream); | 781 | amdtp_out_stream_pcm_abort(&fwspk->stream); |
783 | snd_card_disconnect(fwspk->card); | 782 | snd_card_disconnect(fwspk->card); |
783 | |||
784 | mutex_lock(&fwspk->mutex); | ||
784 | fwspk_stop_stream(fwspk); | 785 | fwspk_stop_stream(fwspk); |
785 | mutex_unlock(&fwspk->mutex); | 786 | mutex_unlock(&fwspk->mutex); |
786 | 787 | ||
@@ -796,8 +797,8 @@ static void fwspk_bus_reset(struct fw_unit *unit) | |||
796 | fcp_bus_reset(fwspk->unit); | 797 | fcp_bus_reset(fwspk->unit); |
797 | 798 | ||
798 | if (cmp_connection_update(&fwspk->connection) < 0) { | 799 | if (cmp_connection_update(&fwspk->connection) < 0) { |
799 | mutex_lock(&fwspk->mutex); | ||
800 | amdtp_out_stream_pcm_abort(&fwspk->stream); | 800 | amdtp_out_stream_pcm_abort(&fwspk->stream); |
801 | mutex_lock(&fwspk->mutex); | ||
801 | fwspk_stop_stream(fwspk); | 802 | fwspk_stop_stream(fwspk); |
802 | mutex_unlock(&fwspk->mutex); | 803 | mutex_unlock(&fwspk->mutex); |
803 | return; | 804 | return; |