aboutsummaryrefslogtreecommitdiffstats
path: root/sound/firewire
diff options
context:
space:
mode:
authorStefan Richter <stefanr@s5r6.in-berlin.de>2011-08-27 10:45:28 -0400
committerTakashi Iwai <tiwai@suse.de>2011-10-04 01:16:31 -0400
commita0978e8039f1b1bfb9fbc68f682b14313bb4f9ad (patch)
tree1c255087a112e82598000df49d13e25a5c61b9e9 /sound/firewire
parentbb690c9e2702e49af3be2fb6f03d9b60e0afcab7 (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.c5
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;