Re: [PATCH RESEND] sparc: vio: use sysfs_emit in sysfs show functions
From: Thorsten Blum
Date: Thu Jun 04 2026 - 11:38:26 EST
Gentle ping?
On Mon, May 04, 2026 at 08:13:20PM +0200, Thorsten Blum wrote:
> Replace sprintf() and scnprintf() with sysfs_emit() in sysfs show
> functions. sysfs_emit() is preferred to format sysfs output as it
> provides better bounds checking.
>
> Signed-off-by: Thorsten Blum <thorsten.blum@xxxxxxxxx>
> ---
> arch/sparc/kernel/vio.c | 9 +++++----
> 1 file changed, 5 insertions(+), 4 deletions(-)
>
> diff --git a/arch/sparc/kernel/vio.c b/arch/sparc/kernel/vio.c
> index 8b4f55047716..b7b06752a038 100644
> --- a/arch/sparc/kernel/vio.c
> +++ b/arch/sparc/kernel/vio.c
> @@ -13,6 +13,7 @@
> #include <linux/kernel.h>
> #include <linux/slab.h>
> #include <linux/string.h>
> +#include <linux/sysfs.h>
> #include <linux/irq.h>
> #include <linux/export.h>
> #include <linux/init.h>
> @@ -121,7 +122,7 @@ static ssize_t devspec_show(struct device *dev,
> else if (!strcmp(vdev->type, "vdc-port"))
> str = "vdisk";
>
> - return sprintf(buf, "%s\n", str);
> + return sysfs_emit(buf, "%s\n", str);
> }
> static DEVICE_ATTR_RO(devspec);
>
> @@ -129,7 +130,7 @@ static ssize_t type_show(struct device *dev,
> struct device_attribute *attr, char *buf)
> {
> struct vio_dev *vdev = to_vio_dev(dev);
> - return sprintf(buf, "%s\n", vdev->type);
> + return sysfs_emit(buf, "%s\n", vdev->type);
> }
> static DEVICE_ATTR_RO(type);
>
> @@ -138,7 +139,7 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
> {
> const struct vio_dev *vdev = to_vio_dev(dev);
>
> - return sprintf(buf, "vio:T%sS%s\n", vdev->type, vdev->compat);
> + return sysfs_emit(buf, "vio:T%sS%s\n", vdev->type, vdev->compat);
> }
> static DEVICE_ATTR_RO(modalias);
>
> @@ -192,7 +193,7 @@ show_pciobppath_attr(struct device *dev, struct device_attribute *attr,
> vdev = to_vio_dev(dev);
> dp = vdev->dp;
>
> - return scnprintf(buf, PAGE_SIZE, "%pOF\n", dp);
> + return sysfs_emit(buf, "%pOF\n", dp);
> }
>
> static DEVICE_ATTR(obppath, S_IRUSR | S_IRGRP | S_IROTH,