Commit e290e6af authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'printk-for-5.2-fixes' of...

Merge tag 'printk-for-5.2-fixes' of ssh://gitolite.kernel.org/pub/scm/linux/kernel/git/pmladek/printk

Pull printk fixup from Petr Mladek:
 "Replace the problematic probe_kernel_read() with original simple
  pointer checks in vsprintf()"

* tag 'printk-for-5.2-fixes' of ssh://gitolite.kernel.org/pub/scm/linux/kernel/git/pmladek/printk:
  vsprintf: Do not break early boot with probing addresses
parents 3232b43f 2ac5a3bf
...@@ -628,19 +628,16 @@ static char *error_string(char *buf, char *end, const char *s, ...@@ -628,19 +628,16 @@ static char *error_string(char *buf, char *end, const char *s,
} }
/* /*
* This is not a fool-proof test. 99% of the time that this will fault is * Do not call any complex external code here. Nested printk()/vsprintf()
* due to a bad pointer, not one that crosses into bad memory. Just test * might cause infinite loops. Failures might break printk() and would
* the address to make sure it doesn't fault due to a poorly added printk * be hard to debug.
* during debugging.
*/ */
static const char *check_pointer_msg(const void *ptr) static const char *check_pointer_msg(const void *ptr)
{ {
char byte;
if (!ptr) if (!ptr)
return "(null)"; return "(null)";
if (probe_kernel_address(ptr, byte)) if ((unsigned long)ptr < PAGE_SIZE || IS_ERR_VALUE(ptr))
return "(efault)"; return "(efault)";
return NULL; return NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment