]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ALSA: scarlett2: Add missing mutex lock around get meter levels
authorGeoffrey D. Bennett <g@b4.vu>
Tue, 19 Dec 2023 17:38:09 +0000 (04:08 +1030)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Jan 2024 23:45:07 +0000 (15:45 -0800)
[ Upstream commit 993f7b42fa066b055e3a19b7f76ad8157c0927a0 ]

As scarlett2_meter_ctl_get() uses meter_level_map[], the data_mutex
should be locked while accessing it.

Signed-off-by: Geoffrey D. Bennett <g@b4.vu>
Fixes: 3473185f31df ("ALSA: scarlett2: Remap Level Meter values")
Link: https://lore.kernel.org/r/77e093c27402c83d0730681448fa4f57583349dd.1703001053.git.g@b4.vu
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
sound/usb/mixer_scarlett2.c

index cdaf0470e62b6635c1852683cdd657babab71229..3b7fcd0907e673b41d45f1dc69010b98f9cc4f8d 100644 (file)
@@ -3880,10 +3880,12 @@ static int scarlett2_meter_ctl_get(struct snd_kcontrol *kctl,
        u16 meter_levels[SCARLETT2_MAX_METERS];
        int i, err;
 
+       mutex_lock(&private->data_mutex);
+
        err = scarlett2_usb_get_meter_levels(elem->head.mixer, elem->channels,
                                             meter_levels);
        if (err < 0)
-               return err;
+               goto unlock;
 
        /* copy & translate from meter_levels[] using meter_level_map[] */
        for (i = 0; i < elem->channels; i++) {
@@ -3898,7 +3900,10 @@ static int scarlett2_meter_ctl_get(struct snd_kcontrol *kctl,
                ucontrol->value.integer.value[i] = value;
        }
 
-       return 0;
+unlock:
+       mutex_unlock(&private->data_mutex);
+
+       return err;
 }
 
 static const struct snd_kcontrol_new scarlett2_meter_ctl = {