tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git 
master
head:   086ba2ec163b638abd2a90ef3e8bab0238d02e56
commit: 56a5b7910e965c6905d112ce94fd9a9f5561f326 ASoC: codecs: max98373: add 
SoundWire support
date:   5 weeks ago
compiler: mipsel-linux-gcc (GCC) 9.3.0

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <l...@intel.com>


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++;
      ^
   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++)
           ^

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-...@lists.01.org

Reply via email to