bcache: replace snprintf in show functions with sysfs_emit

coccicheck complains about the use of snprintf() in sysfs show functions.

Fix the following coccicheck warning:
drivers/md/bcache/sysfs.h:54:12-20: WARNING: use scnprintf or sprintf.

Implement sysfs_print() by sysfs_emit() and remove snprint() since no one
uses it any more.

Suggested-by: Coly Li <colyli@suse.de>
Signed-off-by: Qing Wang <wangqing@vivo.com>
Signed-off-by: Coly Li <colyli@suse.de>
Link: https://lore.kernel.org/r/20211029060930.119923-3-colyli@suse.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
Qing Wang 2021-10-29 14:09:30 +08:00 committed by Jens Axboe
parent cf2197ca4b
commit 1b86db5f4e
2 changed files with 16 additions and 19 deletions

View File

@ -51,13 +51,27 @@ STORE(fn) \
#define sysfs_printf(file, fmt, ...) \ #define sysfs_printf(file, fmt, ...) \
do { \ do { \
if (attr == &sysfs_ ## file) \ if (attr == &sysfs_ ## file) \
return snprintf(buf, PAGE_SIZE, fmt "\n", __VA_ARGS__); \ return sysfs_emit(buf, fmt "\n", __VA_ARGS__); \
} while (0) } while (0)
#define sysfs_print(file, var) \ #define sysfs_print(file, var) \
do { \ do { \
if (attr == &sysfs_ ## file) \ if (attr == &sysfs_ ## file) \
return snprint(buf, PAGE_SIZE, var); \ return sysfs_emit(buf, \
__builtin_types_compatible_p(typeof(var), int) \
? "%i\n" : \
__builtin_types_compatible_p(typeof(var), unsigned int) \
? "%u\n" : \
__builtin_types_compatible_p(typeof(var), long) \
? "%li\n" : \
__builtin_types_compatible_p(typeof(var), unsigned long)\
? "%lu\n" : \
__builtin_types_compatible_p(typeof(var), int64_t) \
? "%lli\n" : \
__builtin_types_compatible_p(typeof(var), uint64_t) \
? "%llu\n" : \
__builtin_types_compatible_p(typeof(var), const char *) \
? "%s\n" : "%i\n", var); \
} while (0) } while (0)
#define sysfs_hprint(file, val) \ #define sysfs_hprint(file, val) \

View File

@ -340,23 +340,6 @@ static inline int bch_strtoul_h(const char *cp, long *res)
_r; \ _r; \
}) })
#define snprint(buf, size, var) \
snprintf(buf, size, \
__builtin_types_compatible_p(typeof(var), int) \
? "%i\n" : \
__builtin_types_compatible_p(typeof(var), unsigned int) \
? "%u\n" : \
__builtin_types_compatible_p(typeof(var), long) \
? "%li\n" : \
__builtin_types_compatible_p(typeof(var), unsigned long)\
? "%lu\n" : \
__builtin_types_compatible_p(typeof(var), int64_t) \
? "%lli\n" : \
__builtin_types_compatible_p(typeof(var), uint64_t) \
? "%llu\n" : \
__builtin_types_compatible_p(typeof(var), const char *) \
? "%s\n" : "%i\n", var)
ssize_t bch_hprint(char *buf, int64_t v); ssize_t bch_hprint(char *buf, int64_t v);
bool bch_is_zero(const char *p, size_t n); bool bch_is_zero(const char *p, size_t n);