public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [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(&current->sighand->siglock);
-		handler = current->sighand->action[signr-1].sa.sa_handler;
-		spin_unlock_irq(&current->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(&current->sighand->siglock);
> -		handler = current->sighand->action[signr-1].sa.sa_handler;
> -		spin_unlock_irq(&current->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