Takashi Iwai f488d0
From 06764dc931848c3a9bc01a63bbf76a605408bb54 Mon Sep 17 00:00:00 2001
Takashi Iwai f488d0
From: Takashi Iwai <tiwai@suse.de>
Takashi Iwai f488d0
Date: Tue, 16 Nov 2021 08:13:12 +0100
Takashi Iwai f488d0
Subject: [PATCH] ALSA: jack: Add missing rwsem around snd_ctl_remove() calls
Takashi Iwai f488d0
Git-commit: 06764dc931848c3a9bc01a63bbf76a605408bb54
Takashi Iwai f488d0
Patch-mainline: v5.17-rc1
Takashi Iwai f488d0
References: git-fixes
Takashi Iwai f488d0
Takashi Iwai f488d0
snd_ctl_remove() has to be called with card->controls_rwsem held (when
Takashi Iwai f488d0
called after the card instantiation).  This patch add the missing
Takashi Iwai f488d0
rwsem calls around it.
Takashi Iwai f488d0
Takashi Iwai f488d0
Fixes: 9058cbe1eed2 ("ALSA: jack: implement kctl creating for jack devices")
Takashi Iwai f488d0
Link: https://lore.kernel.org/r/20211116071314.15065-1-tiwai@suse.de
Takashi Iwai f488d0
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Takashi Iwai f488d0
Takashi Iwai f488d0
---
Takashi Iwai f488d0
 sound/core/jack.c | 3 +++
Takashi Iwai f488d0
 1 file changed, 3 insertions(+)
Takashi Iwai f488d0
Takashi Iwai f488d0
diff --git a/sound/core/jack.c b/sound/core/jack.c
Takashi Iwai f488d0
index 32350c6aba84..f50a1e920e1d 100644
Takashi Iwai f488d0
--- a/sound/core/jack.c
Takashi Iwai f488d0
+++ b/sound/core/jack.c
Takashi Iwai f488d0
@@ -62,10 +62,13 @@ static int snd_jack_dev_free(struct snd_device *device)
Takashi Iwai f488d0
 	struct snd_card *card = device->card;
Takashi Iwai f488d0
 	struct snd_jack_kctl *jack_kctl, *tmp_jack_kctl;
Takashi Iwai f488d0
 
Takashi Iwai f488d0
+	down_write(&card->controls_rwsem);
Takashi Iwai f488d0
 	list_for_each_entry_safe(jack_kctl, tmp_jack_kctl, &jack->kctl_list, list) {
Takashi Iwai f488d0
 		list_del_init(&jack_kctl->list);
Takashi Iwai f488d0
 		snd_ctl_remove(card, jack_kctl->kctl);
Takashi Iwai f488d0
 	}
Takashi Iwai f488d0
+	up_write(&card->controls_rwsem);
Takashi Iwai f488d0
+
Takashi Iwai f488d0
 	if (jack->private_free)
Takashi Iwai f488d0
 		jack->private_free(jack);
Takashi Iwai f488d0
 
Takashi Iwai f488d0
-- 
Takashi Iwai f488d0
2.31.1
Takashi Iwai f488d0