* [PATCH] ARM: remove redundant irq disable at halt and restart
@ 2014-10-24 19:06 Johan Hovold
2014-10-24 19:16 ` Felipe Balbi
2014-11-26 15:13 ` Johan Hovold
0 siblings, 2 replies; 8+ messages in thread
From: Johan Hovold @ 2014-10-24 19:06 UTC (permalink / raw)
To: linux-arm-kernel
Remove redundant local_irq_disable() at machine halt and restart.
Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with
smp_send_stop()") interrupts are disabled before stopping secondary
CPUs.
Signed-off-by: Johan Hovold <johan@kernel.org>
---
arch/arm/kernel/process.c | 2 --
1 file changed, 2 deletions(-)
diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c
index a35f6ebbd2c2..5663ab57cf07 100644
--- a/arch/arm/kernel/process.c
+++ b/arch/arm/kernel/process.c
@@ -195,7 +195,6 @@ void machine_halt(void)
local_irq_disable();
smp_send_stop();
- local_irq_disable();
while (1);
}
@@ -237,7 +236,6 @@ void machine_restart(char *cmd)
/* Whoops - the platform was unable to reboot. Tell the user! */
printk("Reboot failed -- System halted\n");
- local_irq_disable();
while (1);
}
--
2.0.4
^ permalink raw reply related [flat|nested] 8+ messages in thread* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:06 [PATCH] ARM: remove redundant irq disable at halt and restart Johan Hovold @ 2014-10-24 19:16 ` Felipe Balbi 2014-10-24 19:21 ` Felipe Balbi 2014-11-26 15:13 ` Johan Hovold 1 sibling, 1 reply; 8+ messages in thread From: Felipe Balbi @ 2014-10-24 19:16 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > Remove redundant local_irq_disable() at machine halt and restart. > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > smp_send_stop()") interrupts are disabled before stopping secondary > CPUs. Assuming this is correct, you should have: Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) Cc: <stable@vger.kernel.org> # v3.12+ > Signed-off-by: Johan Hovold <johan@kernel.org> > --- > arch/arm/kernel/process.c | 2 -- > 1 file changed, 2 deletions(-) > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > index a35f6ebbd2c2..5663ab57cf07 100644 > --- a/arch/arm/kernel/process.c > +++ b/arch/arm/kernel/process.c > @@ -195,7 +195,6 @@ void machine_halt(void) > local_irq_disable(); > smp_send_stop(); > > - local_irq_disable(); > while (1); > } > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > /* Whoops - the platform was unable to reboot. Tell the user! */ > printk("Reboot failed -- System halted\n"); > - local_irq_disable(); ... but wouldn't this reintroduce the the buck which that commit fixed ? -- balbi -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 819 bytes Desc: Digital signature URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20141024/2526e9cd/attachment.sig> ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:16 ` Felipe Balbi @ 2014-10-24 19:21 ` Felipe Balbi 2014-10-24 19:28 ` Johan Hovold 0 siblings, 1 reply; 8+ messages in thread From: Felipe Balbi @ 2014-10-24 19:21 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 02:16:27PM -0500, Felipe Balbi wrote: > On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > > Remove redundant local_irq_disable() at machine halt and restart. > > > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > > smp_send_stop()") interrupts are disabled before stopping secondary > > CPUs. > > Assuming this is correct, you should have: > > Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) > Cc: <stable@vger.kernel.org> # v3.12+ > > > Signed-off-by: Johan Hovold <johan@kernel.org> > > --- > > arch/arm/kernel/process.c | 2 -- > > 1 file changed, 2 deletions(-) > > > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > > index a35f6ebbd2c2..5663ab57cf07 100644 > > --- a/arch/arm/kernel/process.c > > +++ b/arch/arm/kernel/process.c > > @@ -195,7 +195,6 @@ void machine_halt(void) > > local_irq_disable(); > > smp_send_stop(); > > > > - local_irq_disable(); > > while (1); > > } > > > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > > > /* Whoops - the platform was unable to reboot. Tell the user! */ > > printk("Reboot failed -- System halted\n"); > > - local_irq_disable(); > > ... but wouldn't this reintroduce the the buck which that commit fixed ? s/buck/bug :-) my fingers have a mind of their own, aparently. -- balbi -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 819 bytes Desc: Digital signature URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20141024/fce47236/attachment.sig> ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:21 ` Felipe Balbi @ 2014-10-24 19:28 ` Johan Hovold 2014-10-24 19:42 ` Felipe Balbi 0 siblings, 1 reply; 8+ messages in thread From: Johan Hovold @ 2014-10-24 19:28 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 02:21:11PM -0500, Felipe Balbi wrote: > On Fri, Oct 24, 2014 at 02:16:27PM -0500, Felipe Balbi wrote: > > On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > > > Remove redundant local_irq_disable() at machine halt and restart. > > > > > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > > > smp_send_stop()") interrupts are disabled before stopping secondary > > > CPUs. > > > > Assuming this is correct, you should have: > > > > Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) > > Cc: <stable@vger.kernel.org> # v3.12+ It's not a bug. Just a redundant disabling of already disabled interrupts, something which could possibly lead someone to believe that interrupts could be re-enabled by the power-off handler. And if that was the case, wouldn't that introduce the bug that 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with smp_send_stop()") was trying to fix? > > > Signed-off-by: Johan Hovold <johan@kernel.org> > > > --- > > > arch/arm/kernel/process.c | 2 -- > > > 1 file changed, 2 deletions(-) > > > > > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > > > index a35f6ebbd2c2..5663ab57cf07 100644 > > > --- a/arch/arm/kernel/process.c > > > +++ b/arch/arm/kernel/process.c > > > @@ -195,7 +195,6 @@ void machine_halt(void) > > > local_irq_disable(); > > > smp_send_stop(); > > > > > > - local_irq_disable(); > > > while (1); > > > } > > > > > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > > > > > /* Whoops - the platform was unable to reboot. Tell the user! */ > > > printk("Reboot failed -- System halted\n"); > > > - local_irq_disable(); > > > > ... but wouldn't this reintroduce the the buck which that commit fixed ? > > s/buck/bug :-) my fingers have a mind of their own, aparently. :) No, the interrupts would still be disabled. Thanks, Johan ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:28 ` Johan Hovold @ 2014-10-24 19:42 ` Felipe Balbi 2014-10-24 19:50 ` Johan Hovold 0 siblings, 1 reply; 8+ messages in thread From: Felipe Balbi @ 2014-10-24 19:42 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 09:28:45PM +0200, Johan Hovold wrote: > On Fri, Oct 24, 2014 at 02:21:11PM -0500, Felipe Balbi wrote: > > On Fri, Oct 24, 2014 at 02:16:27PM -0500, Felipe Balbi wrote: > > > On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > > > > Remove redundant local_irq_disable() at machine halt and restart. > > > > > > > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > > > > smp_send_stop()") interrupts are disabled before stopping secondary > > > > CPUs. > > > > > > Assuming this is correct, you should have: > > > > > > Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) > > > Cc: <stable@vger.kernel.org> # v3.12+ > > It's not a bug. Just a redundant disabling of already disabled > interrupts, something which could possibly lead someone to believe that > interrupts could be re-enabled by the power-off handler. I didn't dig any of this out but I'll assume you did :-) So I withdraw my comment ;-) > > > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > > > > index a35f6ebbd2c2..5663ab57cf07 100644 > > > > --- a/arch/arm/kernel/process.c > > > > +++ b/arch/arm/kernel/process.c > > > > @@ -195,7 +195,6 @@ void machine_halt(void) > > > > local_irq_disable(); > > > > smp_send_stop(); > > > > > > > > - local_irq_disable(); > > > > while (1); > > > > } > > > > > > > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > > > > > > > /* Whoops - the platform was unable to reboot. Tell the user! */ > > > > printk("Reboot failed -- System halted\n"); > > > > - local_irq_disable(); > > > > > > ... but wouldn't this reintroduce the the buck which that commit fixed ? > > > > s/buck/bug :-) my fingers have a mind of their own, aparently. > > :) > > No, the interrupts would still be disabled. alright... so far I couldn't find where IRQs are disable before machine_power_off() is called. Starting a do_poweroff(), couldn't find it... Oh well, I'll keep digging. cheers -- balbi -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 819 bytes Desc: Digital signature URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20141024/6c01e9a1/attachment-0001.sig> ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:42 ` Felipe Balbi @ 2014-10-24 19:50 ` Johan Hovold 2014-10-24 20:07 ` Felipe Balbi 0 siblings, 1 reply; 8+ messages in thread From: Johan Hovold @ 2014-10-24 19:50 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 02:42:50PM -0500, Felipe Balbi wrote: > On Fri, Oct 24, 2014 at 09:28:45PM +0200, Johan Hovold wrote: > > On Fri, Oct 24, 2014 at 02:21:11PM -0500, Felipe Balbi wrote: > > > On Fri, Oct 24, 2014 at 02:16:27PM -0500, Felipe Balbi wrote: > > > > On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > > > > > Remove redundant local_irq_disable() at machine halt and restart. > > > > > > > > > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > > > > > smp_send_stop()") interrupts are disabled before stopping secondary > > > > > CPUs. > > > > > > > > Assuming this is correct, you should have: > > > > > > > > Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) > > > > Cc: <stable@vger.kernel.org> # v3.12+ > > > > It's not a bug. Just a redundant disabling of already disabled > > interrupts, something which could possibly lead someone to believe that > > interrupts could be re-enabled by the power-off handler. I meant re-enabled by arm_pm_restart(). > I didn't dig any of this out but I'll assume you did :-) So I withdraw > my comment ;-) > > > > > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > > > > > index a35f6ebbd2c2..5663ab57cf07 100644 > > > > > --- a/arch/arm/kernel/process.c > > > > > +++ b/arch/arm/kernel/process.c > > > > > @@ -195,7 +195,6 @@ void machine_halt(void) > > > > > local_irq_disable(); > > > > > smp_send_stop(); > > > > > > > > > > - local_irq_disable(); > > > > > while (1); > > > > > } > > > > > > > > > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > > > > > > > > > /* Whoops - the platform was unable to reboot. Tell the user! */ > > > > > printk("Reboot failed -- System halted\n"); > > > > > - local_irq_disable(); > > > > > > > > ... but wouldn't this reintroduce the the buck which that commit fixed ? > > > > > > s/buck/bug :-) my fingers have a mind of their own, aparently. > > > > :) > > > > No, the interrupts would still be disabled. > > alright... so far I couldn't find where IRQs are disable before > machine_power_off() is called. Starting a do_poweroff(), couldn't find > it... Oh well, I'll keep digging. It's done a few lines above in the same function. ;) void machine_restart(char *cmd) { local_irq_disable(); ^^^ smp_send_stop(); arm_pm_restart(reboot_mode, cmd); /* Give a grace period for failure to restart of 1s */ mdelay(1000); /* Whoops - the platform was unable to reboot. Tell the user! */ printk("Reboot failed -- System halted\n"); local_irq_disable(); while (1); } [ and similarly in machine_power_off(). ] Johan ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:50 ` Johan Hovold @ 2014-10-24 20:07 ` Felipe Balbi 0 siblings, 0 replies; 8+ messages in thread From: Felipe Balbi @ 2014-10-24 20:07 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 09:50:29PM +0200, Johan Hovold wrote: > On Fri, Oct 24, 2014 at 02:42:50PM -0500, Felipe Balbi wrote: > > On Fri, Oct 24, 2014 at 09:28:45PM +0200, Johan Hovold wrote: > > > On Fri, Oct 24, 2014 at 02:21:11PM -0500, Felipe Balbi wrote: > > > > On Fri, Oct 24, 2014 at 02:16:27PM -0500, Felipe Balbi wrote: > > > > > On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > > > > > > Remove redundant local_irq_disable() at machine halt and restart. > > > > > > > > > > > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > > > > > > smp_send_stop()") interrupts are disabled before stopping secondary > > > > > > CPUs. > > > > > > > > > > Assuming this is correct, you should have: > > > > > > > > > > Fixes: 44424c3 (ARM: 7803/1: Fix deadlock scenario with smp_send_stop()) > > > > > Cc: <stable@vger.kernel.org> # v3.12+ > > > > > > It's not a bug. Just a redundant disabling of already disabled > > > interrupts, something which could possibly lead someone to believe that > > > interrupts could be re-enabled by the power-off handler. > > I meant re-enabled by arm_pm_restart(). > > > I didn't dig any of this out but I'll assume you did :-) So I withdraw > > my comment ;-) > > > > > > > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > > > > > > index a35f6ebbd2c2..5663ab57cf07 100644 > > > > > > --- a/arch/arm/kernel/process.c > > > > > > +++ b/arch/arm/kernel/process.c > > > > > > @@ -195,7 +195,6 @@ void machine_halt(void) > > > > > > local_irq_disable(); > > > > > > smp_send_stop(); > > > > > > > > > > > > - local_irq_disable(); > > > > > > while (1); > > > > > > } > > > > > > > > > > > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > > > > > > > > > > > /* Whoops - the platform was unable to reboot. Tell the user! */ > > > > > > printk("Reboot failed -- System halted\n"); > > > > > > - local_irq_disable(); > > > > > > > > > > ... but wouldn't this reintroduce the the buck which that commit fixed ? > > > > > > > > s/buck/bug :-) my fingers have a mind of their own, aparently. > > > > > > :) > > > > > > No, the interrupts would still be disabled. > > > > alright... so far I couldn't find where IRQs are disable before > > machine_power_off() is called. Starting a do_poweroff(), couldn't find > > it... Oh well, I'll keep digging. > > It's done a few lines above in the same function. ;) > > void machine_restart(char *cmd) > { > local_irq_disable(); > ^^^ > smp_send_stop(); > > arm_pm_restart(reboot_mode, cmd); > > /* Give a grace period for failure to restart of 1s */ > mdelay(1000); > > /* Whoops - the platform was unable to reboot. Tell the user! */ > printk("Reboot failed -- System halted\n"); > local_irq_disable(); > while (1); > } > > [ and similarly in machine_power_off(). ] oh, now I get it :-) Nevermind, I completely missed that it was duplicated. My bad. Reviewed-by: Felipe Balbi <balbi@ti.com> -- balbi -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 819 bytes Desc: Digital signature URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20141024/2fe28c40/attachment-0001.sig> ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] ARM: remove redundant irq disable at halt and restart 2014-10-24 19:06 [PATCH] ARM: remove redundant irq disable at halt and restart Johan Hovold 2014-10-24 19:16 ` Felipe Balbi @ 2014-11-26 15:13 ` Johan Hovold 1 sibling, 0 replies; 8+ messages in thread From: Johan Hovold @ 2014-11-26 15:13 UTC (permalink / raw) To: linux-arm-kernel On Fri, Oct 24, 2014 at 09:06:32PM +0200, Johan Hovold wrote: > Remove redundant local_irq_disable() at machine halt and restart. > > Since commit 44424c34049f ("ARM: 7803/1: Fix deadlock scenario with > smp_send_stop()") interrupts are disabled before stopping secondary > CPUs. > > Signed-off-by: Johan Hovold <johan@kernel.org> Russell, have you had a chance to look at this clean up? Thanks, Johan > --- > arch/arm/kernel/process.c | 2 -- > 1 file changed, 2 deletions(-) > > diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c > index a35f6ebbd2c2..5663ab57cf07 100644 > --- a/arch/arm/kernel/process.c > +++ b/arch/arm/kernel/process.c > @@ -195,7 +195,6 @@ void machine_halt(void) > local_irq_disable(); > smp_send_stop(); > > - local_irq_disable(); > while (1); > } > > @@ -237,7 +236,6 @@ void machine_restart(char *cmd) > > /* Whoops - the platform was unable to reboot. Tell the user! */ > printk("Reboot failed -- System halted\n"); > - local_irq_disable(); > while (1); > } ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2014-11-26 15:13 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-10-24 19:06 [PATCH] ARM: remove redundant irq disable at halt and restart Johan Hovold 2014-10-24 19:16 ` Felipe Balbi 2014-10-24 19:21 ` Felipe Balbi 2014-10-24 19:28 ` Johan Hovold 2014-10-24 19:42 ` Felipe Balbi 2014-10-24 19:50 ` Johan Hovold 2014-10-24 20:07 ` Felipe Balbi 2014-11-26 15:13 ` Johan Hovold
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).