[PATCH v1 1/1] lib/vsprintf: refactor duplicate code to xnumber()
From: Andy Shevchenko
Date: Mon Dec 28 2015 - 13:19:16 EST
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@xxxxxxxxxxxxxxx>
---
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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/