* [PATCH] avr32: init cannot ignore signals sent by force_sig_info()
@ 2011-04-04 14:58 Matt Fleming
2011-04-04 16:04 ` Oleg Nesterov
2011-04-13 13:14 ` Hans-Christian Egtvedt
0 siblings, 2 replies; 3+ messages in thread
From: Matt Fleming @ 2011-04-04 14:58 UTC (permalink / raw)
To: Hans-Christian Egtvedt; +Cc: linux-kernel, Oleg Nesterov, Matt Fleming
From: Matt Fleming <matt.fleming@linux.intel.com>
We can delete the code that checks to see if we're sending an ignored
signal to init because force_sig_info() already handles this case.
force_sig_info() will kill init even if the signal handler is SIG_DFL
and the scenario described in the comment where init might "generate
the same exception over and over again" cannot occur (force_sig_info()
clears SIGNAL_UNKILLABLE to ensure that init will die).
Also, the use of is_global_init() is not correct in the multhreaded
case, as Oleg Nesterov explains,
"is_global_init() is not right in theory, /sbin/init can be
multithreaded. And, this doesn't cover the sub-namespace
inits... I'd suggest to check SIGNAL_UNKILLABLE, but looking
closer I think you can simply remove this code."
It seems this code was copied from arch/powerpc in March 2007 in commit
623b0355d5b1 "[AVR32] Clean up exception handling code"
but the code was deleted from arch/powerpc in November 2009 in commit
a0592d42fe3e "powerpc: kill the obsolete code under is_global_init()"
So catch up with powerpc and delete the bogus code.
Signed-off-by: Matt Fleming <matt.fleming@linux.intel.com>
---
arch/avr32/kernel/traps.c | 22 ----------------------
1 files changed, 0 insertions(+), 22 deletions(-)
diff --git a/arch/avr32/kernel/traps.c b/arch/avr32/kernel/traps.c
index b91b204..7aa2575 100644
--- a/arch/avr32/kernel/traps.c
+++ b/arch/avr32/kernel/traps.c
@@ -95,28 +95,6 @@ void _exception(long signr, struct pt_regs *regs, int code,
info.si_code = code;
info.si_addr = (void __user *)addr;
force_sig_info(signr, &info, current);
-
- /*
- * Init gets no signals that it doesn't have a handler for.
- * That's all very well, but if it has caused a synchronous
- * exception and we ignore the resulting signal, it will just
- * generate the same exception over and over again and we get
- * nowhere. Better to kill it and let the kernel panic.
- */
- if (is_global_init(current)) {
- __sighandler_t handler;
-
- spin_lock_irq(¤t->sighand->siglock);
- handler = current->sighand->action[signr-1].sa.sa_handler;
- spin_unlock_irq(¤t->sighand->siglock);
- if (handler == SIG_DFL) {
- /* init has generated a synchronous exception
- and it doesn't have a handler for the signal */
- printk(KERN_CRIT "init has generated signal %ld "
- "but has no handler for it\n", signr);
- do_exit(signr);
- }
- }
}
asmlinkage void do_nmi(unsigned long ecr, struct pt_regs *regs)
--
1.7.4
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] avr32: init cannot ignore signals sent by force_sig_info()
2011-04-04 14:58 [PATCH] avr32: init cannot ignore signals sent by force_sig_info() Matt Fleming
@ 2011-04-04 16:04 ` Oleg Nesterov
2011-04-13 13:14 ` Hans-Christian Egtvedt
1 sibling, 0 replies; 3+ messages in thread
From: Oleg Nesterov @ 2011-04-04 16:04 UTC (permalink / raw)
To: Matt Fleming; +Cc: Hans-Christian Egtvedt, linux-kernel, Matt Fleming
On 04/04, Matt Fleming wrote:
>
> --- a/arch/avr32/kernel/traps.c
> +++ b/arch/avr32/kernel/traps.c
> @@ -95,28 +95,6 @@ void _exception(long signr, struct pt_regs *regs, int code,
> info.si_code = code;
> info.si_addr = (void __user *)addr;
> force_sig_info(signr, &info, current);
> -
> - /*
> - * Init gets no signals that it doesn't have a handler for.
> - * That's all very well, but if it has caused a synchronous
> - * exception and we ignore the resulting signal, it will just
> - * generate the same exception over and over again and we get
> - * nowhere. Better to kill it and let the kernel panic.
> - */
> - if (is_global_init(current)) {
> - __sighandler_t handler;
> -
> - spin_lock_irq(¤t->sighand->siglock);
> - handler = current->sighand->action[signr-1].sa.sa_handler;
> - spin_unlock_irq(¤t->sighand->siglock);
> - if (handler == SIG_DFL) {
> - /* init has generated a synchronous exception
> - and it doesn't have a handler for the signal */
> - printk(KERN_CRIT "init has generated signal %ld "
> - "but has no handler for it\n", signr);
> - do_exit(signr);
> - }
> - }
Reviewed-by: Oleg Nesterov <oleg@redhat.com>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] avr32: init cannot ignore signals sent by force_sig_info()
2011-04-04 14:58 [PATCH] avr32: init cannot ignore signals sent by force_sig_info() Matt Fleming
2011-04-04 16:04 ` Oleg Nesterov
@ 2011-04-13 13:14 ` Hans-Christian Egtvedt
1 sibling, 0 replies; 3+ messages in thread
From: Hans-Christian Egtvedt @ 2011-04-13 13:14 UTC (permalink / raw)
To: Matt Fleming; +Cc: linux-kernel, Oleg Nesterov, Matt Fleming
On Mon, 2011-04-04 at 15:58 +0100, Matt Fleming wrote:
> From: Matt Fleming <matt.fleming@linux.intel.com>
>
> We can delete the code that checks to see if we're sending an ignored
> signal to init because force_sig_info() already handles this case.
> force_sig_info() will kill init even if the signal handler is SIG_DFL
> and the scenario described in the comment where init might "generate
> the same exception over and over again" cannot occur (force_sig_info()
> clears SIGNAL_UNKILLABLE to ensure that init will die).
>
> Also, the use of is_global_init() is not correct in the multhreaded
> case, as Oleg Nesterov explains,
>
> "is_global_init() is not right in theory, /sbin/init can be
> multithreaded. And, this doesn't cover the sub-namespace
> inits... I'd suggest to check SIGNAL_UNKILLABLE, but looking
> closer I think you can simply remove this code."
>
> It seems this code was copied from arch/powerpc in March 2007 in commit
>
> 623b0355d5b1 "[AVR32] Clean up exception handling code"
>
> but the code was deleted from arch/powerpc in November 2009 in commit
>
> a0592d42fe3e "powerpc: kill the obsolete code under is_global_init()"
>
> So catch up with powerpc and delete the bogus code.
>
> Signed-off-by: Matt Fleming <matt.fleming@linux.intel.com>
Thanks for this cleanup, added to the AVR32 tree.
Signed-off-by: Hans-Christian Egtvedt <hans-christian.egtvedt@atmel.com>
--
Hans-Christian Egtvedt
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2011-04-13 13:15 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-04-04 14:58 [PATCH] avr32: init cannot ignore signals sent by force_sig_info() Matt Fleming
2011-04-04 16:04 ` Oleg Nesterov
2011-04-13 13:14 ` Hans-Christian Egtvedt
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox