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
| ||
|
Date: Mon, 28 Dec 2015 20:18:23 +0200 From: Andy Shevchenko <andriy.shevchenko@...ux.intel.com> To: Andrew Morton <akpm@...ux-foundation.org>, Rasmus Villemoes <linux@...musvillemoes.dk>, linux-kernel@...r.kernel.org Cc: Andy Shevchenko <andriy.shevchenko@...ux.intel.com> Subject: [PATCH v1 1/1] lib/vsprintf: refactor duplicate code to xnumber() xnumber() is a special helper to print a fixed size type in a hex format with '0x' prefix with padding and reduced size. In the module we have already several copies of such code. Consolidate them under xnumber() helper. There are couple of differences though. It seems nobody cared about the output in case of CONFIG_KALLSYMS=n when printing symbol address because the asked width is not enough to care either prefix or last byte. Fixed here. The %pNF specifier used to be allowed with a specific field width, though there is neither any user of it nor mention in the documentation. Signed-off-by: Andy Shevchenko <andriy.shevchenko@...ux.intel.com> --- lib/vsprintf.c | 43 +++++++++++++++---------------------------- 1 file changed, 15 insertions(+), 28 deletions(-) diff --git a/lib/vsprintf.c b/lib/vsprintf.c index dcf5646..e971549 100644 --- a/lib/vsprintf.c +++ b/lib/vsprintf.c @@ -514,6 +514,16 @@ char *number(char *buf, char *end, unsigned long long num, return buf; } +static noinline_for_stack +char *xnumber(char *buf, char *end, unsigned long long value, unsigned int type, + struct printf_spec spec) +{ + spec.field_width = 2 + 2 * type; + spec.flags |= SPECIAL | SMALL | ZEROPAD; + spec.base = 16; + return number(buf, end, value, spec); +} + static void move_right(char *buf, char *end, unsigned len, unsigned spaces) { size_t size; @@ -649,11 +659,7 @@ char *symbol_string(char *buf, char *end, void *ptr, return string(buf, end, sym, spec); #else - spec.field_width = 2 * sizeof(void *); - spec.flags |= SPECIAL | SMALL | ZEROPAD; - spec.base = 16; - - return number(buf, end, value, spec); + return xnumber(buf, end, value, sizeof(void *), spec); #endif } @@ -1318,36 +1324,20 @@ static char *netdev_feature_string(char *buf, char *end, const u8 *addr, struct printf_spec spec) { - spec.flags |= SPECIAL | SMALL | ZEROPAD; - if (spec.field_width == -1) - spec.field_width = 2 + 2 * sizeof(netdev_features_t); - spec.base = 16; - - return number(buf, end, *(const netdev_features_t *)addr, spec); + return xnumber(buf, end, *(const netdev_features_t *)addr, sizeof(netdev_features_t), spec); } static noinline_for_stack char *address_val(char *buf, char *end, const void *addr, struct printf_spec spec, const char *fmt) { - unsigned long long num; - - spec.flags |= SPECIAL | SMALL | ZEROPAD; - spec.base = 16; - switch (fmt[1]) { case 'd': - num = *(const dma_addr_t *)addr; - spec.field_width = sizeof(dma_addr_t) * 2 + 2; - break; + return xnumber(buf, end, *(const dma_addr_t *)addr, sizeof(dma_addr_t), spec); case 'p': default: - num = *(const phys_addr_t *)addr; - spec.field_width = sizeof(phys_addr_t) * 2 + 2; - break; + return xnumber(buf, end, *(const phys_addr_t *)addr, sizeof(phys_addr_t), spec); } - - return number(buf, end, num, spec); } static noinline_for_stack @@ -1366,10 +1356,7 @@ char *clock(char *buf, char *end, struct clk *clk, struct printf_spec spec, #ifdef CONFIG_COMMON_CLK return string(buf, end, __clk_get_name(clk), spec); #else - spec.base = 16; - spec.field_width = sizeof(unsigned long) * 2 + 2; - spec.flags |= SPECIAL | SMALL | ZEROPAD; - return number(buf, end, (unsigned long)clk, spec); + return xnumber(buf, end, (unsigned long)clk, sizeof(unsigned long), spec); #endif } } -- 2.6.4 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists