[PATCH] printk: Print error pointers as negative integers for %p

From: David Howells
Date: Tue Feb 06 2018 - 04:22:18 EST


The new hashing feature of unadorned printk("%p") makes it hard to spot if
the pointer actually carries an error value. Make %p print any pointer
that matches IS_ERR() as a negative integer.

Should I set SMALL and the field_width as well, I wonder?

Signed-off-by: David Howells <dhowells@xxxxxxxxxx>
---

lib/vsprintf.c | 6 ++++++
1 file changed, 6 insertions(+)

diff --git a/lib/vsprintf.c b/lib/vsprintf.c
index 77ee6ced11b1..d87adca33b12 100644
--- a/lib/vsprintf.c
+++ b/lib/vsprintf.c
@@ -1705,6 +1705,12 @@ static char *ptr_to_id(char *buf, char *end, void *ptr, struct printf_spec spec)
return string(buf, end, "(ptrval)", spec);
}

+ if (IS_ERR(ptr)) {
+ spec.type = FORMAT_TYPE_INT;
+ spec.flags |= SIGN;
+ return number(buf, end, PTR_ERR(ptr), spec);
+ }
+
#ifdef CONFIG_64BIT
hashval = (unsigned long)siphash_1u64((u64)ptr, &ptr_key);
/*