Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

mpx: Extend siginfo structure to include bound violation information

This patch adds new fields about bound violation into siginfo
structure. si_lower and si_upper are respectively lower bound
and upper bound when bound violation is caused.

Signed-off-by: Qiaowei Ren <qiaowei.ren@intel.com>
Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Cc: linux-mm@kvack.org
Cc: linux-mips@linux-mips.org
Cc: Dave Hansen <dave@sr71.net>
Link: http://lkml.kernel.org/r/20141114151819.1908C900@viggo.jf.intel.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>

authored by

Qiaowei Ren and committed by
Thomas Gleixner
ee1b58d3 62e7759b

+12 -1
+8 -1
include/uapi/asm-generic/siginfo.h
··· 91 91 int _trapno; /* TRAP # which caused the signal */ 92 92 #endif 93 93 short _addr_lsb; /* LSB of the reported address */ 94 + struct { 95 + void __user *_lower; 96 + void __user *_upper; 97 + } _addr_bnd; 94 98 } _sigfault; 95 99 96 100 /* SIGPOLL */ ··· 135 131 #define si_trapno _sifields._sigfault._trapno 136 132 #endif 137 133 #define si_addr_lsb _sifields._sigfault._addr_lsb 134 + #define si_lower _sifields._sigfault._addr_bnd._lower 135 + #define si_upper _sifields._sigfault._addr_bnd._upper 138 136 #define si_band _sifields._sigpoll._band 139 137 #define si_fd _sifields._sigpoll._fd 140 138 #ifdef __ARCH_SIGSYS ··· 205 199 */ 206 200 #define SEGV_MAPERR (__SI_FAULT|1) /* address not mapped to object */ 207 201 #define SEGV_ACCERR (__SI_FAULT|2) /* invalid permissions for mapped object */ 208 - #define NSIGSEGV 2 202 + #define SEGV_BNDERR (__SI_FAULT|3) /* failed address bound checks */ 203 + #define NSIGSEGV 3 209 204 210 205 /* 211 206 * SIGBUS si_codes
+4
kernel/signal.c
··· 2748 2748 if (from->si_code == BUS_MCEERR_AR || from->si_code == BUS_MCEERR_AO) 2749 2749 err |= __put_user(from->si_addr_lsb, &to->si_addr_lsb); 2750 2750 #endif 2751 + #ifdef SEGV_BNDERR 2752 + err |= __put_user(from->si_lower, &to->si_lower); 2753 + err |= __put_user(from->si_upper, &to->si_upper); 2754 + #endif 2751 2755 break; 2752 2756 case __SI_CHLD: 2753 2757 err |= __put_user(from->si_pid, &to->si_pid);