ALSA: dice: fix locking
authorStefan Richter <stefanr@s5r6.in-berlin.de>
Sat, 27 Aug 2011 18:05:15 +0000 (20:05 +0200)
committerClemens Ladisch <clemens@ladisch.de>
Sun, 20 Oct 2013 20:07:57 +0000 (22:07 +0200)
Avoid a lock inversion between dice->mutex and pcm->open_mutex.

Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
sound/firewire/dice.c

index 2d198aed6f94bafb0f7be5547641dc7e0d413cd8..2d3a04ef9840ef971e38ed6f86eea73437f234cf 100644 (file)
@@ -981,12 +981,12 @@ static void dice_remove(struct fw_unit *unit)
 {
        struct dice *dice = dev_get_drvdata(&unit->device);
 
-       mutex_lock(&dice->mutex);
-
        amdtp_out_stream_pcm_abort(&dice->stream);
 
        snd_card_disconnect(dice->card);
 
+       mutex_lock(&dice->mutex);
+
        dice_stream_stop(dice);
        dice_owner_clear(dice);
 
@@ -999,8 +999,6 @@ static void dice_bus_reset(struct fw_unit *unit)
 {
        struct dice *dice = dev_get_drvdata(&unit->device);
 
-       mutex_lock(&dice->mutex);
-
        /*
         * On a bus reset, the DICE firmware disables streaming and then goes
         * off contemplating its own navel for hundreds of milliseconds before
@@ -1011,6 +1009,8 @@ static void dice_bus_reset(struct fw_unit *unit)
         */
        amdtp_out_stream_pcm_abort(&dice->stream);
 
+       mutex_lock(&dice->mutex);
+
        dice->global_enabled = false;
        dice_stream_stop_packets(dice);