Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a0978e80 authored by Stefan Richter's avatar Stefan Richter Committed by Takashi Iwai
Browse files

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 f3f7c183
"ALSA: isight: fix locking").

Signed-off-by: default avatarStefan Richter <stefanr@s5r6.in-berlin.de>
Signed-off-by: default avatarClemens Ladisch <clemens@ladisch.de>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent bb690c9e
Loading
Loading
Loading
Loading
+3 −2
Original line number Diff line number Diff line
@@ -778,9 +778,10 @@ static int __devexit fwspk_remove(struct device *dev)
{
	struct fwspk *fwspk = dev_get_drvdata(dev);

	mutex_lock(&fwspk->mutex);
	amdtp_out_stream_pcm_abort(&fwspk->stream);
	snd_card_disconnect(fwspk->card);

	mutex_lock(&fwspk->mutex);
	fwspk_stop_stream(fwspk);
	mutex_unlock(&fwspk->mutex);

@@ -796,8 +797,8 @@ static void fwspk_bus_reset(struct fw_unit *unit)
	fcp_bus_reset(fwspk->unit);

	if (cmp_connection_update(&fwspk->connection) < 0) {
		mutex_lock(&fwspk->mutex);
		amdtp_out_stream_pcm_abort(&fwspk->stream);
		mutex_lock(&fwspk->mutex);
		fwspk_stop_stream(fwspk);
		mutex_unlock(&fwspk->mutex);
		return;