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: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <202412210625.Wl5iFYw5-lkp@intel.com>
Date: Sat, 21 Dec 2024 06:30:33 +0800
From: kernel test robot <lkp@...el.com>
To: Simon Horman <horms@...nel.org>
Cc: oe-kbuild-all@...ts.linux.dev, linux-kernel@...r.kernel.org,
	Jakub Kicinski <kuba@...nel.org>
Subject: drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c:278:59: warning:
 '%u' directive output may be truncated writing between 1 and 10 bytes into a
 region of size 6

Hi Simon,

FYI, the error/warning still remains.

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   e9b8ffafd20ad21357a789cc58ffaa162b3ad074
commit: 5874e0c9f25661c2faefe4809907166defae3d7f net: atlantic: Avoid warning about potential string truncation
date:   4 months ago
config: x86_64-randconfig-074-20241221 (https://download.01.org/0day-ci/archive/20241221/202412210625.Wl5iFYw5-lkp@intel.com/config)
compiler: gcc-11 (Debian 11.3.0-12) 11.3.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20241221/202412210625.Wl5iFYw5-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/202412210625.Wl5iFYw5-lkp@intel.com/

All warnings (new ones prefixed by >>):

   drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c: In function 'aq_ethtool_get_strings':
>> drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c:278:59: warning: '%u' directive output may be truncated writing between 1 and 10 bytes into a region of size 6 [-Wformat-truncation=]
     278 |                                 snprintf(tc_string, 8, "TC%u ", tc);
         |                                                           ^~
   drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c:278:56: note: directive argument in the range [0, 4294967294]
     278 |                                 snprintf(tc_string, 8, "TC%u ", tc);
         |                                                        ^~~~~~~
   drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c:278:33: note: 'snprintf' output between 5 and 14 bytes into a destination of size 8
     278 |                                 snprintf(tc_string, 8, "TC%u ", tc);
         |                                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


vim +278 drivers/net/ethernet/aquantia/atlantic/aq_ethtool.c

   261	
   262		cfg = aq_nic_get_cfg(nic);
   263	
   264		switch (stringset) {
   265		case ETH_SS_STATS: {
   266			const int rx_stat_cnt = ARRAY_SIZE(aq_ethtool_queue_rx_stat_names);
   267			const int tx_stat_cnt = ARRAY_SIZE(aq_ethtool_queue_tx_stat_names);
   268			char tc_string[8];
   269			unsigned int tc;
   270	
   271			memset(tc_string, 0, sizeof(tc_string));
   272			memcpy(p, aq_ethtool_stat_names,
   273			       sizeof(aq_ethtool_stat_names));
   274			p = p + sizeof(aq_ethtool_stat_names);
   275	
   276			for (tc = 0; tc < cfg->tcs; tc++) {
   277				if (cfg->is_qos)
 > 278					snprintf(tc_string, 8, "TC%u ", tc);
   279	
   280				for (i = 0; i < cfg->vecs; i++) {
   281					for (si = 0; si < rx_stat_cnt; si++) {
   282						ethtool_sprintf(&p,
   283						     aq_ethtool_queue_rx_stat_names[si],
   284						     tc_string,
   285						     AQ_NIC_CFG_TCVEC2RING(cfg, tc, i));
   286					}
   287					for (si = 0; si < tx_stat_cnt; si++) {
   288						ethtool_sprintf(&p,
   289						     aq_ethtool_queue_tx_stat_names[si],
   290						     tc_string,
   291						     AQ_NIC_CFG_TCVEC2RING(cfg, tc, i));
   292					}
   293				}
   294			}
   295	#if IS_REACHABLE(CONFIG_PTP_1588_CLOCK)
   296			if (nic->aq_ptp) {
   297				const int rx_ring_cnt = aq_ptp_get_ring_cnt(nic, ATL_RING_RX);
   298				const int tx_ring_cnt = aq_ptp_get_ring_cnt(nic, ATL_RING_TX);
   299				unsigned int ptp_ring_idx =
   300					aq_ptp_ring_idx(nic->aq_nic_cfg.tc_mode);
   301	
   302				snprintf(tc_string, 8, "PTP ");
   303	
   304				for (i = 0; i < max(rx_ring_cnt, tx_ring_cnt); i++) {
   305					for (si = 0; si < rx_stat_cnt; si++) {
   306						ethtool_sprintf(&p,
   307							 aq_ethtool_queue_rx_stat_names[si],
   308							 tc_string,
   309							 i ? PTP_HWST_RING_IDX : ptp_ring_idx);
   310					}
   311					if (i >= tx_ring_cnt)
   312						continue;
   313					for (si = 0; si < tx_stat_cnt; si++) {
   314						ethtool_sprintf(&p,
   315							 aq_ethtool_queue_tx_stat_names[si],
   316							 tc_string,
   317							 i ? PTP_HWST_RING_IDX : ptp_ring_idx);
   318					}
   319				}
   320			}
   321	#endif
   322	#if IS_ENABLED(CONFIG_MACSEC)
   323			if (!nic->macsec_cfg)
   324				break;
   325	
   326			memcpy(p, aq_macsec_stat_names, sizeof(aq_macsec_stat_names));
   327			p = p + sizeof(aq_macsec_stat_names);
   328			for (i = 0; i < AQ_MACSEC_MAX_SC; i++) {
   329				struct aq_macsec_txsc *aq_txsc;
   330	
   331				if (!(test_bit(i, &nic->macsec_cfg->txsc_idx_busy)))
   332					continue;
   333	
   334				for (si = 0;
   335					si < ARRAY_SIZE(aq_macsec_txsc_stat_names);
   336					si++) {
   337					ethtool_sprintf(&p,
   338						 aq_macsec_txsc_stat_names[si], i);
   339				}
   340				aq_txsc = &nic->macsec_cfg->aq_txsc[i];
   341				for (sa = 0; sa < MACSEC_NUM_AN; sa++) {
   342					if (!(test_bit(sa, &aq_txsc->tx_sa_idx_busy)))
   343						continue;
   344					for (si = 0;
   345					     si < ARRAY_SIZE(aq_macsec_txsa_stat_names);
   346					     si++) {
   347						ethtool_sprintf(&p,
   348							 aq_macsec_txsa_stat_names[si],
   349							 i, sa);
   350					}
   351				}
   352			}
   353			for (i = 0; i < AQ_MACSEC_MAX_SC; i++) {
   354				struct aq_macsec_rxsc *aq_rxsc;
   355	
   356				if (!(test_bit(i, &nic->macsec_cfg->rxsc_idx_busy)))
   357					continue;
   358	
   359				aq_rxsc = &nic->macsec_cfg->aq_rxsc[i];
   360				for (sa = 0; sa < MACSEC_NUM_AN; sa++) {
   361					if (!(test_bit(sa, &aq_rxsc->rx_sa_idx_busy)))
   362						continue;
   363					for (si = 0;
   364					     si < ARRAY_SIZE(aq_macsec_rxsa_stat_names);
   365					     si++) {
   366						ethtool_sprintf(&p,
   367							 aq_macsec_rxsa_stat_names[si],
   368							 i, sa);
   369					}
   370				}
   371			}
   372	#endif
   373			break;
   374		}
   375		case ETH_SS_PRIV_FLAGS:
   376			memcpy(p, aq_ethtool_priv_flag_names,
   377			       sizeof(aq_ethtool_priv_flag_names));
   378			break;
   379		}
   380	}
   381	

-- 
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