Re: sound/soc/codecs/max98373-sdw.c:325:4: warning: Variable 'i' is reassigned a value before the old one has been used.

From: Pierre-Louis Bossart
Date: Tue Aug 11 2020 - 12:27:32 EST



cppcheck warnings: (new ones prefixed by >>)

sound/soc/codecs/max98373-sdw.c:325:4: warning: Variable 'i' is reassigned a value before the old one has been used. [redundantAssignment]
i = 0;
^
sound/soc/codecs/max98373-sdw.c:313:4: note: Variable 'i' is reassigned a value before the old one has been used.
i++;
^

the variable is incremented at the end of the loop, and reset at the start of a new loop, not sure how to avoid this warning.

sound/soc/codecs/max98373-sdw.c:325:4: note: Variable 'i' is reassigned a value before the old one has been used.
i = 0;
^
sound/soc/codecs/max98373-sdw.c:344:9: warning: Variable 'i' is reassigned a value before the old one has been used. [redundantAssignment]
for (i = 0; i < num_of_ports; i++)
^
sound/soc/codecs/max98373-sdw.c:333:4: note: Variable 'i' is reassigned a value before the old one has been used.
i++;
^
sound/soc/codecs/max98373-sdw.c:344:9: note: Variable 'i' is reassigned a value before the old one has been used.
for (i = 0; i < num_of_ports; i++)
^

Same problem, the variable is reset at the start of a new loop, but the problem is solved - that code was removed in the latest code (to be submitted after the merge window).

vim +/i +325 sound/soc/codecs/max98373-sdw.c

281
282 static int max98373_read_prop(struct sdw_slave *slave)
283 {
284 struct sdw_slave_prop *prop = &slave->prop;
285 int nval, i, num_of_ports;
286 u32 bit;
287 unsigned long addr;
288 struct sdw_dpn_prop *dpn;
289
290 /* BITMAP: 00001000 Dataport 3 is active */
291 prop->source_ports = BIT(3);
292 /* BITMAP: 00000010 Dataport 1 is active */
293 prop->sink_ports = BIT(1);
294 prop->paging_support = true;
295 prop->clk_stop_timeout = 20;
296
297 nval = hweight32(prop->source_ports);
298 num_of_ports = nval;
299 prop->src_dpn_prop = devm_kcalloc(&slave->dev, nval,
300 sizeof(*prop->src_dpn_prop),
301 GFP_KERNEL);
302 if (!prop->src_dpn_prop)
303 return -ENOMEM;
304
305 i = 0;
306 dpn = prop->src_dpn_prop;
307 addr = prop->source_ports;
308 for_each_set_bit(bit, &addr, 32) {
309 dpn[i].num = bit;
310 dpn[i].type = SDW_DPN_FULL;
311 dpn[i].simple_ch_prep_sm = true;
312 dpn[i].ch_prep_timeout = 10;
313 i++;
314 }
315
316 /* do this again for sink now */
317 nval = hweight32(prop->sink_ports);
318 num_of_ports += nval;
319 prop->sink_dpn_prop = devm_kcalloc(&slave->dev, nval,
320 sizeof(*prop->sink_dpn_prop),
321 GFP_KERNEL);
322 if (!prop->sink_dpn_prop)
323 return -ENOMEM;
324
> 325 i = 0;
326 dpn = prop->sink_dpn_prop;
327 addr = prop->sink_ports;
328 for_each_set_bit(bit, &addr, 32) {
329 dpn[i].num = bit;
330 dpn[i].type = SDW_DPN_FULL;
331 dpn[i].simple_ch_prep_sm = true;
332 dpn[i].ch_prep_timeout = 10;
333 i++;
334 }
335
336 /* Allocate port_ready based on num_of_ports */
337 slave->port_ready = devm_kcalloc(&slave->dev, num_of_ports,
338 sizeof(*slave->port_ready),
339 GFP_KERNEL);
340 if (!slave->port_ready)
341 return -ENOMEM;
342
343 /* Initialize completion */
344 for (i = 0; i < num_of_ports; i++)
345 init_completion(&slave->port_ready[i]);
346
347 /* set the timeout values */
348 prop->clk_stop_timeout = 20;
349
350 return 0;
351 }
352

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@xxxxxxxxxxxx