ALSA: control-led: Replace sprintf() with sysfs_emit()

For sysfs outputs, it's safer to use a new helper, sysfs_emit(),
instead of the raw sprintf() & co.  This patch replaces such sprintf()
calls with sysfs_emit() while simplifying the open code in
list_show().

Link: https://lore.kernel.org/r/20220801165639.26030-4-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
Takashi Iwai 2022-08-01 18:56:35 +02:00
parent 0980bb1ff0
commit ade7956396

View File

@ -405,7 +405,7 @@ static ssize_t mode_show(struct device *dev,
case MODE_ON: str = "on"; break; case MODE_ON: str = "on"; break;
case MODE_OFF: str = "off"; break; case MODE_OFF: str = "off"; break;
} }
return sprintf(buf, "%s\n", str); return sysfs_emit(buf, "%s\n", str);
} }
static ssize_t mode_store(struct device *dev, static ssize_t mode_store(struct device *dev,
@ -443,7 +443,7 @@ static ssize_t brightness_show(struct device *dev,
{ {
struct snd_ctl_led *led = container_of(dev, struct snd_ctl_led, dev); struct snd_ctl_led *led = container_of(dev, struct snd_ctl_led, dev);
return sprintf(buf, "%u\n", ledtrig_audio_get(led->trigger_type)); return sysfs_emit(buf, "%u\n", ledtrig_audio_get(led->trigger_type));
} }
static DEVICE_ATTR_RW(mode); static DEVICE_ATTR_RW(mode);
@ -618,8 +618,7 @@ static ssize_t list_show(struct device *dev,
struct snd_ctl_led_card *led_card = container_of(dev, struct snd_ctl_led_card, dev); struct snd_ctl_led_card *led_card = container_of(dev, struct snd_ctl_led_card, dev);
struct snd_card *card; struct snd_card *card;
struct snd_ctl_led_ctl *lctl; struct snd_ctl_led_ctl *lctl;
char *buf2 = buf; size_t l = 0;
size_t l;
card = snd_card_ref(led_card->number); card = snd_card_ref(led_card->number);
if (!card) if (!card)
@ -627,23 +626,19 @@ static ssize_t list_show(struct device *dev,
down_read(&card->controls_rwsem); down_read(&card->controls_rwsem);
mutex_lock(&snd_ctl_led_mutex); mutex_lock(&snd_ctl_led_mutex);
if (snd_ctl_led_card_valid[led_card->number]) { if (snd_ctl_led_card_valid[led_card->number]) {
list_for_each_entry(lctl, &led_card->led->controls, list) list_for_each_entry(lctl, &led_card->led->controls, list) {
if (lctl->card == card) { if (lctl->card != card)
if (buf2 - buf > PAGE_SIZE - 16) continue;
break; if (l)
if (buf2 != buf) l += sysfs_emit_at(buf, l, " ");
*buf2++ = ' '; l += sysfs_emit_at(buf, l, "%u",
l = scnprintf(buf2, 15, "%u", lctl->kctl->id.numid + lctl->index_offset);
lctl->kctl->id.numid +
lctl->index_offset);
buf2[l] = '\0';
buf2 += l + 1;
} }
} }
mutex_unlock(&snd_ctl_led_mutex); mutex_unlock(&snd_ctl_led_mutex);
up_read(&card->controls_rwsem); up_read(&card->controls_rwsem);
snd_card_unref(card); snd_card_unref(card);
return buf2 - buf; return l;
} }
static DEVICE_ATTR_WO(attach); static DEVICE_ATTR_WO(attach);