提交 3eb0f519 编写于 作者: E Eric W. Biederman

signal: Ensure every siginfo we send has all bits initialized

Call clear_siginfo to ensure every stack allocated siginfo is properly
initialized before being passed to the signal sending functions.

Note: It is not safe to depend on C initializers to initialize struct
siginfo on the stack because C is allowed to skip holes when
initializing a structure.

The initialization of struct siginfo in tracehook_report_syscall_exit
was moved from the helper user_single_step_siginfo into
tracehook_report_syscall_exit itself, to make it clear that the local
variable siginfo gets fully initialized.

In a few cases the scope of struct siginfo has been reduced to make it
clear that siginfo siginfo is not used on other paths in the function
in which it is declared.

Instances of using memset to initialize siginfo have been replaced
with calls clear_siginfo for clarity.
Signed-off-by: N"Eric W. Biederman" <ebiederm@xmission.com>
上级 f6ed1eca
...@@ -881,6 +881,7 @@ SYSCALL_DEFINE5(osf_setsysinfo, unsigned long, op, void __user *, buffer, ...@@ -881,6 +881,7 @@ SYSCALL_DEFINE5(osf_setsysinfo, unsigned long, op, void __user *, buffer,
if (fex & IEEE_TRAP_ENABLE_DZE) si_code = FPE_FLTDIV; if (fex & IEEE_TRAP_ENABLE_DZE) si_code = FPE_FLTDIV;
if (fex & IEEE_TRAP_ENABLE_INV) si_code = FPE_FLTINV; if (fex & IEEE_TRAP_ENABLE_INV) si_code = FPE_FLTINV;
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
......
...@@ -221,6 +221,7 @@ do_sigreturn(struct sigcontext __user *sc) ...@@ -221,6 +221,7 @@ do_sigreturn(struct sigcontext __user *sc)
if (ptrace_cancel_bpt (current)) { if (ptrace_cancel_bpt (current)) {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_BRKPT; info.si_code = TRAP_BRKPT;
...@@ -255,6 +256,7 @@ do_rt_sigreturn(struct rt_sigframe __user *frame) ...@@ -255,6 +256,7 @@ do_rt_sigreturn(struct rt_sigframe __user *frame)
if (ptrace_cancel_bpt (current)) { if (ptrace_cancel_bpt (current)) {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_BRKPT; info.si_code = TRAP_BRKPT;
......
...@@ -228,6 +228,7 @@ do_entArith(unsigned long summary, unsigned long write_mask, ...@@ -228,6 +228,7 @@ do_entArith(unsigned long summary, unsigned long write_mask,
} }
die_if_kernel("Arithmetic fault", regs, 0, NULL); die_if_kernel("Arithmetic fault", regs, 0, NULL);
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
...@@ -241,6 +242,7 @@ do_entIF(unsigned long type, struct pt_regs *regs) ...@@ -241,6 +242,7 @@ do_entIF(unsigned long type, struct pt_regs *regs)
siginfo_t info; siginfo_t info;
int signo, code; int signo, code;
clear_siginfo(&info);
if ((regs->ps & ~IPL_MAX) == 0) { if ((regs->ps & ~IPL_MAX) == 0) {
if (type == 1) { if (type == 1) {
const unsigned int *data const unsigned int *data
...@@ -430,6 +432,7 @@ do_entDbg(struct pt_regs *regs) ...@@ -430,6 +432,7 @@ do_entDbg(struct pt_regs *regs)
die_if_kernel("Instruction fault", regs, 0, NULL); die_if_kernel("Instruction fault", regs, 0, NULL);
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLOPC; info.si_code = ILL_ILLOPC;
...@@ -761,6 +764,8 @@ do_entUnaUser(void __user * va, unsigned long opcode, ...@@ -761,6 +764,8 @@ do_entUnaUser(void __user * va, unsigned long opcode,
siginfo_t info; siginfo_t info;
long error; long error;
clear_siginfo(&info);
/* Check the UAC bits to decide what the user wants us to do /* Check the UAC bits to decide what the user wants us to do
with the unaliged access. */ with the unaliged access. */
......
...@@ -91,6 +91,8 @@ do_page_fault(unsigned long address, unsigned long mmcsr, ...@@ -91,6 +91,8 @@ do_page_fault(unsigned long address, unsigned long mmcsr,
siginfo_t info; siginfo_t info;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
/* As of EV6, a load into $31/$f31 is a prefetch, and never faults /* As of EV6, a load into $31/$f31 is a prefetch, and never faults
(or is suppressed by the PALcode). Support that for older CPUs (or is suppressed by the PALcode). Support that for older CPUs
by ignoring such an instruction. */ by ignoring such an instruction. */
......
...@@ -70,6 +70,8 @@ void do_page_fault(unsigned long address, struct pt_regs *regs) ...@@ -70,6 +70,8 @@ void do_page_fault(unsigned long address, struct pt_regs *regs)
int write = regs->ecr_cause & ECR_C_PROTV_STORE; /* ST/EX */ int write = regs->ecr_cause & ECR_C_PROTV_STORE; /* ST/EX */
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
/* /*
* We fault-in kernel-space virtual memory on-demand. The * We fault-in kernel-space virtual memory on-demand. The
* 'reference' page table is init_mm.pgd. * 'reference' page table is init_mm.pgd.
......
...@@ -205,6 +205,7 @@ void ptrace_break(struct task_struct *tsk, struct pt_regs *regs) ...@@ -205,6 +205,7 @@ void ptrace_break(struct task_struct *tsk, struct pt_regs *regs)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_BRKPT; info.si_code = TRAP_BRKPT;
......
...@@ -112,6 +112,7 @@ static void set_segfault(struct pt_regs *regs, unsigned long addr) ...@@ -112,6 +112,7 @@ static void set_segfault(struct pt_regs *regs, unsigned long addr)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
down_read(&current->mm->mmap_sem); down_read(&current->mm->mmap_sem);
if (find_vma(current->mm, addr) == NULL) if (find_vma(current->mm, addr) == NULL)
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
......
...@@ -439,6 +439,7 @@ asmlinkage void do_undefinstr(struct pt_regs *regs) ...@@ -439,6 +439,7 @@ asmlinkage void do_undefinstr(struct pt_regs *regs)
siginfo_t info; siginfo_t info;
void __user *pc; void __user *pc;
clear_siginfo(&info);
pc = (void __user *)instruction_pointer(regs); pc = (void __user *)instruction_pointer(regs);
if (processor_mode(regs) == SVC_MODE) { if (processor_mode(regs) == SVC_MODE) {
...@@ -537,6 +538,7 @@ static int bad_syscall(int n, struct pt_regs *regs) ...@@ -537,6 +538,7 @@ static int bad_syscall(int n, struct pt_regs *regs)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
if ((current->personality & PER_MASK) != PER_LINUX) { if ((current->personality & PER_MASK) != PER_LINUX) {
send_sig(SIGSEGV, current, 1); send_sig(SIGSEGV, current, 1);
return regs->ARM_r0; return regs->ARM_r0;
...@@ -604,6 +606,7 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs) ...@@ -604,6 +606,7 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
if ((no >> 16) != (__ARM_NR_BASE>> 16)) if ((no >> 16) != (__ARM_NR_BASE>> 16))
return bad_syscall(no, regs); return bad_syscall(no, regs);
...@@ -740,6 +743,8 @@ baddataabort(int code, unsigned long instr, struct pt_regs *regs) ...@@ -740,6 +743,8 @@ baddataabort(int code, unsigned long instr, struct pt_regs *regs)
unsigned long addr = instruction_pointer(regs); unsigned long addr = instruction_pointer(regs);
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
#ifdef CONFIG_DEBUG_USER #ifdef CONFIG_DEBUG_USER
if (user_debug & UDBG_BADABORT) { if (user_debug & UDBG_BADABORT) {
pr_err("[%d] %s: bad data abort: code %d instr 0x%08lx\n", pr_err("[%d] %s: bad data abort: code %d instr 0x%08lx\n",
......
...@@ -950,6 +950,7 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs) ...@@ -950,6 +950,7 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs)
if (ai_usermode & UM_SIGNAL) { if (ai_usermode & UM_SIGNAL) {
siginfo_t si; siginfo_t si;
clear_siginfo(&si);
si.si_signo = SIGBUS; si.si_signo = SIGBUS;
si.si_errno = 0; si.si_errno = 0;
si.si_code = BUS_ADRALN; si.si_code = BUS_ADRALN;
......
...@@ -163,6 +163,8 @@ __do_user_fault(struct task_struct *tsk, unsigned long addr, ...@@ -163,6 +163,8 @@ __do_user_fault(struct task_struct *tsk, unsigned long addr,
{ {
struct siginfo si; struct siginfo si;
clear_siginfo(&si);
#ifdef CONFIG_DEBUG_USER #ifdef CONFIG_DEBUG_USER
if (((user_debug & UDBG_SEGV) && (sig == SIGSEGV)) || if (((user_debug & UDBG_SEGV) && (sig == SIGSEGV)) ||
((user_debug & UDBG_BUS) && (sig == SIGBUS))) { ((user_debug & UDBG_BUS) && (sig == SIGBUS))) {
...@@ -557,6 +559,7 @@ do_DataAbort(unsigned long addr, unsigned int fsr, struct pt_regs *regs) ...@@ -557,6 +559,7 @@ do_DataAbort(unsigned long addr, unsigned int fsr, struct pt_regs *regs)
inf->name, fsr, addr); inf->name, fsr, addr);
show_pte(current->mm, addr); show_pte(current->mm, addr);
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
...@@ -589,6 +592,7 @@ do_PrefetchAbort(unsigned long addr, unsigned int ifsr, struct pt_regs *regs) ...@@ -589,6 +592,7 @@ do_PrefetchAbort(unsigned long addr, unsigned int ifsr, struct pt_regs *regs)
pr_alert("Unhandled prefetch abort: %s (0x%03x) at 0x%08lx\n", pr_alert("Unhandled prefetch abort: %s (0x%03x) at 0x%08lx\n",
inf->name, ifsr, addr); inf->name, ifsr, addr);
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
......
...@@ -218,8 +218,7 @@ static void vfp_raise_sigfpe(unsigned int sicode, struct pt_regs *regs) ...@@ -218,8 +218,7 @@ static void vfp_raise_sigfpe(unsigned int sicode, struct pt_regs *regs)
{ {
siginfo_t info; siginfo_t info;
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_code = sicode; info.si_code = sicode;
info.si_addr = (void __user *)(instruction_pointer(regs) - 4); info.si_addr = (void __user *)(instruction_pointer(regs) - 4);
......
...@@ -882,7 +882,7 @@ asmlinkage void do_fpsimd_exc(unsigned int esr, struct pt_regs *regs) ...@@ -882,7 +882,7 @@ asmlinkage void do_fpsimd_exc(unsigned int esr, struct pt_regs *regs)
si_code = FPE_FLTRES; si_code = FPE_FLTRES;
} }
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_code = si_code; info.si_code = si_code;
info.si_addr = (void __user *)instruction_pointer(regs); info.si_addr = (void __user *)instruction_pointer(regs);
......
...@@ -112,6 +112,7 @@ long compat_arm_syscall(struct pt_regs *regs) ...@@ -112,6 +112,7 @@ long compat_arm_syscall(struct pt_regs *regs)
break; break;
} }
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLTRP; info.si_code = ILL_ILLTRP;
......
...@@ -634,6 +634,7 @@ asmlinkage void bad_el0_sync(struct pt_regs *regs, int reason, unsigned int esr) ...@@ -634,6 +634,7 @@ asmlinkage void bad_el0_sync(struct pt_regs *regs, int reason, unsigned int esr)
siginfo_t info; siginfo_t info;
void __user *pc = (void __user *)instruction_pointer(regs); void __user *pc = (void __user *)instruction_pointer(regs);
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLOPC; info.si_code = ILL_ILLOPC;
......
...@@ -305,11 +305,12 @@ static void do_bad_area(unsigned long addr, unsigned int esr, struct pt_regs *re ...@@ -305,11 +305,12 @@ static void do_bad_area(unsigned long addr, unsigned int esr, struct pt_regs *re
*/ */
if (user_mode(regs)) { if (user_mode(regs)) {
const struct fault_info *inf = esr_to_fault_info(esr); const struct fault_info *inf = esr_to_fault_info(esr);
struct siginfo si = { struct siginfo si;
.si_signo = inf->sig,
.si_code = inf->code, clear_siginfo(&si);
.si_addr = (void __user *)addr, si.si_signo = inf->sig;
}; si.si_code = inf->code;
si.si_addr = (void __user *)addr;
__do_user_fault(&si, esr); __do_user_fault(&si, esr);
} else { } else {
...@@ -583,6 +584,7 @@ static int do_sea(unsigned long addr, unsigned int esr, struct pt_regs *regs) ...@@ -583,6 +584,7 @@ static int do_sea(unsigned long addr, unsigned int esr, struct pt_regs *regs)
nmi_exit(); nmi_exit();
} }
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
...@@ -687,6 +689,7 @@ asmlinkage void __exception do_mem_abort(unsigned long addr, unsigned int esr, ...@@ -687,6 +689,7 @@ asmlinkage void __exception do_mem_abort(unsigned long addr, unsigned int esr,
show_pte(addr); show_pte(addr);
} }
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
...@@ -729,6 +732,7 @@ asmlinkage void __exception do_sp_pc_abort(unsigned long addr, ...@@ -729,6 +732,7 @@ asmlinkage void __exception do_sp_pc_abort(unsigned long addr,
local_irq_enable(); local_irq_enable();
} }
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
...@@ -772,7 +776,6 @@ asmlinkage int __exception do_debug_exception(unsigned long addr, ...@@ -772,7 +776,6 @@ asmlinkage int __exception do_debug_exception(unsigned long addr,
struct pt_regs *regs) struct pt_regs *regs)
{ {
const struct fault_info *inf = debug_fault_info + DBG_ESR_EVT(esr); const struct fault_info *inf = debug_fault_info + DBG_ESR_EVT(esr);
struct siginfo info;
int rv; int rv;
/* /*
...@@ -788,6 +791,9 @@ asmlinkage int __exception do_debug_exception(unsigned long addr, ...@@ -788,6 +791,9 @@ asmlinkage int __exception do_debug_exception(unsigned long addr,
if (!inf->fn(addr, esr, regs)) { if (!inf->fn(addr, esr, regs)) {
rv = 1; rv = 1;
} else { } else {
struct siginfo info;
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
......
...@@ -246,6 +246,7 @@ static void do_trap(struct exception_info *except_info, struct pt_regs *regs) ...@@ -246,6 +246,7 @@ static void do_trap(struct exception_info *except_info, struct pt_regs *regs)
unsigned long addr = instruction_pointer(regs); unsigned long addr = instruction_pointer(regs);
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
if (except_info->code != TRAP_BRKPT) if (except_info->code != TRAP_BRKPT)
pr_err("TRAP: %s PC[0x%lx] signo[%d] code[%d]\n", pr_err("TRAP: %s PC[0x%lx] signo[%d] code[%d]\n",
except_info->kernel_str, regs->pc, except_info->kernel_str, regs->pc,
......
...@@ -414,6 +414,7 @@ void do_trap0(struct pt_regs *regs) ...@@ -414,6 +414,7 @@ void do_trap0(struct pt_regs *regs)
if (user_mode(regs)) { if (user_mode(regs)) {
struct siginfo info; struct siginfo info;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
/* /*
......
...@@ -56,6 +56,7 @@ void do_page_fault(unsigned long address, long cause, struct pt_regs *regs) ...@@ -56,6 +56,7 @@ void do_page_fault(unsigned long address, long cause, struct pt_regs *regs)
const struct exception_table_entry *fixup; const struct exception_table_entry *fixup;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
/* /*
* If we're in an interrupt or have no user context, * If we're in an interrupt or have no user context,
* then must not take the fault. * then must not take the fault.
......
...@@ -62,6 +62,7 @@ ia64_emulate_brl (struct pt_regs *regs, unsigned long ar_ec) ...@@ -62,6 +62,7 @@ ia64_emulate_brl (struct pt_regs *regs, unsigned long ar_ec)
struct illegal_op_return rv; struct illegal_op_return rv;
long tmp_taken, unimplemented_address; long tmp_taken, unimplemented_address;
clear_siginfo(&siginfo);
rv.fkt = (unsigned long) -1; rv.fkt = (unsigned long) -1;
/* /*
......
...@@ -153,6 +153,7 @@ ia64_rt_sigreturn (struct sigscratch *scr) ...@@ -153,6 +153,7 @@ ia64_rt_sigreturn (struct sigscratch *scr)
return retval; return retval;
give_sigsegv: give_sigsegv:
clear_siginfo(&si);
si.si_signo = SIGSEGV; si.si_signo = SIGSEGV;
si.si_errno = 0; si.si_errno = 0;
si.si_code = SI_KERNEL; si.si_code = SI_KERNEL;
...@@ -236,6 +237,7 @@ force_sigsegv_info (int sig, void __user *addr) ...@@ -236,6 +237,7 @@ force_sigsegv_info (int sig, void __user *addr)
unsigned long flags; unsigned long flags;
struct siginfo si; struct siginfo si;
clear_siginfo(&si);
if (sig == SIGSEGV) { if (sig == SIGSEGV) {
/* /*
* Acquiring siglock around the sa_handler-update is almost * Acquiring siglock around the sa_handler-update is almost
......
...@@ -104,6 +104,7 @@ __kprobes ia64_bad_break (unsigned long break_num, struct pt_regs *regs) ...@@ -104,6 +104,7 @@ __kprobes ia64_bad_break (unsigned long break_num, struct pt_regs *regs)
int sig, code; int sig, code;
/* SIGILL, SIGFPE, SIGSEGV, and SIGBUS want these field initialized: */ /* SIGILL, SIGFPE, SIGSEGV, and SIGBUS want these field initialized: */
clear_siginfo(&siginfo);
siginfo.si_addr = (void __user *) (regs->cr_iip + ia64_psr(regs)->ri); siginfo.si_addr = (void __user *) (regs->cr_iip + ia64_psr(regs)->ri);
siginfo.si_imm = break_num; siginfo.si_imm = break_num;
siginfo.si_flags = 0; /* clear __ISR_VALID */ siginfo.si_flags = 0; /* clear __ISR_VALID */
...@@ -293,7 +294,6 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr) ...@@ -293,7 +294,6 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr)
{ {
long exception, bundle[2]; long exception, bundle[2];
unsigned long fault_ip; unsigned long fault_ip;
struct siginfo siginfo;
fault_ip = regs->cr_iip; fault_ip = regs->cr_iip;
if (!fp_fault && (ia64_psr(regs)->ri == 0)) if (!fp_fault && (ia64_psr(regs)->ri == 0))
...@@ -344,10 +344,13 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr) ...@@ -344,10 +344,13 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr)
printk(KERN_ERR "handle_fpu_swa: fp_emulate() returned -1\n"); printk(KERN_ERR "handle_fpu_swa: fp_emulate() returned -1\n");
return -1; return -1;
} else { } else {
struct siginfo siginfo;
/* is next instruction a trap? */ /* is next instruction a trap? */
if (exception & 2) { if (exception & 2) {
ia64_increment_ip(regs); ia64_increment_ip(regs);
} }
clear_siginfo(&siginfo);
siginfo.si_signo = SIGFPE; siginfo.si_signo = SIGFPE;
siginfo.si_errno = 0; siginfo.si_errno = 0;
siginfo.si_code = FPE_FIXME; /* default code */ siginfo.si_code = FPE_FIXME; /* default code */
...@@ -372,6 +375,9 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr) ...@@ -372,6 +375,9 @@ handle_fpu_swa (int fp_fault, struct pt_regs *regs, unsigned long isr)
return -1; return -1;
} else if (exception != 0) { } else if (exception != 0) {
/* raise exception */ /* raise exception */
struct siginfo siginfo;
clear_siginfo(&siginfo);
siginfo.si_signo = SIGFPE; siginfo.si_signo = SIGFPE;
siginfo.si_errno = 0; siginfo.si_errno = 0;
siginfo.si_code = FPE_FIXME; /* default code */ siginfo.si_code = FPE_FIXME; /* default code */
...@@ -420,7 +426,7 @@ ia64_illegal_op_fault (unsigned long ec, long arg1, long arg2, long arg3, ...@@ -420,7 +426,7 @@ ia64_illegal_op_fault (unsigned long ec, long arg1, long arg2, long arg3,
if (die_if_kernel(buf, &regs, 0)) if (die_if_kernel(buf, &regs, 0))
return rv; return rv;
memset(&si, 0, sizeof(si)); clear_siginfo(&si);
si.si_signo = SIGILL; si.si_signo = SIGILL;
si.si_code = ILL_ILLOPC; si.si_code = ILL_ILLOPC;
si.si_addr = (void __user *) (regs.cr_iip + ia64_psr(&regs)->ri); si.si_addr = (void __user *) (regs.cr_iip + ia64_psr(&regs)->ri);
...@@ -434,7 +440,6 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -434,7 +440,6 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
long arg7, struct pt_regs regs) long arg7, struct pt_regs regs)
{ {
unsigned long code, error = isr, iip; unsigned long code, error = isr, iip;
struct siginfo siginfo;
char buf[128]; char buf[128];
int result, sig; int result, sig;
static const char *reason[] = { static const char *reason[] = {
...@@ -485,6 +490,7 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -485,6 +490,7 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
case 26: /* NaT Consumption */ case 26: /* NaT Consumption */
if (user_mode(&regs)) { if (user_mode(&regs)) {
struct siginfo siginfo;
void __user *addr; void __user *addr;
if (((isr >> 4) & 0xf) == 2) { if (((isr >> 4) & 0xf) == 2) {
...@@ -499,6 +505,7 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -499,6 +505,7 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
addr = (void __user *) (regs.cr_iip addr = (void __user *) (regs.cr_iip
+ ia64_psr(&regs)->ri); + ia64_psr(&regs)->ri);
} }
clear_siginfo(&siginfo);
siginfo.si_signo = sig; siginfo.si_signo = sig;
siginfo.si_code = code; siginfo.si_code = code;
siginfo.si_errno = 0; siginfo.si_errno = 0;
...@@ -515,6 +522,9 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -515,6 +522,9 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
case 31: /* Unsupported Data Reference */ case 31: /* Unsupported Data Reference */
if (user_mode(&regs)) { if (user_mode(&regs)) {
struct siginfo siginfo;
clear_siginfo(&siginfo);
siginfo.si_signo = SIGILL; siginfo.si_signo = SIGILL;
siginfo.si_code = ILL_ILLOPN; siginfo.si_code = ILL_ILLOPN;
siginfo.si_errno = 0; siginfo.si_errno = 0;
...@@ -531,6 +541,10 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -531,6 +541,10 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
case 29: /* Debug */ case 29: /* Debug */
case 35: /* Taken Branch Trap */ case 35: /* Taken Branch Trap */
case 36: /* Single Step Trap */ case 36: /* Single Step Trap */
{
struct siginfo siginfo;
clear_siginfo(&siginfo);
if (fsys_mode(current, &regs)) { if (fsys_mode(current, &regs)) {
extern char __kernel_syscall_via_break[]; extern char __kernel_syscall_via_break[];
/* /*
...@@ -578,11 +592,15 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -578,11 +592,15 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
siginfo.si_isr = isr; siginfo.si_isr = isr;
force_sig_info(SIGTRAP, &siginfo, current); force_sig_info(SIGTRAP, &siginfo, current);
return; return;
}
case 32: /* fp fault */ case 32: /* fp fault */
case 33: /* fp trap */ case 33: /* fp trap */
result = handle_fpu_swa((vector == 32) ? 1 : 0, &regs, isr); result = handle_fpu_swa((vector == 32) ? 1 : 0, &regs, isr);
if ((result < 0) || (current->thread.flags & IA64_THREAD_FPEMU_SIGFPE)) { if ((result < 0) || (current->thread.flags & IA64_THREAD_FPEMU_SIGFPE)) {
struct siginfo siginfo;
clear_siginfo(&siginfo);
siginfo.si_signo = SIGFPE; siginfo.si_signo = SIGFPE;
siginfo.si_errno = 0; siginfo.si_errno = 0;
siginfo.si_code = FPE_FLTINV; siginfo.si_code = FPE_FLTINV;
...@@ -616,6 +634,9 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa, ...@@ -616,6 +634,9 @@ ia64_fault (unsigned long vector, unsigned long isr, unsigned long ifa,
} else { } else {
/* Unimplemented Instr. Address Trap */ /* Unimplemented Instr. Address Trap */
if (user_mode(&regs)) { if (user_mode(&regs)) {
struct siginfo siginfo;
clear_siginfo(&siginfo);
siginfo.si_signo = SIGILL; siginfo.si_signo = SIGILL;
siginfo.si_code = ILL_BADIADDR; siginfo.si_code = ILL_BADIADDR;
siginfo.si_errno = 0; siginfo.si_errno = 0;
......
...@@ -1537,6 +1537,7 @@ ia64_handle_unaligned (unsigned long ifa, struct pt_regs *regs) ...@@ -1537,6 +1537,7 @@ ia64_handle_unaligned (unsigned long ifa, struct pt_regs *regs)
/* NOT_REACHED */ /* NOT_REACHED */
} }
force_sigbus: force_sigbus:
clear_siginfo(&si);
si.si_signo = SIGBUS; si.si_signo = SIGBUS;
si.si_errno = 0; si.si_errno = 0;
si.si_code = BUS_ADRALN; si.si_code = BUS_ADRALN;
......
...@@ -85,7 +85,6 @@ ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *re ...@@ -85,7 +85,6 @@ ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *re
int signal = SIGSEGV, code = SEGV_MAPERR; int signal = SIGSEGV, code = SEGV_MAPERR;
struct vm_area_struct *vma, *prev_vma; struct vm_area_struct *vma, *prev_vma;
struct mm_struct *mm = current->mm; struct mm_struct *mm = current->mm;
struct siginfo si;
unsigned long mask; unsigned long mask;
int fault; int fault;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
...@@ -249,6 +248,9 @@ ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *re ...@@ -249,6 +248,9 @@ ia64_do_page_fault (unsigned long address, unsigned long isr, struct pt_regs *re
return; return;
} }
if (user_mode(regs)) { if (user_mode(regs)) {
struct siginfo si;
clear_siginfo(&si);
si.si_signo = signal; si.si_signo = signal;
si.si_errno = 0; si.si_errno = 0;
si.si_code = code; si.si_code = code;
......
...@@ -1011,6 +1011,7 @@ asmlinkage void trap_c(struct frame *fp) ...@@ -1011,6 +1011,7 @@ asmlinkage void trap_c(struct frame *fp)
int vector = (fp->ptregs.vector >> 2) & 0xff; int vector = (fp->ptregs.vector >> 2) & 0xff;
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
if (fp->ptregs.sr & PS_S) { if (fp->ptregs.sr & PS_S) {
if (vector == VEC_TRACE) { if (vector == VEC_TRACE) {
/* traced a trapping instruction on a 68020/30, /* traced a trapping instruction on a 68020/30,
...@@ -1163,6 +1164,7 @@ asmlinkage void fpemu_signal(int signal, int code, void *addr) ...@@ -1163,6 +1164,7 @@ asmlinkage void fpemu_signal(int signal, int code, void *addr)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = signal; info.si_signo = signal;
info.si_errno = 0; info.si_errno = 0;
info.si_code = code; info.si_code = code;
......
...@@ -65,6 +65,7 @@ void _exception(int signr, struct pt_regs *regs, int code, unsigned long addr) ...@@ -65,6 +65,7 @@ void _exception(int signr, struct pt_regs *regs, int code, unsigned long addr)
if (kernel_mode(regs)) if (kernel_mode(regs))
die("Exception in kernel mode", regs, signr); die("Exception in kernel mode", regs, signr);
clear_siginfo(&info);
info.si_signo = signr; info.si_signo = signr;
info.si_errno = 0; info.si_errno = 0;
info.si_code = code; info.si_code = code;
......
...@@ -88,7 +88,6 @@ void do_page_fault(struct pt_regs *regs, unsigned long address, ...@@ -88,7 +88,6 @@ void do_page_fault(struct pt_regs *regs, unsigned long address,
{ {
struct vm_area_struct *vma; struct vm_area_struct *vma;
struct mm_struct *mm = current->mm; struct mm_struct *mm = current->mm;
siginfo_t info;
int code = SEGV_MAPERR; int code = SEGV_MAPERR;
int is_write = error_code & ESR_S; int is_write = error_code & ESR_S;
int fault; int fault;
...@@ -295,6 +294,9 @@ void do_page_fault(struct pt_regs *regs, unsigned long address, ...@@ -295,6 +294,9 @@ void do_page_fault(struct pt_regs *regs, unsigned long address,
do_sigbus: do_sigbus:
up_read(&mm->mmap_sem); up_read(&mm->mmap_sem);
if (user_mode(regs)) { if (user_mode(regs)) {
siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRERR; info.si_code = BUS_ADRERR;
......
...@@ -63,6 +63,7 @@ static void __kprobes __do_page_fault(struct pt_regs *regs, unsigned long write, ...@@ -63,6 +63,7 @@ static void __kprobes __do_page_fault(struct pt_regs *regs, unsigned long write,
return; return;
#endif #endif
clear_siginfo(&info);
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
/* /*
......
...@@ -229,6 +229,7 @@ int bad_syscall(int n, struct pt_regs *regs) ...@@ -229,6 +229,7 @@ int bad_syscall(int n, struct pt_regs *regs)
return regs->uregs[0]; return regs->uregs[0];
} }
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLTRP; info.si_code = ILL_ILLTRP;
...@@ -292,7 +293,7 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, ...@@ -292,7 +293,7 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs,
tsk->thread.trap_no = ENTRY_DEBUG_RELATED; tsk->thread.trap_no = ENTRY_DEBUG_RELATED;
tsk->thread.error_code = error_code; tsk->thread.error_code = error_code;
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_code = si_code; info.si_code = si_code;
info.si_addr = (void __user *)instruction_pointer(regs); info.si_addr = (void __user *)instruction_pointer(regs);
......
...@@ -77,6 +77,7 @@ void do_page_fault(unsigned long entry, unsigned long addr, ...@@ -77,6 +77,7 @@ void do_page_fault(unsigned long entry, unsigned long addr,
unsigned int mask = VM_READ | VM_WRITE | VM_EXEC; unsigned int mask = VM_READ | VM_WRITE | VM_EXEC;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
error_code = error_code & (ITYPE_mskINST | ITYPE_mskETYPE); error_code = error_code & (ITYPE_mskINST | ITYPE_mskETYPE);
tsk = current; tsk = current;
mm = tsk->mm; mm = tsk->mm;
......
...@@ -28,6 +28,7 @@ static void _send_sig(int signo, int code, unsigned long addr) ...@@ -28,6 +28,7 @@ static void _send_sig(int signo, int code, unsigned long addr)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = signo; info.si_signo = signo;
info.si_errno = 0; info.si_errno = 0;
info.si_code = code; info.si_code = code;
......
...@@ -251,7 +251,7 @@ void __init trap_init(void) ...@@ -251,7 +251,7 @@ void __init trap_init(void)
asmlinkage void do_trap(struct pt_regs *regs, unsigned long address) asmlinkage void do_trap(struct pt_regs *regs, unsigned long address)
{ {
siginfo_t info; siginfo_t info;
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_code = TRAP_TRACE; info.si_code = TRAP_TRACE;
info.si_addr = (void *)address; info.si_addr = (void *)address;
...@@ -266,6 +266,7 @@ asmlinkage void do_unaligned_access(struct pt_regs *regs, unsigned long address) ...@@ -266,6 +266,7 @@ asmlinkage void do_unaligned_access(struct pt_regs *regs, unsigned long address)
if (user_mode(regs)) { if (user_mode(regs)) {
/* Send a SIGBUS */ /* Send a SIGBUS */
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
...@@ -285,6 +286,7 @@ asmlinkage void do_bus_fault(struct pt_regs *regs, unsigned long address) ...@@ -285,6 +286,7 @@ asmlinkage void do_bus_fault(struct pt_regs *regs, unsigned long address)
if (user_mode(regs)) { if (user_mode(regs)) {
/* Send a SIGBUS */ /* Send a SIGBUS */
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRERR; info.si_code = BUS_ADRERR;
...@@ -485,6 +487,7 @@ asmlinkage void do_illegal_instruction(struct pt_regs *regs, ...@@ -485,6 +487,7 @@ asmlinkage void do_illegal_instruction(struct pt_regs *regs,
if (user_mode(regs)) { if (user_mode(regs)) {
/* Send a SIGILL */ /* Send a SIGILL */
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLOPC; info.si_code = ILL_ILLOPC;
......
...@@ -56,6 +56,7 @@ asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long address, ...@@ -56,6 +56,7 @@ asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long address,
int fault; int fault;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
tsk = current; tsk = current;
/* /*
......
...@@ -90,6 +90,7 @@ void user_enable_single_step(struct task_struct *task) ...@@ -90,6 +90,7 @@ void user_enable_single_step(struct task_struct *task)
ptrace_disable(task); ptrace_disable(task);
/* Don't wake up the task, but let the /* Don't wake up the task, but let the
parent know something happened. */ parent know something happened. */
clear_siginfo(&si);
si.si_code = TRAP_TRACE; si.si_code = TRAP_TRACE;
si.si_addr = (void __user *) (task_regs(task)->iaoq[0] & ~3); si.si_addr = (void __user *) (task_regs(task)->iaoq[0] & ~3);
si.si_signo = SIGTRAP; si.si_signo = SIGTRAP;
......
...@@ -299,6 +299,7 @@ static void handle_gdb_break(struct pt_regs *regs, int wot) ...@@ -299,6 +299,7 @@ static void handle_gdb_break(struct pt_regs *regs, int wot)
{ {
struct siginfo si; struct siginfo si;
clear_siginfo(&si);
si.si_signo = SIGTRAP; si.si_signo = SIGTRAP;
si.si_errno = 0; si.si_errno = 0;
si.si_code = wot; si.si_code = wot;
...@@ -489,6 +490,7 @@ void notrace handle_interruption(int code, struct pt_regs *regs) ...@@ -489,6 +490,7 @@ void notrace handle_interruption(int code, struct pt_regs *regs)
unsigned long fault_space = 0; unsigned long fault_space = 0;
struct siginfo si; struct siginfo si;
clear_siginfo(&si);
if (code == 1) if (code == 1)
pdc_console_restart(); /* switch back to pdc if HPMC */ pdc_console_restart(); /* switch back to pdc if HPMC */
else else
......
...@@ -455,6 +455,7 @@ void handle_unaligned(struct pt_regs *regs) ...@@ -455,6 +455,7 @@ void handle_unaligned(struct pt_regs *regs)
struct siginfo si; struct siginfo si;
register int flop=0; /* true if this is a flop */ register int flop=0; /* true if this is a flop */
clear_siginfo(&si);
__inc_irq_stat(irq_unaligned_count); __inc_irq_stat(irq_unaligned_count);
/* log a message with pacing */ /* log a message with pacing */
......
...@@ -93,6 +93,7 @@ handle_fpe(struct pt_regs *regs) ...@@ -93,6 +93,7 @@ handle_fpe(struct pt_regs *regs)
*/ */
__u64 frcopy[36]; __u64 frcopy[36];
clear_siginfo(&si);
memcpy(frcopy, regs->fr, sizeof regs->fr); memcpy(frcopy, regs->fr, sizeof regs->fr);
frcopy[32] = 0; frcopy[32] = 0;
......
...@@ -356,6 +356,7 @@ void do_page_fault(struct pt_regs *regs, unsigned long code, ...@@ -356,6 +356,7 @@ void do_page_fault(struct pt_regs *regs, unsigned long code,
struct siginfo si; struct siginfo si;
unsigned int lsb = 0; unsigned int lsb = 0;
clear_siginfo(&si);
switch (code) { switch (code) {
case 15: /* Data TLB miss fault/Data page fault */ case 15: /* Data TLB miss fault/Data page fault */
/* send SIGSEGV when outside of vma */ /* send SIGSEGV when outside of vma */
......
...@@ -632,6 +632,7 @@ void do_break (struct pt_regs *regs, unsigned long address, ...@@ -632,6 +632,7 @@ void do_break (struct pt_regs *regs, unsigned long address,
hw_breakpoint_disable(); hw_breakpoint_disable();
/* Deliver the signal to userspace */ /* Deliver the signal to userspace */
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_HWBKPT; info.si_code = TRAP_HWBKPT;
......
...@@ -296,7 +296,6 @@ NOKPROBE_SYMBOL(die); ...@@ -296,7 +296,6 @@ NOKPROBE_SYMBOL(die);
void user_single_step_siginfo(struct task_struct *tsk, void user_single_step_siginfo(struct task_struct *tsk,
struct pt_regs *regs, siginfo_t *info) struct pt_regs *regs, siginfo_t *info)
{ {
memset(info, 0, sizeof(*info));
info->si_signo = SIGTRAP; info->si_signo = SIGTRAP;
info->si_code = TRAP_TRACE; info->si_code = TRAP_TRACE;
info->si_addr = (void __user *)regs->nip; info->si_addr = (void __user *)regs->nip;
...@@ -334,7 +333,7 @@ void _exception_pkey(int signr, struct pt_regs *regs, int code, ...@@ -334,7 +333,7 @@ void _exception_pkey(int signr, struct pt_regs *regs, int code,
*/ */
thread_pkey_regs_save(&current->thread); thread_pkey_regs_save(&current->thread);
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = signr; info.si_signo = signr;
info.si_code = code; info.si_code = code;
info.si_addr = (void __user *) addr; info.si_addr = (void __user *) addr;
......
...@@ -168,6 +168,7 @@ static int do_sigbus(struct pt_regs *regs, unsigned long address, ...@@ -168,6 +168,7 @@ static int do_sigbus(struct pt_regs *regs, unsigned long address,
return SIGBUS; return SIGBUS;
current->thread.trap_nr = BUS_ADRERR; current->thread.trap_nr = BUS_ADRERR;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRERR; info.si_code = BUS_ADRERR;
......
...@@ -44,7 +44,7 @@ static void spufs_handle_event(struct spu_context *ctx, ...@@ -44,7 +44,7 @@ static void spufs_handle_event(struct spu_context *ctx,
return; return;
} }
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
switch (type) { switch (type) {
case SPE_EVENT_INVALID_DMA: case SPE_EVENT_INVALID_DMA:
......
...@@ -68,6 +68,7 @@ static inline void do_trap_siginfo(int signo, int code, ...@@ -68,6 +68,7 @@ static inline void do_trap_siginfo(int signo, int code,
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = signo; info.si_signo = signo;
info.si_errno = 0; info.si_errno = 0;
info.si_code = code; info.si_code = code;
......
...@@ -47,6 +47,7 @@ void do_report_trap(struct pt_regs *regs, int si_signo, int si_code, char *str) ...@@ -47,6 +47,7 @@ void do_report_trap(struct pt_regs *regs, int si_signo, int si_code, char *str)
siginfo_t info; siginfo_t info;
if (user_mode(regs)) { if (user_mode(regs)) {
clear_siginfo(&info);
info.si_signo = si_signo; info.si_signo = si_signo;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
...@@ -86,6 +87,7 @@ void do_per_trap(struct pt_regs *regs) ...@@ -86,6 +87,7 @@ void do_per_trap(struct pt_regs *regs)
return; return;
if (!current->ptrace) if (!current->ptrace)
return; return;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_HWBKPT; info.si_code = TRAP_HWBKPT;
...@@ -165,7 +167,6 @@ void translation_exception(struct pt_regs *regs) ...@@ -165,7 +167,6 @@ void translation_exception(struct pt_regs *regs)
void illegal_op(struct pt_regs *regs) void illegal_op(struct pt_regs *regs)
{ {
siginfo_t info;
__u8 opcode[6]; __u8 opcode[6];
__u16 __user *location; __u16 __user *location;
int is_uprobe_insn = 0; int is_uprobe_insn = 0;
...@@ -178,6 +179,8 @@ void illegal_op(struct pt_regs *regs) ...@@ -178,6 +179,8 @@ void illegal_op(struct pt_regs *regs)
return; return;
if (*((__u16 *) opcode) == S390_BREAKPOINT_U16) { if (*((__u16 *) opcode) == S390_BREAKPOINT_U16) {
if (current->ptrace) { if (current->ptrace) {
siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_BRKPT; info.si_code = TRAP_BRKPT;
......
...@@ -268,6 +268,7 @@ static noinline void do_sigsegv(struct pt_regs *regs, int si_code) ...@@ -268,6 +268,7 @@ static noinline void do_sigsegv(struct pt_regs *regs, int si_code)
struct siginfo si; struct siginfo si;
report_user_fault(regs, SIGSEGV, 1); report_user_fault(regs, SIGSEGV, 1);
clear_siginfo(&si);
si.si_signo = SIGSEGV; si.si_signo = SIGSEGV;
si.si_errno = 0; si.si_errno = 0;
si.si_code = si_code; si.si_code = si_code;
...@@ -323,6 +324,7 @@ static noinline void do_sigbus(struct pt_regs *regs) ...@@ -323,6 +324,7 @@ static noinline void do_sigbus(struct pt_regs *regs)
* Send a sigbus, regardless of whether we were in kernel * Send a sigbus, regardless of whether we were in kernel
* or user mode. * or user mode.
*/ */
clear_siginfo(&si);
si.si_signo = SIGBUS; si.si_signo = SIGBUS;
si.si_errno = 0; si.si_errno = 0;
si.si_code = BUS_ADRERR; si.si_code = BUS_ADRERR;
......
...@@ -537,6 +537,7 @@ asmlinkage void do_address_error(struct pt_regs *regs, ...@@ -537,6 +537,7 @@ asmlinkage void do_address_error(struct pt_regs *regs,
"access (PC %lx PR %lx)\n", current->comm, regs->pc, "access (PC %lx PR %lx)\n", current->comm, regs->pc,
regs->pr); regs->pr);
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
...@@ -600,6 +601,7 @@ asmlinkage void do_divide_error(unsigned long r4) ...@@ -600,6 +601,7 @@ asmlinkage void do_divide_error(unsigned long r4)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
switch (r4) { switch (r4) {
case TRAP_DIVZERO_ERROR: case TRAP_DIVZERO_ERROR:
info.si_code = FPE_INTDIV; info.si_code = FPE_INTDIV;
......
...@@ -560,6 +560,7 @@ static int ieee_fpe_handler(struct pt_regs *regs) ...@@ -560,6 +560,7 @@ static int ieee_fpe_handler(struct pt_regs *regs)
~(FPSCR_CAUSE_MASK | FPSCR_FLAG_MASK); ~(FPSCR_CAUSE_MASK | FPSCR_FLAG_MASK);
task_thread_info(tsk)->status |= TS_USEDFPU; task_thread_info(tsk)->status |= TS_USEDFPU;
} else { } else {
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_code = FPE_FLTINV; info.si_code = FPE_FLTINV;
......
...@@ -44,6 +44,7 @@ force_sig_info_fault(int si_signo, int si_code, unsigned long address, ...@@ -44,6 +44,7 @@ force_sig_info_fault(int si_signo, int si_code, unsigned long address,
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = si_signo; info.si_signo = si_signo;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
......
...@@ -520,6 +520,7 @@ static void stack_unaligned(unsigned long sp) ...@@ -520,6 +520,7 @@ static void stack_unaligned(unsigned long sp)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
......
...@@ -152,6 +152,7 @@ sparc_breakpoint (struct pt_regs *regs) ...@@ -152,6 +152,7 @@ sparc_breakpoint (struct pt_regs *regs)
#ifdef DEBUG_SPARC_BREAKPOINT #ifdef DEBUG_SPARC_BREAKPOINT
printk ("TRAP: Entering kernel PC=%x, nPC=%x\n", regs->pc, regs->npc); printk ("TRAP: Entering kernel PC=%x, nPC=%x\n", regs->pc, regs->npc);
#endif #endif
clear_siginfo(&info);
info.si_signo = SIGTRAP; info.si_signo = SIGTRAP;
info.si_errno = 0; info.si_errno = 0;
info.si_code = TRAP_BRKPT; info.si_code = TRAP_BRKPT;
......
...@@ -104,6 +104,7 @@ void do_hw_interrupt(struct pt_regs *regs, unsigned long type) ...@@ -104,6 +104,7 @@ void do_hw_interrupt(struct pt_regs *regs, unsigned long type)
if(regs->psr & PSR_PS) if(regs->psr & PSR_PS)
die_if_kernel("Kernel bad trap", regs); die_if_kernel("Kernel bad trap", regs);
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLTRP; info.si_code = ILL_ILLTRP;
...@@ -124,6 +125,7 @@ void do_illegal_instruction(struct pt_regs *regs, unsigned long pc, unsigned lon ...@@ -124,6 +125,7 @@ void do_illegal_instruction(struct pt_regs *regs, unsigned long pc, unsigned lon
regs->pc, *(unsigned long *)regs->pc); regs->pc, *(unsigned long *)regs->pc);
#endif #endif
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLOPC; info.si_code = ILL_ILLOPC;
...@@ -139,6 +141,7 @@ void do_priv_instruction(struct pt_regs *regs, unsigned long pc, unsigned long n ...@@ -139,6 +141,7 @@ void do_priv_instruction(struct pt_regs *regs, unsigned long pc, unsigned long n
if(psr & PSR_PS) if(psr & PSR_PS)
die_if_kernel("Penguin instruction from Penguin mode??!?!", regs); die_if_kernel("Penguin instruction from Penguin mode??!?!", regs);
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_PRVOPC; info.si_code = ILL_PRVOPC;
...@@ -165,6 +168,7 @@ void do_memaccess_unaligned(struct pt_regs *regs, unsigned long pc, unsigned lon ...@@ -165,6 +168,7 @@ void do_memaccess_unaligned(struct pt_regs *regs, unsigned long pc, unsigned lon
instruction_dump ((unsigned long *) regs->pc); instruction_dump ((unsigned long *) regs->pc);
printk ("do_MNA!\n"); printk ("do_MNA!\n");
#endif #endif
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
...@@ -303,6 +307,7 @@ void do_fpe_trap(struct pt_regs *regs, unsigned long pc, unsigned long npc, ...@@ -303,6 +307,7 @@ void do_fpe_trap(struct pt_regs *regs, unsigned long pc, unsigned long npc,
} }
fsr = fpt->thread.fsr; fsr = fpt->thread.fsr;
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_addr = (void __user *)pc; info.si_addr = (void __user *)pc;
...@@ -336,6 +341,7 @@ void handle_tag_overflow(struct pt_regs *regs, unsigned long pc, unsigned long n ...@@ -336,6 +341,7 @@ void handle_tag_overflow(struct pt_regs *regs, unsigned long pc, unsigned long n
if(psr & PSR_PS) if(psr & PSR_PS)
die_if_kernel("Penguin overflow trap from kernel mode", regs); die_if_kernel("Penguin overflow trap from kernel mode", regs);
clear_siginfo(&info);
info.si_signo = SIGEMT; info.si_signo = SIGEMT;
info.si_errno = 0; info.si_errno = 0;
info.si_code = EMT_TAGOVF; info.si_code = EMT_TAGOVF;
...@@ -365,6 +371,7 @@ void handle_reg_access(struct pt_regs *regs, unsigned long pc, unsigned long npc ...@@ -365,6 +371,7 @@ void handle_reg_access(struct pt_regs *regs, unsigned long pc, unsigned long npc
printk("Register Access Exception at PC %08lx NPC %08lx PSR %08lx\n", printk("Register Access Exception at PC %08lx NPC %08lx PSR %08lx\n",
pc, npc, psr); pc, npc, psr);
#endif #endif
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_OBJERR; info.si_code = BUS_OBJERR;
...@@ -378,6 +385,7 @@ void handle_cp_disabled(struct pt_regs *regs, unsigned long pc, unsigned long np ...@@ -378,6 +385,7 @@ void handle_cp_disabled(struct pt_regs *regs, unsigned long pc, unsigned long np
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_COPROC; info.si_code = ILL_COPROC;
...@@ -395,6 +403,7 @@ void handle_cp_exception(struct pt_regs *regs, unsigned long pc, unsigned long n ...@@ -395,6 +403,7 @@ void handle_cp_exception(struct pt_regs *regs, unsigned long pc, unsigned long n
printk("Co-Processor Exception at PC %08lx NPC %08lx PSR %08lx\n", printk("Co-Processor Exception at PC %08lx NPC %08lx PSR %08lx\n",
pc, npc, psr); pc, npc, psr);
#endif #endif
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_COPROC; info.si_code = ILL_COPROC;
...@@ -408,6 +417,7 @@ void handle_hw_divzero(struct pt_regs *regs, unsigned long pc, unsigned long npc ...@@ -408,6 +417,7 @@ void handle_hw_divzero(struct pt_regs *regs, unsigned long pc, unsigned long npc
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_code = FPE_INTDIV; info.si_code = FPE_INTDIV;
......
...@@ -107,6 +107,7 @@ void bad_trap(struct pt_regs *regs, long lvl) ...@@ -107,6 +107,7 @@ void bad_trap(struct pt_regs *regs, long lvl)
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLTRP; info.si_code = ILL_ILLTRP;
...@@ -206,6 +207,7 @@ void spitfire_insn_access_exception(struct pt_regs *regs, unsigned long sfsr, un ...@@ -206,6 +207,7 @@ void spitfire_insn_access_exception(struct pt_regs *regs, unsigned long sfsr, un
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGSEGV; info.si_signo = SIGSEGV;
info.si_errno = 0; info.si_errno = 0;
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
...@@ -247,6 +249,7 @@ void sun4v_insn_access_exception(struct pt_regs *regs, unsigned long addr, unsig ...@@ -247,6 +249,7 @@ void sun4v_insn_access_exception(struct pt_regs *regs, unsigned long addr, unsig
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGSEGV; info.si_signo = SIGSEGV;
info.si_errno = 0; info.si_errno = 0;
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
...@@ -338,6 +341,7 @@ void spitfire_data_access_exception(struct pt_regs *regs, unsigned long sfsr, un ...@@ -338,6 +341,7 @@ void spitfire_data_access_exception(struct pt_regs *regs, unsigned long sfsr, un
if (is_no_fault_exception(regs)) if (is_no_fault_exception(regs))
return; return;
clear_siginfo(&info);
info.si_signo = SIGSEGV; info.si_signo = SIGSEGV;
info.si_errno = 0; info.si_errno = 0;
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
...@@ -595,6 +599,7 @@ static void spitfire_ue_log(unsigned long afsr, unsigned long afar, unsigned lon ...@@ -595,6 +599,7 @@ static void spitfire_ue_log(unsigned long afsr, unsigned long afar, unsigned lon
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_OBJERR; info.si_code = BUS_OBJERR;
...@@ -2211,6 +2216,7 @@ bool sun4v_nonresum_error_user_handled(struct pt_regs *regs, ...@@ -2211,6 +2216,7 @@ bool sun4v_nonresum_error_user_handled(struct pt_regs *regs,
addr += PAGE_SIZE; addr += PAGE_SIZE;
} }
} }
clear_siginfo(&info);
info.si_signo = SIGKILL; info.si_signo = SIGKILL;
info.si_errno = 0; info.si_errno = 0;
info.si_trapno = 0; info.si_trapno = 0;
...@@ -2221,6 +2227,7 @@ bool sun4v_nonresum_error_user_handled(struct pt_regs *regs, ...@@ -2221,6 +2227,7 @@ bool sun4v_nonresum_error_user_handled(struct pt_regs *regs,
if (attrs & SUN4V_ERR_ATTRS_PIO) { if (attrs & SUN4V_ERR_ATTRS_PIO) {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_code = BUS_ADRERR; info.si_code = BUS_ADRERR;
info.si_addr = (void __user *)sun4v_get_vaddr(regs); info.si_addr = (void __user *)sun4v_get_vaddr(regs);
...@@ -2368,6 +2375,7 @@ static void do_fpe_common(struct pt_regs *regs) ...@@ -2368,6 +2375,7 @@ static void do_fpe_common(struct pt_regs *regs)
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_addr = (void __user *)regs->tpc; info.si_addr = (void __user *)regs->tpc;
...@@ -2440,6 +2448,7 @@ void do_tof(struct pt_regs *regs) ...@@ -2440,6 +2448,7 @@ void do_tof(struct pt_regs *regs)
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGEMT; info.si_signo = SIGEMT;
info.si_errno = 0; info.si_errno = 0;
info.si_code = EMT_TAGOVF; info.si_code = EMT_TAGOVF;
...@@ -2465,6 +2474,7 @@ void do_div0(struct pt_regs *regs) ...@@ -2465,6 +2474,7 @@ void do_div0(struct pt_regs *regs)
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_code = FPE_INTDIV; info.si_code = FPE_INTDIV;
...@@ -2666,6 +2676,7 @@ void do_illegal_instruction(struct pt_regs *regs) ...@@ -2666,6 +2676,7 @@ void do_illegal_instruction(struct pt_regs *regs)
} }
} }
} }
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_ILLOPC; info.si_code = ILL_ILLOPC;
...@@ -2692,6 +2703,7 @@ void mem_address_unaligned(struct pt_regs *regs, unsigned long sfar, unsigned lo ...@@ -2692,6 +2703,7 @@ void mem_address_unaligned(struct pt_regs *regs, unsigned long sfar, unsigned lo
if (is_no_fault_exception(regs)) if (is_no_fault_exception(regs))
return; return;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
...@@ -2717,6 +2729,7 @@ void sun4v_do_mna(struct pt_regs *regs, unsigned long addr, unsigned long type_c ...@@ -2717,6 +2729,7 @@ void sun4v_do_mna(struct pt_regs *regs, unsigned long addr, unsigned long type_c
if (is_no_fault_exception(regs)) if (is_no_fault_exception(regs))
return; return;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
...@@ -2785,6 +2798,7 @@ void do_privop(struct pt_regs *regs) ...@@ -2785,6 +2798,7 @@ void do_privop(struct pt_regs *regs)
regs->tpc &= 0xffffffff; regs->tpc &= 0xffffffff;
regs->tnpc &= 0xffffffff; regs->tnpc &= 0xffffffff;
} }
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_PRVOPC; info.si_code = ILL_PRVOPC;
......
...@@ -313,6 +313,7 @@ static void user_mna_trap_fault(struct pt_regs *regs, unsigned int insn) ...@@ -313,6 +313,7 @@ static void user_mna_trap_fault(struct pt_regs *regs, unsigned int insn)
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
......
...@@ -129,6 +129,7 @@ static void __do_fault_siginfo(int code, int sig, struct pt_regs *regs, ...@@ -129,6 +129,7 @@ static void __do_fault_siginfo(int code, int sig, struct pt_regs *regs,
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = sig; info.si_signo = sig;
info.si_code = code; info.si_code = code;
info.si_errno = 0; info.si_errno = 0;
......
...@@ -172,6 +172,7 @@ static void do_fault_siginfo(int code, int sig, struct pt_regs *regs, ...@@ -172,6 +172,7 @@ static void do_fault_siginfo(int code, int sig, struct pt_regs *regs,
unsigned long addr; unsigned long addr;
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_code = code; info.si_code = code;
info.si_signo = sig; info.si_signo = sig;
info.si_errno = 0; info.si_errno = 0;
......
...@@ -164,6 +164,7 @@ static void bad_segv(struct faultinfo fi, unsigned long ip) ...@@ -164,6 +164,7 @@ static void bad_segv(struct faultinfo fi, unsigned long ip)
{ {
struct siginfo si; struct siginfo si;
clear_siginfo(&si);
si.si_signo = SIGSEGV; si.si_signo = SIGSEGV;
si.si_code = SEGV_ACCERR; si.si_code = SEGV_ACCERR;
si.si_addr = (void __user *) FAULT_ADDRESS(fi); si.si_addr = (void __user *) FAULT_ADDRESS(fi);
...@@ -220,6 +221,7 @@ unsigned long segv(struct faultinfo fi, unsigned long ip, int is_user, ...@@ -220,6 +221,7 @@ unsigned long segv(struct faultinfo fi, unsigned long ip, int is_user,
int is_write = FAULT_WRITE(fi); int is_write = FAULT_WRITE(fi);
unsigned long address = FAULT_ADDRESS(fi); unsigned long address = FAULT_ADDRESS(fi);
clear_siginfo(&si);
if (!is_user && regs) if (!is_user && regs)
current->thread.segv_regs = container_of(regs, struct pt_regs, regs); current->thread.segv_regs = container_of(regs, struct pt_regs, regs);
......
...@@ -56,7 +56,7 @@ void ucf64_raise_sigfpe(unsigned int sicode, struct pt_regs *regs) ...@@ -56,7 +56,7 @@ void ucf64_raise_sigfpe(unsigned int sicode, struct pt_regs *regs)
{ {
siginfo_t info; siginfo_t info;
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_code = sicode; info.si_code = sicode;
......
...@@ -125,6 +125,7 @@ static void __do_user_fault(struct task_struct *tsk, unsigned long addr, ...@@ -125,6 +125,7 @@ static void __do_user_fault(struct task_struct *tsk, unsigned long addr,
tsk->thread.address = addr; tsk->thread.address = addr;
tsk->thread.error_code = fsr; tsk->thread.error_code = fsr;
tsk->thread.trap_no = 14; tsk->thread.trap_no = 14;
clear_siginfo(&si);
si.si_signo = sig; si.si_signo = sig;
si.si_errno = 0; si.si_errno = 0;
si.si_code = code; si.si_code = code;
...@@ -472,6 +473,7 @@ asmlinkage void do_DataAbort(unsigned long addr, unsigned int fsr, ...@@ -472,6 +473,7 @@ asmlinkage void do_DataAbort(unsigned long addr, unsigned int fsr,
printk(KERN_ALERT "Unhandled fault: %s (0x%03x) at 0x%08lx\n", printk(KERN_ALERT "Unhandled fault: %s (0x%03x) at 0x%08lx\n",
inf->name, fsr, addr); inf->name, fsr, addr);
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
...@@ -491,6 +493,7 @@ asmlinkage void do_PrefetchAbort(unsigned long addr, ...@@ -491,6 +493,7 @@ asmlinkage void do_PrefetchAbort(unsigned long addr,
printk(KERN_ALERT "Unhandled prefetch abort: %s (0x%03x) at 0x%08lx\n", printk(KERN_ALERT "Unhandled prefetch abort: %s (0x%03x) at 0x%08lx\n",
inf->name, ifsr, addr); inf->name, ifsr, addr);
clear_siginfo(&info);
info.si_signo = inf->sig; info.si_signo = inf->sig;
info.si_errno = 0; info.si_errno = 0;
info.si_code = inf->code; info.si_code = inf->code;
......
...@@ -107,7 +107,7 @@ static bool write_ok_or_segv(unsigned long ptr, size_t size) ...@@ -107,7 +107,7 @@ static bool write_ok_or_segv(unsigned long ptr, size_t size)
thread->cr2 = ptr; thread->cr2 = ptr;
thread->trap_nr = X86_TRAP_PF; thread->trap_nr = X86_TRAP_PF;
memset(&info, 0, sizeof(info)); clear_siginfo(&info);
info.si_signo = SIGSEGV; info.si_signo = SIGSEGV;
info.si_errno = 0; info.si_errno = 0;
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
......
...@@ -1377,7 +1377,6 @@ static void fill_sigtrap_info(struct task_struct *tsk, ...@@ -1377,7 +1377,6 @@ static void fill_sigtrap_info(struct task_struct *tsk,
tsk->thread.trap_nr = X86_TRAP_DB; tsk->thread.trap_nr = X86_TRAP_DB;
tsk->thread.error_code = error_code; tsk->thread.error_code = error_code;
memset(info, 0, sizeof(*info));
info->si_signo = SIGTRAP; info->si_signo = SIGTRAP;
info->si_code = si_code; info->si_code = si_code;
info->si_addr = user_mode(regs) ? (void __user *)regs->ip : NULL; info->si_addr = user_mode(regs) ? (void __user *)regs->ip : NULL;
...@@ -1395,6 +1394,7 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, ...@@ -1395,6 +1394,7 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs,
{ {
struct siginfo info; struct siginfo info;
clear_siginfo(&info);
fill_sigtrap_info(tsk, regs, error_code, si_code, &info); fill_sigtrap_info(tsk, regs, error_code, si_code, &info);
/* Send us the fake SIGTRAP */ /* Send us the fake SIGTRAP */
force_sig_info(SIGTRAP, &info, tsk); force_sig_info(SIGTRAP, &info, tsk);
......
...@@ -299,6 +299,7 @@ static void do_error_trap(struct pt_regs *regs, long error_code, char *str, ...@@ -299,6 +299,7 @@ static void do_error_trap(struct pt_regs *regs, long error_code, char *str,
if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) != if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) !=
NOTIFY_STOP) { NOTIFY_STOP) {
cond_local_irq_enable(regs); cond_local_irq_enable(regs);
clear_siginfo(&info);
do_trap(trapnr, signr, str, regs, error_code, do_trap(trapnr, signr, str, regs, error_code,
fill_trap_info(regs, signr, trapnr, &info)); fill_trap_info(regs, signr, trapnr, &info));
} }
...@@ -854,6 +855,7 @@ static void math_error(struct pt_regs *regs, int error_code, int trapnr) ...@@ -854,6 +855,7 @@ static void math_error(struct pt_regs *regs, int error_code, int trapnr)
task->thread.trap_nr = trapnr; task->thread.trap_nr = trapnr;
task->thread.error_code = error_code; task->thread.error_code = error_code;
clear_siginfo(&info);
info.si_signo = SIGFPE; info.si_signo = SIGFPE;
info.si_errno = 0; info.si_errno = 0;
info.si_addr = (void __user *)uprobe_get_trap_addr(regs); info.si_addr = (void __user *)uprobe_get_trap_addr(regs);
...@@ -929,6 +931,7 @@ dotraplinkage void do_iret_error(struct pt_regs *regs, long error_code) ...@@ -929,6 +931,7 @@ dotraplinkage void do_iret_error(struct pt_regs *regs, long error_code)
RCU_LOCKDEP_WARN(!rcu_is_watching(), "entry code didn't wake RCU"); RCU_LOCKDEP_WARN(!rcu_is_watching(), "entry code didn't wake RCU");
local_irq_enable(); local_irq_enable();
clear_siginfo(&info);
info.si_signo = SIGILL; info.si_signo = SIGILL;
info.si_errno = 0; info.si_errno = 0;
info.si_code = ILL_BADSTK; info.si_code = ILL_BADSTK;
......
...@@ -278,6 +278,7 @@ static void force_sig_info_umip_fault(void __user *addr, struct pt_regs *regs) ...@@ -278,6 +278,7 @@ static void force_sig_info_umip_fault(void __user *addr, struct pt_regs *regs)
tsk->thread.error_code = X86_PF_USER | X86_PF_WRITE; tsk->thread.error_code = X86_PF_USER | X86_PF_WRITE;
tsk->thread.trap_nr = X86_TRAP_PF; tsk->thread.trap_nr = X86_TRAP_PF;
clear_siginfo(&info);
info.si_signo = SIGSEGV; info.si_signo = SIGSEGV;
info.si_errno = 0; info.si_errno = 0;
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
......
...@@ -3007,6 +3007,7 @@ static void kvm_send_hwpoison_signal(unsigned long address, struct task_struct * ...@@ -3007,6 +3007,7 @@ static void kvm_send_hwpoison_signal(unsigned long address, struct task_struct *
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_MCEERR_AR; info.si_code = BUS_MCEERR_AR;
......
...@@ -209,6 +209,7 @@ force_sig_info_fault(int si_signo, int si_code, unsigned long address, ...@@ -209,6 +209,7 @@ force_sig_info_fault(int si_signo, int si_code, unsigned long address,
unsigned lsb = 0; unsigned lsb = 0;
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = si_signo; info.si_signo = si_signo;
info.si_errno = 0; info.si_errno = 0;
info.si_code = si_code; info.si_code = si_code;
......
...@@ -334,6 +334,7 @@ do_unaligned_user (struct pt_regs *regs) ...@@ -334,6 +334,7 @@ do_unaligned_user (struct pt_regs *regs)
"(pid = %d, pc = %#010lx)\n", "(pid = %d, pc = %#010lx)\n",
regs->excvaddr, current->comm, regs->excvaddr, current->comm,
task_pid_nr(current), regs->pc); task_pid_nr(current), regs->pc);
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_ADRALN; info.si_code = BUS_ADRALN;
......
...@@ -45,6 +45,7 @@ void do_page_fault(struct pt_regs *regs) ...@@ -45,6 +45,7 @@ void do_page_fault(struct pt_regs *regs)
int fault; int fault;
unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE; unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;
clear_siginfo(&info);
info.si_code = SEGV_MAPERR; info.si_code = SEGV_MAPERR;
/* We fault-in kernel-space virtual memory on-demand. The /* We fault-in kernel-space virtual memory on-demand. The
......
...@@ -345,7 +345,6 @@ extern void user_single_step_siginfo(struct task_struct *tsk, ...@@ -345,7 +345,6 @@ extern void user_single_step_siginfo(struct task_struct *tsk,
static inline void user_single_step_siginfo(struct task_struct *tsk, static inline void user_single_step_siginfo(struct task_struct *tsk,
struct pt_regs *regs, siginfo_t *info) struct pt_regs *regs, siginfo_t *info)
{ {
memset(info, 0, sizeof(*info));
info->si_signo = SIGTRAP; info->si_signo = SIGTRAP;
} }
#endif #endif
......
...@@ -124,6 +124,7 @@ static inline void tracehook_report_syscall_exit(struct pt_regs *regs, int step) ...@@ -124,6 +124,7 @@ static inline void tracehook_report_syscall_exit(struct pt_regs *regs, int step)
{ {
if (step) { if (step) {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
user_single_step_siginfo(current, regs, &info); user_single_step_siginfo(current, regs, &info);
force_sig_info(SIGTRAP, &info, current); force_sig_info(SIGTRAP, &info, current);
return; return;
......
...@@ -1401,6 +1401,7 @@ static void kvm_send_hwpoison_signal(unsigned long address, ...@@ -1401,6 +1401,7 @@ static void kvm_send_hwpoison_signal(unsigned long address,
{ {
siginfo_t info; siginfo_t info;
clear_siginfo(&info);
info.si_signo = SIGBUS; info.si_signo = SIGBUS;
info.si_errno = 0; info.si_errno = 0;
info.si_code = BUS_MCEERR_AR; info.si_code = BUS_MCEERR_AR;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册