[bcache:for-next 9/27] drivers/md/bcache/sysfs.c:271 __cached_dev_store() error: uninitialized symbol 'v'.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



tree:   https://git.kernel.org/pub/scm/linux/kernel/git/colyli/linux-bcache.git for-next
head:   2b04674443471465b4bdc0e52b2355bb5e128078
commit: 9c26e5fd96446919cc77c14a09ba9b6cf2320ab5 [9/27] bcache: set max writeback rate when I/O request is idle

smatch warnings:
drivers/md/bcache/sysfs.c:271 __cached_dev_store() error: uninitialized symbol 'v'.

# https://git.kernel.org/pub/scm/linux/kernel/git/colyli/linux-bcache.git/commit/?id=9c26e5fd96446919cc77c14a09ba9b6cf2320ab5
git remote add bcache https://git.kernel.org/pub/scm/linux/kernel/git/colyli/linux-bcache.git
git remote update bcache
git checkout 9c26e5fd96446919cc77c14a09ba9b6cf2320ab5
vim +/v +271 drivers/md/bcache/sysfs.c

cafe5635 Kent Overstreet     2013-03-23  257  
cafe5635 Kent Overstreet     2013-03-23  258  	sysfs_strtoul(data_csum,	dc->disk.data_csum);
cafe5635 Kent Overstreet     2013-03-23  259  	d_strtoul(verify);
5ceaaad7 Kent Overstreet     2013-09-10  260  	d_strtoul(bypass_torture_test);
cafe5635 Kent Overstreet     2013-03-23  261  	d_strtoul(writeback_metadata);
cafe5635 Kent Overstreet     2013-03-23  262  	d_strtoul(writeback_running);
cafe5635 Kent Overstreet     2013-03-23  263  	d_strtoul(writeback_delay);
16749c23 Kent Overstreet     2013-11-11  264  
cafe5635 Kent Overstreet     2013-03-23  265  	sysfs_strtoul_clamp(writeback_percent, dc->writeback_percent, 0, 40);
cafe5635 Kent Overstreet     2013-03-23  266  
9c26e5fd Coly Li             2018-07-26  267  	if (attr == &sysfs_writeback_rate) {
9c26e5fd Coly Li             2018-07-26  268  		int v;
9c26e5fd Coly Li             2018-07-26  269  
9c26e5fd Coly Li             2018-07-26  270  		sysfs_strtoul_clamp(writeback_rate, v, 1, INT_MAX);
                                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
9c26e5fd Coly Li             2018-07-26 @271  		atomic_long_set(&dc->writeback_rate.rate, v);
                                                                                                  ^
This code is impossible to reach, so Smatch isn't supposed to generate
a warning...  It doesn't warn when I build it on my system...  Sometimes
Smatch takes short cuts if the system is overloaded so that might be the
reason for this warning.

Anyway, sysfs_strtoul_clamp() returns if "attr == &sysfs_writeback_rate".

9c26e5fd Coly Li             2018-07-26  272  	}
16749c23 Kent Overstreet     2013-11-11  273  
7a5e3ecb Coly Li             2018-02-07  274  	sysfs_strtoul_clamp(writeback_rate_update_seconds,
7a5e3ecb Coly Li             2018-02-07  275  			    dc->writeback_rate_update_seconds,
7a5e3ecb Coly Li             2018-02-07  276  			    1, WRITEBACK_RATE_UPDATE_SECS_MAX);
1d316e65 Michael Lyle        2017-10-13  277  	d_strtoul(writeback_rate_i_term_inverse);
16749c23 Kent Overstreet     2013-11-11  278  	d_strtoul_nonzero(writeback_rate_p_term_inverse);
cafe5635 Kent Overstreet     2013-03-23  279  
c7b7bd07 Coly Li             2018-03-18  280  	sysfs_strtoul_clamp(io_error_limit, dc->error_limit, 0, INT_MAX);
c7b7bd07 Coly Li             2018-03-18  281  
c7b7bd07 Coly Li             2018-03-18  282  	if (attr == &sysfs_io_disable) {
c7b7bd07 Coly Li             2018-03-18  283  		int v = strtoul_or_return(buf);
c7b7bd07 Coly Li             2018-03-18  284  
c7b7bd07 Coly Li             2018-03-18  285  		dc->io_disable = v ? 1 : 0;
c7b7bd07 Coly Li             2018-03-18  286  	}
c7b7bd07 Coly Li             2018-03-18  287  
cafe5635 Kent Overstreet     2013-03-23  288  	d_strtoi_h(sequential_cutoff);
cafe5635 Kent Overstreet     2013-03-23  289  	d_strtoi_h(readahead);
cafe5635 Kent Overstreet     2013-03-23  290  
cafe5635 Kent Overstreet     2013-03-23  291  	if (attr == &sysfs_clear_stats)
cafe5635 Kent Overstreet     2013-03-23  292  		bch_cache_accounting_clear(&dc->accounting);
cafe5635 Kent Overstreet     2013-03-23  293  
cafe5635 Kent Overstreet     2013-03-23  294  	if (attr == &sysfs_running &&
cafe5635 Kent Overstreet     2013-03-23  295  	    strtoul_or_return(buf))
cafe5635 Kent Overstreet     2013-03-23  296  		bch_cached_dev_run(dc);
cafe5635 Kent Overstreet     2013-03-23  297  
cafe5635 Kent Overstreet     2013-03-23  298  	if (attr == &sysfs_cache_mode) {
ce4c3e19 Andy Shevchenko     2018-05-28  299  		v = __sysfs_match_string(bch_cache_modes, -1, buf);
cafe5635 Kent Overstreet     2013-03-23  300  		if (v < 0)
cafe5635 Kent Overstreet     2013-03-23  301  			return v;
cafe5635 Kent Overstreet     2013-03-23  302  
cafe5635 Kent Overstreet     2013-03-23  303  		if ((unsigned) v != BDEV_CACHE_MODE(&dc->sb)) {
cafe5635 Kent Overstreet     2013-03-23  304  			SET_BDEV_CACHE_MODE(&dc->sb, v);
cafe5635 Kent Overstreet     2013-03-23  305  			bch_write_bdev_super(dc, NULL);
cafe5635 Kent Overstreet     2013-03-23  306  		}
cafe5635 Kent Overstreet     2013-03-23  307  	}
cafe5635 Kent Overstreet     2013-03-23  308  
7e027ca4 Coly Li             2018-03-18  309  	if (attr == &sysfs_stop_when_cache_set_failed) {
ce4c3e19 Andy Shevchenko     2018-05-28  310  		v = __sysfs_match_string(bch_stop_on_failure_modes, -1, buf);
7e027ca4 Coly Li             2018-03-18  311  		if (v < 0)
7e027ca4 Coly Li             2018-03-18  312  			return v;
7e027ca4 Coly Li             2018-03-18  313  
7e027ca4 Coly Li             2018-03-18  314  		dc->stop_when_cache_set_failed = v;
7e027ca4 Coly Li             2018-03-18  315  	}
7e027ca4 Coly Li             2018-03-18  316  
cafe5635 Kent Overstreet     2013-03-23  317  	if (attr == &sysfs_label) {
aee6f1cf Gabriel de Perthuis 2013-09-23  318  		if (size > SB_LABEL_SIZE)
aee6f1cf Gabriel de Perthuis 2013-09-23  319  			return -EINVAL;
aee6f1cf Gabriel de Perthuis 2013-09-23  320  		memcpy(dc->sb.label, buf, size);
aee6f1cf Gabriel de Perthuis 2013-09-23  321  		if (size < SB_LABEL_SIZE)
aee6f1cf Gabriel de Perthuis 2013-09-23  322  			dc->sb.label[size] = '\0';
aee6f1cf Gabriel de Perthuis 2013-09-23  323  		if (size && dc->sb.label[size - 1] == '\n')
aee6f1cf Gabriel de Perthuis 2013-09-23  324  			dc->sb.label[size - 1] = '\0';
cafe5635 Kent Overstreet     2013-03-23  325  		bch_write_bdev_super(dc, NULL);
cafe5635 Kent Overstreet     2013-03-23  326  		if (dc->disk.c) {
cafe5635 Kent Overstreet     2013-03-23  327  			memcpy(dc->disk.c->uuids[dc->disk.id].label,
cafe5635 Kent Overstreet     2013-03-23  328  			       buf, SB_LABEL_SIZE);
cafe5635 Kent Overstreet     2013-03-23  329  			bch_uuid_write(dc->disk.c);
cafe5635 Kent Overstreet     2013-03-23  330  		}
ab9e1400 Gabriel de Perthuis 2013-06-09  331  		env = kzalloc(sizeof(struct kobj_uevent_env), GFP_KERNEL);
d2a65ce2 Dan Carpenter       2013-07-05  332  		if (!env)
d2a65ce2 Dan Carpenter       2013-07-05  333  			return -ENOMEM;
ab9e1400 Gabriel de Perthuis 2013-06-09  334  		add_uevent_var(env, "DRIVER=bcache");
ab9e1400 Gabriel de Perthuis 2013-06-09  335  		add_uevent_var(env, "CACHED_UUID=%pU", dc->sb.uuid),
ab9e1400 Gabriel de Perthuis 2013-06-09  336  		add_uevent_var(env, "CACHED_LABEL=%s", buf);
ab9e1400 Gabriel de Perthuis 2013-06-09  337  		kobject_uevent_env(
ab9e1400 Gabriel de Perthuis 2013-06-09  338  			&disk_to_dev(dc->disk.disk)->kobj, KOBJ_CHANGE, env->envp);
ab9e1400 Gabriel de Perthuis 2013-06-09  339  		kfree(env);
cafe5635 Kent Overstreet     2013-03-23  340  	}
cafe5635 Kent Overstreet     2013-03-23  341  
cafe5635 Kent Overstreet     2013-03-23  342  	if (attr == &sysfs_attach) {
73ac105b Tang Junhui         2018-02-07  343  		uint8_t		set_uuid[16];
73ac105b Tang Junhui         2018-02-07  344  
73ac105b Tang Junhui         2018-02-07  345  		if (bch_parse_uuid(buf, set_uuid) < 16)
cafe5635 Kent Overstreet     2013-03-23  346  			return -EINVAL;
cafe5635 Kent Overstreet     2013-03-23  347  
7f4fc93d Tang Junhui         2018-02-07  348  		v = -ENOENT;
cafe5635 Kent Overstreet     2013-03-23  349  		list_for_each_entry(c, &bch_cache_sets, list) {
73ac105b Tang Junhui         2018-02-07  350  			v = bch_cached_dev_attach(dc, c, set_uuid);
cafe5635 Kent Overstreet     2013-03-23  351  			if (!v)
cafe5635 Kent Overstreet     2013-03-23  352  				return size;
cafe5635 Kent Overstreet     2013-03-23  353  		}
cafe5635 Kent Overstreet     2013-03-23  354  
cafe5635 Kent Overstreet     2013-03-23  355  		pr_err("Can't attach %s: cache set not found", buf);
7f4fc93d Tang Junhui         2018-02-07  356  		return v;
cafe5635 Kent Overstreet     2013-03-23  357  	}
cafe5635 Kent Overstreet     2013-03-23  358  
cafe5635 Kent Overstreet     2013-03-23  359  	if (attr == &sysfs_detach && dc->disk.c)
cafe5635 Kent Overstreet     2013-03-23  360  		bch_cached_dev_detach(dc);
cafe5635 Kent Overstreet     2013-03-23  361  
cafe5635 Kent Overstreet     2013-03-23  362  	if (attr == &sysfs_stop)
cafe5635 Kent Overstreet     2013-03-23  363  		bcache_device_stop(&dc->disk);
cafe5635 Kent Overstreet     2013-03-23  364  
cafe5635 Kent Overstreet     2013-03-23  365  	return size;
cafe5635 Kent Overstreet     2013-03-23  366  }
cafe5635 Kent Overstreet     2013-03-23  367  

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation



[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]

  Powered by Linux