block: avoid using uninitialized value in from queue_var_store

commit c678ef5286 upstream.

As found by gcc-4.8, the QUEUE_SYSFS_BIT_FNS macro creates functions
that use a value generated by queue_var_store independent of whether
that value was set or not.

block/blk-sysfs.c: In function 'queue_store_nonrot':
block/blk-sysfs.c:244:385: warning: 'val' may be used uninitialized in this function [-Wmaybe-uninitialized]

Unlike most other such warnings, this one is not a false positive,
writing any non-number string into the sysfs files indeed has
an undefined result, rather than returning an error.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Arnd Bergmann 2013-04-03 21:53:57 +02:00 committed by Greg Kroah-Hartman
parent 972595ab7b
commit 2570f53200

View file

@ -200,6 +200,8 @@ queue_store_##name(struct request_queue *q, const char *page, size_t count) \
unsigned long val; \ unsigned long val; \
ssize_t ret; \ ssize_t ret; \
ret = queue_var_store(&val, page, count); \ ret = queue_var_store(&val, page, count); \
if (ret < 0) \
return ret; \
if (neg) \ if (neg) \
val = !val; \ val = !val; \
\ \