ARM: 8807/1: mm: Facilitate debugging CONFIG_KUSER_HELPERS disabled
authorFlorian Fainelli <f.fainelli@gmail.com>
Wed, 31 Oct 2018 22:53:12 +0000 (23:53 +0100)
committerRussell King <rmk+kernel@armlinux.org.uk>
Thu, 8 Nov 2018 10:57:10 +0000 (10:57 +0000)
Some software such as perf makes unconditional use of the special
[vectors] page which is only provided when CONFIG_KUSER_HELPERS is
enabled in the kernel.

Facilitate the debugging of such situations by printing a debug message
to the kernel log showing the task name and the faulting address.

Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Suggested-by: Russell King <rmk+kernel@armlinux.org.uk>
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
arch/arm/mm/fault.c

index f4ea4c6..58f69fa 100644 (file)
@@ -173,6 +173,12 @@ __do_user_fault(struct task_struct *tsk, unsigned long addr,
                show_regs(regs);
        }
 #endif
+#ifndef CONFIG_KUSER_HELPERS
+       if ((sig == SIGSEGV) && ((addr & PAGE_MASK) == 0xffff0000))
+               printk_ratelimited(KERN_DEBUG
+                                  "%s: CONFIG_KUSER_HELPERS disabled at 0x%08lx\n",
+                                  tsk->comm, addr);
+#endif
 
        tsk->thread.address = addr;
        tsk->thread.error_code = fsr;