]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ALSA: usb-audio: qcom: Use snprintf for mixer control name formatting
authorwangdicheng <wangdicheng@kylinos.cn>
Wed, 3 Jun 2026 09:11:00 +0000 (17:11 +0800)
committerTakashi Iwai <tiwai@suse.de>
Thu, 4 Jun 2026 08:15:09 +0000 (10:15 +0200)
The current code uses sprintf() to format control names without bounds
checking, which could lead to buffer overflow if PCM index is large.
Replace sprintf with snprintf to ensure buffer safety.

The ctl_name buffer is 48 bytes, and the formatted string could exceed
this with large PCM index values. Using snprintf with sizeof(ctl_name)
prevents potential buffer overflow.

Signed-off-by: wangdicheng <wangdicheng@kylinos.cn>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Link: https://patch.msgid.link/20260603091102.231370-2-wangdich9700@163.com
sound/usb/qcom/mixer_usb_offload.c

index 2adeb64f4d33f4c33a915d3a895a071fd8d0630c..48e55d5872d504cf13161f67baa18798c3712702 100644 (file)
@@ -128,7 +128,7 @@ int snd_usb_offload_create_ctl(struct snd_usb_audio *chip, struct device *bedev)
                 */
                chip_kctl->private_value = as->pcm_index |
                                          chip->card->number << 16;
-               sprintf(ctl_name, "USB Offload Playback Card Route PCM#%d",
+               snprintf(ctl_name, sizeof(ctl_name), "USB Offload Playback Card Route PCM#%d",
                        as->pcm_index);
                chip_kctl->name = ctl_name;
                ret = snd_ctl_add(chip->card, snd_ctl_new1(chip_kctl, bedev));
@@ -143,7 +143,7 @@ int snd_usb_offload_create_ctl(struct snd_usb_audio *chip, struct device *bedev)
                 */
                chip_kctl->private_value = as->pcm_index |
                                          chip->card->number << 16;
-               sprintf(ctl_name, "USB Offload Playback PCM Route PCM#%d",
+               snprintf(ctl_name, sizeof(ctl_name), "USB Offload Playback PCM Route PCM#%d",
                        as->pcm_index);
                chip_kctl->name = ctl_name;
                ret = snd_ctl_add(chip->card, snd_ctl_new1(chip_kctl, bedev));