powerpc: Fill in si_addr_lsb siginfo field
authorAnton Blanchard <anton@samba.org>
Wed, 24 Sep 2014 06:59:58 +0000 (16:59 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 2 Oct 2014 07:15:17 +0000 (17:15 +1000)
Fill in the si_addr_lsb siginfo field so the hwpoison code can
pass to userspace the length of memory that has been corrupted.

Signed-off-by: Anton Blanchard <anton@samba.org>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/mm/fault.c

index 588b6ccc05690a89a510c6ce0baaa0e6caeb38b2..24b3f4949df40b984d1a3398646d4f1be6b5d322 100644 (file)
@@ -33,6 +33,7 @@
 #include <linux/magic.h>
 #include <linux/ratelimit.h>
 #include <linux/context_tracking.h>
+#include <linux/hugetlb.h>
 
 #include <asm/firmware.h>
 #include <asm/page.h>
@@ -118,6 +119,7 @@ static int do_sigbus(struct pt_regs *regs, unsigned long address,
                     unsigned int fault)
 {
        siginfo_t info;
+       unsigned int lsb = 0;
 
        up_read(&current->mm->mmap_sem);
 
@@ -135,7 +137,13 @@ static int do_sigbus(struct pt_regs *regs, unsigned long address,
                        current->comm, current->pid, address);
                info.si_code = BUS_MCEERR_AR;
        }
+
+       if (fault & VM_FAULT_HWPOISON_LARGE)
+               lsb = hstate_index_to_shift(VM_FAULT_GET_HINDEX(fault));
+       if (fault & VM_FAULT_HWPOISON)
+               lsb = PAGE_SHIFT;
 #endif
+       info.si_addr_lsb = lsb;
        force_sig_info(SIGBUS, &info, current);
        return MM_FAULT_RETURN;
 }