Commit 3e42084a authored by Lee Jones's avatar Lee Jones Committed by Greg Kroah-Hartman

usb: storage: Remove snprintf() from sysfs call-backs and replace with sysfs_emit()

Since snprintf() has the documented, but still rather strange trait of
returning the length of the data that *would have been* written to the
array if space were available, rather than the arguably more useful
length of data *actually* written, it is usually considered wise to use
something else instead in order to avoid confusion.

In the case of sysfs call-backs, new wrappers exist that do just that.

Link: https://lwn.net/Articles/69419/
Link: https://github.com/KSPP/linux/issues/105
Cc: Alan Stern <stern@rowland.harvard.edu>
Cc:  <usb-storage@lists.one-eyed-alien.net>
Signed-off-by: default avatarLee Jones <lee@kernel.org>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Link: https://lore.kernel.org/r/20231213164246.1021885-13-lee@kernel.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e5892ea8
...@@ -98,26 +98,26 @@ static ssize_t truinst_show(struct device *dev, struct device_attribute *attr, ...@@ -98,26 +98,26 @@ static ssize_t truinst_show(struct device *dev, struct device_attribute *attr,
struct usb_device *udev = interface_to_usbdev(intf); struct usb_device *udev = interface_to_usbdev(intf);
int result; int result;
if (swi_tru_install == TRU_FORCE_MS) { if (swi_tru_install == TRU_FORCE_MS) {
result = snprintf(buf, PAGE_SIZE, "Forced Mass Storage\n"); result = sysfs_emit(buf, "Forced Mass Storage\n");
} else { } else {
swocInfo = kmalloc(sizeof(struct swoc_info), GFP_KERNEL); swocInfo = kmalloc(sizeof(struct swoc_info), GFP_KERNEL);
if (!swocInfo) { if (!swocInfo) {
snprintf(buf, PAGE_SIZE, "Error\n"); sysfs_emit(buf, "Error\n");
return -ENOMEM; return -ENOMEM;
} }
result = sierra_get_swoc_info(udev, swocInfo); result = sierra_get_swoc_info(udev, swocInfo);
if (result < 0) { if (result < 0) {
dev_dbg(dev, "SWIMS: failed SWoC query\n"); dev_dbg(dev, "SWIMS: failed SWoC query\n");
kfree(swocInfo); kfree(swocInfo);
snprintf(buf, PAGE_SIZE, "Error\n"); sysfs_emit(buf, "Error\n");
return -EIO; return -EIO;
} }
debug_swoc(dev, swocInfo); debug_swoc(dev, swocInfo);
result = snprintf(buf, PAGE_SIZE, result = sysfs_emit(buf,
"REV=%02d SKU=%04X VER=%04X\n", "REV=%02d SKU=%04X VER=%04X\n",
swocInfo->rev, swocInfo->rev,
swocInfo->LinuxSKU, swocInfo->LinuxSKU,
swocInfo->LinuxVer); swocInfo->LinuxVer);
kfree(swocInfo); kfree(swocInfo);
} }
return result; return result;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment