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>] [thread-next>] [day] [month] [year] [list]
Date:   Tue, 11 Aug 2020 11:38:41 +0800
From:   kernel test robot <lkp@...el.com>
To:     Ryan Lee <ryans.lee@...imintegrated.com>
Cc:     kbuild-all@...ts.01.org, linux-kernel@...r.kernel.org,
        Mark Brown <broonie@...nel.org>,
        Naveen Manohar <naveen.m@...el.com>,
        Pierre-Louis Bossart <pierre-louis.bossart@...ux.intel.com>,
        Rander Wang <rander.wang@...ux.intel.com>,
        Kai Vehmanen <kai.vehmanen@...ux.intel.com>
Subject: sound/soc/codecs/max98373-sdw.c:325:4: warning: Variable 'i' is
 reassigned a value before the old one has been used.

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

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ