lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <202501160236.YSb9NcEp-lkp@intel.com>
Date: Thu, 16 Jan 2025 02:49:04 +0800
From: kernel test robot <lkp@...el.com>
To: Vincent Mailhol <mailhol.vincent@...adoo.fr>
Cc: oe-kbuild-all@...ts.linux.dev, linux-kernel@...r.kernel.org,
	Marc Kleine-Budde <mkl@...gutronix.de>,
	Andrew Lunn <andrew@...n.ch>
Subject: drivers/net/can/usb/etas_es58x/es58x_devlink.c:201:55: warning:
 '%02u' directive output may be truncated writing between 2 and 3 bytes into
 a region of size between 1 and 3

Hi Vincent,

FYI, the error/warning still remains.

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   619f0b6fad524f08d493a98d55bac9ab8895e3a6
commit: 9f06631c3f1f0f298536443df85a6837ba4c5f5c can: etas_es58x: export product information through devlink_ops::info_get()
date:   2 years, 1 month ago
config: powerpc-buildonly-randconfig-r001-20230115 (https://download.01.org/0day-ci/archive/20250116/202501160236.YSb9NcEp-lkp@intel.com/config)
compiler: powerpc-linux-gcc (GCC) 12.4.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20250116/202501160236.YSb9NcEp-lkp@intel.com/reproduce)

If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <lkp@...el.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202501160236.YSb9NcEp-lkp@intel.com/

All warnings (new ones prefixed by >>):

   drivers/net/can/usb/etas_es58x/es58x_devlink.c: In function 'es58x_devlink_info_get':
>> drivers/net/can/usb/etas_es58x/es58x_devlink.c:201:55: warning: '%02u' directive output may be truncated writing between 2 and 3 bytes into a region of size between 1 and 3 [-Wformat-truncation=]
     201 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                                                       ^~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:201:44: note: directive argument in the range [0, 255]
     201 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                                            ^~~~~~~~~~~~~~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:201:17: note: 'snprintf' output between 9 and 12 bytes into a destination of size 9
     201 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     202 |                          fw_ver->major, fw_ver->minor, fw_ver->revision);
         |                          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:211:55: warning: '%02u' directive output may be truncated writing between 2 and 3 bytes into a region of size between 1 and 3 [-Wformat-truncation=]
     211 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                                                       ^~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:211:44: note: directive argument in the range [0, 255]
     211 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                                            ^~~~~~~~~~~~~~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:211:17: note: 'snprintf' output between 9 and 12 bytes into a destination of size 9
     211 |                 snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
         |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     212 |                          bl_ver->major, bl_ver->minor, bl_ver->revision);
         |                          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:221:52: warning: '%03u' directive output may be truncated writing between 3 and 5 bytes into a region of size between 2 and 4 [-Wformat-truncation=]
     221 |                 snprintf(buf, sizeof(buf), "%c%03u/%03u",
         |                                                    ^~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:221:44: note: directive argument in the range [0, 65535]
     221 |                 snprintf(buf, sizeof(buf), "%c%03u/%03u",
         |                                            ^~~~~~~~~~~~~
   drivers/net/can/usb/etas_es58x/es58x_devlink.c:221:17: note: 'snprintf' output between 9 and 13 bytes into a destination of size 9
     221 |                 snprintf(buf, sizeof(buf), "%c%03u/%03u",
         |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
     222 |                          hw_rev->letter, hw_rev->major, hw_rev->minor);
         |                          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


vim +201 drivers/net/can/usb/etas_es58x/es58x_devlink.c

   177	
   178	/**
   179	 * es58x_devlink_info_get() - Report the product information.
   180	 * @devlink: Devlink.
   181	 * @req: skb wrapper where to put requested information.
   182	 * @extack: Unused.
   183	 *
   184	 * Report the firmware version, the bootloader version, the hardware
   185	 * revision and the serial number through netlink.
   186	 *
   187	 * Return: zero on success, errno when any error occurs.
   188	 */
   189	static int es58x_devlink_info_get(struct devlink *devlink,
   190					  struct devlink_info_req *req,
   191					  struct netlink_ext_ack *extack)
   192	{
   193		struct es58x_device *es58x_dev = devlink_priv(devlink);
   194		struct es58x_sw_version *fw_ver = &es58x_dev->firmware_version;
   195		struct es58x_sw_version *bl_ver = &es58x_dev->bootloader_version;
   196		struct es58x_hw_revision *hw_rev = &es58x_dev->hardware_revision;
   197		char buf[max(sizeof("xx.xx.xx"), sizeof("axxx/xxx"))];
   198		int ret = 0;
   199	
   200		if (es58x_sw_version_is_set(fw_ver)) {
 > 201			snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
   202				 fw_ver->major, fw_ver->minor, fw_ver->revision);
   203			ret = devlink_info_version_running_put(req,
   204							       DEVLINK_INFO_VERSION_GENERIC_FW,
   205							       buf);
   206			if (ret)
   207				return ret;
   208		}
   209	
   210		if (es58x_sw_version_is_set(bl_ver)) {
   211			snprintf(buf, sizeof(buf), "%02u.%02u.%02u",
   212				 bl_ver->major, bl_ver->minor, bl_ver->revision);
   213			ret = devlink_info_version_running_put(req,
   214							       DEVLINK_INFO_VERSION_GENERIC_FW_BOOTLOADER,
   215							       buf);
   216			if (ret)
   217				return ret;
   218		}
   219	
   220		if (es58x_hw_revision_is_set(hw_rev)) {
   221			snprintf(buf, sizeof(buf), "%c%03u/%03u",
   222				 hw_rev->letter, hw_rev->major, hw_rev->minor);
   223			ret = devlink_info_version_fixed_put(req,
   224							     DEVLINK_INFO_VERSION_GENERIC_BOARD_REV,
   225							     buf);
   226			if (ret)
   227				return ret;
   228		}
   229	
   230		return devlink_info_serial_number_put(req, es58x_dev->udev->serial);
   231	}
   232	

-- 
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ