drivers/net/ethernet/sfc/ethtool_common.c:170:32: warning: '%-24s' directive output may be truncated writing between 24 and 31 bytes into a region of size between 0 and 25
From: kernel test robot
Date: Wed Dec 04 2024 - 09:26:27 EST
Hi Alex,
FYI, the error/warning still remains.
tree: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head: feffde684ac29a3b7aec82d2df850fbdbdee55e4
commit: 3653954da498fc80c5da3642ae3f8d8168d7f820 sfc: move some ethtool code
date: 4 years, 11 months ago
config: arm-allmodconfig (https://download.01.org/0day-ci/archive/20241204/202412042129.kPNOwHP4-lkp@xxxxxxxxx/config)
compiler: arm-linux-gnueabi-gcc (GCC) 13.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20241204/202412042129.kPNOwHP4-lkp@xxxxxxxxx/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@xxxxxxxxx>
| Closes: https://lore.kernel.org/oe-kbuild-all/202412042129.kPNOwHP4-lkp@xxxxxxxxx/
All warnings (new ones prefixed by >>):
drivers/net/ethernet/sfc/ethtool_common.c:150:6: warning: no previous prototype for 'efx_fill_test' [-Wmissing-prototypes]
150 | void efx_fill_test(unsigned int test_index, u8 *strings, u64 *data,
| ^~~~~~~~~~~~~
drivers/net/ethernet/sfc/ethtool_common.c:192:5: warning: no previous prototype for 'efx_fill_loopback_test' [-Wmissing-prototypes]
192 | int efx_fill_loopback_test(struct efx_nic *efx,
| ^~~~~~~~~~~~~~~~~~~~~~
drivers/net/ethernet/sfc/ethtool_common.c:296:8: warning: no previous prototype for 'efx_describe_per_queue_stats' [-Wmissing-prototypes]
296 | size_t efx_describe_per_queue_stats(struct efx_nic *efx, u8 *strings)
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
drivers/net/ethernet/sfc/ethtool_common.c: In function 'efx_fill_test':
>> drivers/net/ethernet/sfc/ethtool_common.c:170:32: warning: '%-24s' directive output may be truncated writing between 24 and 31 bytes into a region of size between 0 and 25 [-Wformat-truncation=]
170 | "%-6s %-24s", unit_str, test_str);
| ^~~~~ ~~~~~~~~
drivers/net/ethernet/sfc/ethtool_common.c:168:17: note: 'snprintf' output between 32 and 64 bytes into a destination of size 32
168 | snprintf(strings + test_index * ETH_GSTRING_LEN,
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
169 | ETH_GSTRING_LEN,
| ~~~~~~~~~~~~~~~~
170 | "%-6s %-24s", unit_str, test_str);
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
vim +170 drivers/net/ethernet/sfc/ethtool_common.c
136
137 /**
138 * efx_fill_test - fill in an individual self-test entry
139 * @test_index: Index of the test
140 * @strings: Ethtool strings, or %NULL
141 * @data: Ethtool test results, or %NULL
142 * @test: Pointer to test result (used only if data != %NULL)
143 * @unit_format: Unit name format (e.g. "chan\%d")
144 * @unit_id: Unit id (e.g. 0 for "chan0")
145 * @test_format: Test name format (e.g. "loopback.\%s.tx.sent")
146 * @test_id: Test id (e.g. "PHYXS" for "loopback.PHYXS.tx_sent")
147 *
148 * Fill in an individual self-test entry.
149 */
150 void efx_fill_test(unsigned int test_index, u8 *strings, u64 *data,
151 int *test, const char *unit_format, int unit_id,
152 const char *test_format, const char *test_id)
153 {
154 char unit_str[ETH_GSTRING_LEN], test_str[ETH_GSTRING_LEN];
155
156 /* Fill data value, if applicable */
157 if (data)
158 data[test_index] = *test;
159
160 /* Fill string, if applicable */
161 if (strings) {
162 if (strchr(unit_format, '%'))
163 snprintf(unit_str, sizeof(unit_str),
164 unit_format, unit_id);
165 else
166 strcpy(unit_str, unit_format);
167 snprintf(test_str, sizeof(test_str), test_format, test_id);
168 snprintf(strings + test_index * ETH_GSTRING_LEN,
169 ETH_GSTRING_LEN,
> 170 "%-6s %-24s", unit_str, test_str);
171 }
172 }
173
174 #define EFX_CHANNEL_NAME(_channel) "chan%d", _channel->channel
175 #define EFX_TX_QUEUE_NAME(_tx_queue) "txq%d", _tx_queue->queue
176 #define EFX_RX_QUEUE_NAME(_rx_queue) "rxq%d", _rx_queue->queue
177 #define EFX_LOOPBACK_NAME(_mode, _counter) \
178 "loopback.%s." _counter, STRING_TABLE_LOOKUP(_mode, efx_loopback_mode)
179
180 /**
181 * efx_fill_loopback_test - fill in a block of loopback self-test entries
182 * @efx: Efx NIC
183 * @lb_tests: Efx loopback self-test results structure
184 * @mode: Loopback test mode
185 * @test_index: Starting index of the test
186 * @strings: Ethtool strings, or %NULL
187 * @data: Ethtool test results, or %NULL
188 *
189 * Fill in a block of loopback self-test entries. Return new test
190 * index.
191 */
> 192 int efx_fill_loopback_test(struct efx_nic *efx,
193 struct efx_loopback_self_tests *lb_tests,
194 enum efx_loopback_mode mode,
195 unsigned int test_index, u8 *strings, u64 *data)
196 {
197 struct efx_channel *channel =
198 efx_get_channel(efx, efx->tx_channel_offset);
199 struct efx_tx_queue *tx_queue;
200
201 efx_for_each_channel_tx_queue(tx_queue, channel) {
202 efx_fill_test(test_index++, strings, data,
203 &lb_tests->tx_sent[tx_queue->queue],
204 EFX_TX_QUEUE_NAME(tx_queue),
205 EFX_LOOPBACK_NAME(mode, "tx_sent"));
206 efx_fill_test(test_index++, strings, data,
207 &lb_tests->tx_done[tx_queue->queue],
208 EFX_TX_QUEUE_NAME(tx_queue),
209 EFX_LOOPBACK_NAME(mode, "tx_done"));
210 }
211 efx_fill_test(test_index++, strings, data,
212 &lb_tests->rx_good,
213 "rx", 0,
214 EFX_LOOPBACK_NAME(mode, "rx_good"));
215 efx_fill_test(test_index++, strings, data,
216 &lb_tests->rx_bad,
217 "rx", 0,
218 EFX_LOOPBACK_NAME(mode, "rx_bad"));
219
220 return test_index;
221 }
222
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki