* [PATCH v4 0/3] ARM: rockchip: fix the SMP
@ 2015-06-05 17:05 Caesar Wang
2015-06-05 17:05 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang
` (2 more replies)
0 siblings, 3 replies; 11+ messages in thread
From: Caesar Wang @ 2015-06-05 17:05 UTC (permalink / raw)
To: linux-arm-kernel
Verified on url =
https://chromium.googlesource.com/chromiumos/third_party/kernel/+/chromeos-3.14
Caesar Wang (3):
ARM: rockchip: fix the CPU soft reset
ARM: rockchip: ensure CPU to enter WFI/WFE state
ARM: rockchip: fix the SMP code style
arch/arm/mach-rockchip/platsmp.c | 36 ++++++++++++++++++++++++------------
1 file changed, 24 insertions(+), 12 deletions(-)
--
1.9.1
^ permalink raw reply [flat|nested] 11+ messages in thread* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-05 17:05 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang @ 2015-06-05 17:05 ` Caesar Wang 2015-06-05 20:55 ` Doug Anderson 2015-06-05 17:05 ` [PATCH v4 2/3] ARM: rockchip: ensure CPU to enter WFI/WFE state Caesar Wang 2015-06-05 17:05 ` [PATCH v4 3/3] ARM: rockchip: fix the SMP code style Caesar Wang 2 siblings, 1 reply; 11+ messages in thread From: Caesar Wang @ 2015-06-05 17:05 UTC (permalink / raw) To: linux-arm-kernel We need different orderings when turning a core on and turning a core off. In one case we need to assert reset before turning power off. In ther other case we need to turn power on and the deassert reset. In general, the correct flow is: CPU off: reset_control_assert regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), BIT(pd)) ensure power domain is on CPU on: regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), 0) reset_control_deassert ensure power domain is on This is needed for stressing CPU up/down, as per: cd /sys/devices/system/cpu/ for i in $(seq 1000); do echo "================= $i ============" for j in $(seq 100); do while [[ "$(cat cpu1/online)$(cat cpu2/online)$(cat cpu3/online)" != "000"" ]] echo 0 > cpu1/online echo 0 > cpu2/online echo 0 > cpu3/online done while [[ "$(cat cpu1/online)$(cat cpu2/online)$(cat cpu3/online)" != "111" ]]; do echo 1 > cpu1/online echo 1 > cpu2/online echo 1 > cpu3/online done done done The following is reproducile log: [34466.186812] PM: noirq suspend of devices complete after 0.669 msecs [34466.186824] Disabling non-boot CPUs ... [34466.187509] CPU1: shutdown [34466.188672] CPU2: shutdown [34473.736627] Kernel panic - not syncing:Watchdog detected hard LOCKUP on cpu 0 ....... Signed-off-by: Caesar Wang <wxt@rock-chips.com> Reviewed-by: Doug Anderson <dianders@chromium.org> --- arch/arm/mach-rockchip/platsmp.c | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/arch/arm/mach-rockchip/platsmp.c b/arch/arm/mach-rockchip/platsmp.c index 5b4ca3c..a297b86 100644 --- a/arch/arm/mach-rockchip/platsmp.c +++ b/arch/arm/mach-rockchip/platsmp.c @@ -88,18 +88,26 @@ static int pmu_set_power_domain(int pd, bool on) return PTR_ERR(rstc); } + if (!on) + reset_control_assert(rstc); + + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); + if (ret < 0) { + pr_err("%s: could not update power domain\n", __func__); + reset_control_put(rstc); + return ret; + } + if (on) reset_control_deassert(rstc); - else - reset_control_assert(rstc); reset_control_put(rstc); - } - - ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); - if (ret < 0) { - pr_err("%s: could not update power domain\n", __func__); - return ret; + } else { + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); + if (ret < 0) { + pr_err("%s: could not update power domain\n", __func__); + return ret; + } } ret = -1; -- 1.9.1 ^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-05 17:05 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang @ 2015-06-05 20:55 ` Doug Anderson 2015-06-07 2:51 ` Caesar Wang 0 siblings, 1 reply; 11+ messages in thread From: Doug Anderson @ 2015-06-05 20:55 UTC (permalink / raw) To: linux-arm-kernel Caesar, On Fri, Jun 5, 2015 at 10:05 AM, Caesar Wang <wxt@rock-chips.com> wrote: > + if (!on) > + reset_control_assert(rstc); > + > + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); > + if (ret < 0) { > + pr_err("%s: could not update power domain\n", __func__); > + reset_control_put(rstc); > + return ret; > + } > + > if (on) > reset_control_deassert(rstc); > - else > - reset_control_assert(rstc); As Heiko indicated in the previous patchset, he thought it would be nice to move the 'pmu_power_domain_is_on(pd)' to before you deasserted reset. ...but then I pointed out that you tested that in patch set #2 and it didn't work. Talking to Heiko offline he thought that perhaps you could make 'pmu_power_domain_is_on(pd)' work if you increased your 'udelay(10);' in rockchip_boot_secondary(). Perhaps the old 'pmu_power_domain_is_on' was acting like an extra bit of delay and that's why moving it broke things. I actually went back and tested patch set #2 and it worked for me, so I couldn't test Heiko's theory. Could you go and reproduce the problem with patch set #2 again and then try increasing the udelay() and see if your problems go away? If that works, it might be a slightly better solution. Note that I think Heiko had a slightly cleaner version of your patch set #2 that he posted in response to your patch set #3. -Doug ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-05 20:55 ` Doug Anderson @ 2015-06-07 2:51 ` Caesar Wang 2015-06-07 3:43 ` Doug Anderson 0 siblings, 1 reply; 11+ messages in thread From: Caesar Wang @ 2015-06-07 2:51 UTC (permalink / raw) To: linux-arm-kernel ? 2015?06?06? 04:55, Doug Anderson ??: > Caesar, > > On Fri, Jun 5, 2015 at 10:05 AM, Caesar Wang <wxt@rock-chips.com> wrote: >> + if (!on) >> + reset_control_assert(rstc); >> + >> + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); >> + if (ret < 0) { >> + pr_err("%s: could not update power domain\n", __func__); >> + reset_control_put(rstc); >> + return ret; >> + } >> + >> if (on) >> reset_control_deassert(rstc); >> - else >> - reset_control_assert(rstc); > As Heiko indicated in the previous patchset, he thought it would be > nice to move the 'pmu_power_domain_is_on(pd)' to before you deasserted > reset. ...but then I pointed out that you tested that in patch set #2 > and it didn't work. > > Talking to Heiko offline he thought that perhaps you could make > 'pmu_power_domain_is_on(pd)' work if you increased your 'udelay(10);' > in rockchip_boot_secondary(). Perhaps the old > 'pmu_power_domain_is_on' was acting like an extra bit of delay and > that's why moving it broke things. > > > I actually went back and tested patch set #2 and it worked for me, so > I couldn't test Heiko's theory. Could you go and reproduce the > problem with patch set #2 again and then try increasing the udelay() > and see if your problems go away? If that works, it might be a > slightly better solution. Note that I think Heiko had a slightly > cleaner version of your patch set #2 that he posted in response to > your patch set #3. @@ -150,13 +159,15 @@ static int __cpuinit rockchip_boot_secondary(unsigned int cpu, * sram_base_addr + 4: 0xdeadbeaf * sram_base_addr + 8: start address for pc * */ - udelay(10); + udelay(20); I increased the 'udelay(20)' or 'udelay(50)' in rockchip_boot_secondary(). Set#2 also can repro this issue over 22600 cycles with testing scripts. (about 1 hours) log: ================= 226 ============ [ 4069.134419] CPU1: shutdown [ 4069.164431] CPU2: shutdown [ 4069.204475] CPU3: shutdown ...... [ 4072.454453] CPU1: shutdown [ 4072.504436] CPU2: shutdown [ 4072.554426] CPU3: shutdown [ 4072.577827] CPU1: Booted secondary processor [ 4072.582611] CPU2: Booted secondary processor [ 4072.587426] CPU3: Booted secondary processor <hang> The set #4 will be better work. > > -Doug > > > -- Thanks, - Caesar ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-07 2:51 ` Caesar Wang @ 2015-06-07 3:43 ` Doug Anderson 2015-06-07 5:51 ` Caesar Wang 0 siblings, 1 reply; 11+ messages in thread From: Doug Anderson @ 2015-06-07 3:43 UTC (permalink / raw) To: linux-arm-kernel Caesar, On Sat, Jun 6, 2015 at 7:51 PM, Caesar Wang <wxt@rock-chips.com> wrote: > @@ -150,13 +159,15 @@ static int __cpuinit rockchip_boot_secondary(unsigned > int cpu, > * sram_base_addr + 4: 0xdeadbeaf > * sram_base_addr + 8: start address for pc > * */ > - udelay(10); > + udelay(20); > > I increased the 'udelay(20)' or 'udelay(50)' in rockchip_boot_secondary(). > Set#2 also can repro this issue over 22600 cycles with testing scripts. > (about 1 hours) > > log: > ================= 226 ============ > [ 4069.134419] CPU1: shutdown > [ 4069.164431] CPU2: shutdown > [ 4069.204475] CPU3: shutdown > ...... > [ 4072.454453] CPU1: shutdown > [ 4072.504436] CPU2: shutdown > [ 4072.554426] CPU3: shutdown > [ 4072.577827] CPU1: Booted secondary processor > [ 4072.582611] CPU2: Booted secondary processor > [ 4072.587426] CPU3: Booted secondary processor > <hang> > > The set #4 will be better work. OK, I'm OK with this, but I'd like to get Heiko's opinion. Also: * Just for kicks, does mdelay(1) work? I know that's 100x more than udelay(10), but previously we were actually looping waiting for the power domain, right? ...so maybe the old code used to introduce a pretty big delay. * Does anyone from the chip design team have any idea why patch set #4 works but patch set #2 doesn't? I know it's Sunday morning in China right now, but maybe you could ask Monday? Thanks! -Doug ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-07 3:43 ` Doug Anderson @ 2015-06-07 5:51 ` Caesar Wang 2015-06-07 9:02 ` Heiko Stübner 0 siblings, 1 reply; 11+ messages in thread From: Caesar Wang @ 2015-06-07 5:51 UTC (permalink / raw) To: linux-arm-kernel ? 2015?06?07? 11:43, Doug Anderson ??: > Caesar, > > On Sat, Jun 6, 2015 at 7:51 PM, Caesar Wang <wxt@rock-chips.com> wrote: >> @@ -150,13 +159,15 @@ static int __cpuinit rockchip_boot_secondary(unsigned >> int cpu, >> * sram_base_addr + 4: 0xdeadbeaf >> * sram_base_addr + 8: start address for pc >> * */ >> - udelay(10); >> + udelay(20); >> >> I increased the 'udelay(20)' or 'udelay(50)' in rockchip_boot_secondary(). >> Set#2 also can repro this issue over 22600 cycles with testing scripts. >> (about 1 hours) >> >> log: >> ================= 226 ============ >> [ 4069.134419] CPU1: shutdown >> [ 4069.164431] CPU2: shutdown >> [ 4069.204475] CPU3: shutdown >> ...... >> [ 4072.454453] CPU1: shutdown >> [ 4072.504436] CPU2: shutdown >> [ 4072.554426] CPU3: shutdown >> [ 4072.577827] CPU1: Booted secondary processor >> [ 4072.582611] CPU2: Booted secondary processor >> [ 4072.587426] CPU3: Booted secondary processor >> <hang> >> >> The set #4 will be better work. > OK, I'm OK with this, but I'd like to get Heiko's opinion. > > Also: > * Just for kicks, does mdelay(1) work? I know that's 100x more than OK, it should delay more time. the mdelay(1) can be work over 50000 cycles, so that should be work. Perhaps, can we use 'usleep_range(500, 1000)' to work. Heiko, do you agree with it? > udelay(10), but previously we were actually looping waiting for the > power domain, right? ...so maybe the old code used to introduce a > pretty big delay. > > * Does anyone from the chip design team have any idea why patch set #4 > works but patch set #2 doesn't? I know it's Sunday morning in China > right now, but maybe you could ask Monday? > > > Thanks! > > -Doug > > > -- Thanks, - Caesar ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-07 5:51 ` Caesar Wang @ 2015-06-07 9:02 ` Heiko Stübner 0 siblings, 0 replies; 11+ messages in thread From: Heiko Stübner @ 2015-06-07 9:02 UTC (permalink / raw) To: linux-arm-kernel Hi Caesar, Doug, Am Sonntag, 7. Juni 2015, 13:51:24 schrieb Caesar Wang: > ? 2015?06?07? 11:43, Doug Anderson ??: > > Caesar, > > > > On Sat, Jun 6, 2015 at 7:51 PM, Caesar Wang <wxt@rock-chips.com> wrote: > >> @@ -150,13 +159,15 @@ static int __cpuinit > >> rockchip_boot_secondary(unsigned > >> int cpu, > >> > >> * sram_base_addr + 4: 0xdeadbeaf > >> * sram_base_addr + 8: start address for pc > >> * */ > >> > >> - udelay(10); > >> + udelay(20); > >> > >> I increased the 'udelay(20)' or 'udelay(50)' in > >> rockchip_boot_secondary(). > >> Set#2 also can repro this issue over 22600 cycles with testing scripts. > >> (about 1 hours) > >> > >> log: > >> ================= 226 ============ > >> [ 4069.134419] CPU1: shutdown > >> [ 4069.164431] CPU2: shutdown > >> [ 4069.204475] CPU3: shutdown > >> ...... > >> [ 4072.454453] CPU1: shutdown > >> [ 4072.504436] CPU2: shutdown > >> [ 4072.554426] CPU3: shutdown > >> [ 4072.577827] CPU1: Booted secondary processor > >> [ 4072.582611] CPU2: Booted secondary processor > >> [ 4072.587426] CPU3: Booted secondary processor > >> <hang> > >> > >> The set #4 will be better work. > > > > OK, I'm OK with this, but I'd like to get Heiko's opinion. > > > > Also: > > * Just for kicks, does mdelay(1) work? I know that's 100x more than > > OK, it should delay more time. > > the mdelay(1) can be work over 50000 cycles, so that should be work. > > > Perhaps, can we use 'usleep_range(500, 1000)' to work. > Heiko, do you agree with it? yep :-) As I said before, doing powerup, deassert_reset, wait_for_powerdomain feels like it is only moving the problem a bit but is actually only working by chance, as my [little bit of :-) ] common sense tells me, that we really only should deassert the reset when we're sure that the core has power, i.e. powerup, wait_for_powerdomain, deassert_reset Also, when going down this path, please take a look at the slightly different variant I posted as response to v3, as it makes the diff a bit smaller :-) As for {u/m}delay vs. your usleep_ranges, I don't know if you're allowed to sleep in this area. Other architectures only seem to use udelay in __cpu_up which calls the smp_secondary_startup callback, like: - arch/sh/kernel/smp.c - arch/m32r/kernel/smpboot.c [is even a udelay(1000) and more Heiko > > udelay(10), but previously we were actually looping waiting for the > > power domain, right? ...so maybe the old code used to introduce a > > pretty big delay. > > > > * Does anyone from the chip design team have any idea why patch set #4 > > works but patch set #2 doesn't? I know it's Sunday morning in China > > right now, but maybe you could ask Monday? > > > > > > Thanks! > > > > -Doug ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 2/3] ARM: rockchip: ensure CPU to enter WFI/WFE state 2015-06-05 17:05 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang 2015-06-05 17:05 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang @ 2015-06-05 17:05 ` Caesar Wang 2015-06-05 17:05 ` [PATCH v4 3/3] ARM: rockchip: fix the SMP code style Caesar Wang 2 siblings, 0 replies; 11+ messages in thread From: Caesar Wang @ 2015-06-05 17:05 UTC (permalink / raw) To: linux-arm-kernel In idle mode, core1/2/3 of Cortex-A17 should be either power off or in WFI/WFE state. we can delay 1ms to ensure the CPU enter WFI/WFE state. Signed-off-by: Caesar Wang <wxt@rock-chips.com> --- arch/arm/mach-rockchip/platsmp.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/arch/arm/mach-rockchip/platsmp.c b/arch/arm/mach-rockchip/platsmp.c index a297b86..d809fbc 100644 --- a/arch/arm/mach-rockchip/platsmp.c +++ b/arch/arm/mach-rockchip/platsmp.c @@ -327,6 +327,9 @@ static void __init rockchip_smp_prepare_cpus(unsigned int max_cpus) #ifdef CONFIG_HOTPLUG_CPU static int rockchip_cpu_kill(unsigned int cpu) { + /* ensure CPU can enter the WFI/WFE state */ + mdelay(1); + pmu_set_power_domain(0 + cpu, false); return 1; } -- 1.9.1 ^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH v4 3/3] ARM: rockchip: fix the SMP code style 2015-06-05 17:05 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang 2015-06-05 17:05 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang 2015-06-05 17:05 ` [PATCH v4 2/3] ARM: rockchip: ensure CPU to enter WFI/WFE state Caesar Wang @ 2015-06-05 17:05 ` Caesar Wang 2015-06-05 20:58 ` Doug Anderson 2 siblings, 1 reply; 11+ messages in thread From: Caesar Wang @ 2015-06-05 17:05 UTC (permalink / raw) To: linux-arm-kernel Use the below scripts to check: scripts/checkpatch.pl -f --subject arch/arm/mach-rockchip/platsmp.c Although there is a check, it's no matter. CHECK: usleep_range is preferred over udelay; see Documentation/timers/timers-howto.txt +167udelay(10); total: 0 errors, 0 warnings, 1 checks, 362 lines checked Changes in v4: - Add reset_control_put(rstc) for the non-error case. - Fix commit information in PATCH [1/3] Changes in v3: - FIx the PATCH v2, it doesn't work on chromium 3.14. Changes in v2: - As Kever points out, Fix the subject typo WIF/WFI in PATCH [2/3]. - As Heiko suggestion, re-adjust the cpu on/off flow in PATCH [1/3]. - Use the checkpatch.pl -f --subjective to check in PATCH [3/3]. Signed-off-by: Caesar Wang <wxt@rock-chips.com> --- arch/arm/mach-rockchip/platsmp.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/arch/arm/mach-rockchip/platsmp.c b/arch/arm/mach-rockchip/platsmp.c index d809fbc..63e9c7c 100644 --- a/arch/arm/mach-rockchip/platsmp.c +++ b/arch/arm/mach-rockchip/platsmp.c @@ -115,7 +115,7 @@ static int pmu_set_power_domain(int pd, bool on) ret = pmu_power_domain_is_on(pd); if (ret < 0) { pr_err("%s: could not read power domain state\n", - __func__); + __func__); return ret; } } @@ -139,7 +139,7 @@ static int __cpuinit rockchip_boot_secondary(unsigned int cpu, if (cpu >= ncores) { pr_err("%s: cpu %d outside maximum number of cpus %d\n", - __func__, cpu, ncores); + __func__, cpu, ncores); return -ENXIO; } @@ -158,7 +158,7 @@ static int __cpuinit rockchip_boot_secondary(unsigned int cpu, * */ udelay(10); writel(virt_to_phys(rockchip_secondary_startup), - sram_base_addr + 8); + sram_base_addr + 8); writel(0xDEADBEAF, sram_base_addr + 4); dsb_sev(); } @@ -337,7 +337,7 @@ static int rockchip_cpu_kill(unsigned int cpu) static void rockchip_cpu_die(unsigned int cpu) { v7_exit_coherency_flush(louis); - while(1) + while (1) cpu_do_idle(); } #endif @@ -350,4 +350,5 @@ static struct smp_operations rockchip_smp_ops __initdata = { .cpu_die = rockchip_cpu_die, #endif }; + CPU_METHOD_OF_DECLARE(rk3066_smp, "rockchip,rk3066-smp", &rockchip_smp_ops); -- 1.9.1 ^ permalink raw reply related [flat|nested] 11+ messages in thread
* [PATCH v4 3/3] ARM: rockchip: fix the SMP code style 2015-06-05 17:05 ` [PATCH v4 3/3] ARM: rockchip: fix the SMP code style Caesar Wang @ 2015-06-05 20:58 ` Doug Anderson 0 siblings, 0 replies; 11+ messages in thread From: Doug Anderson @ 2015-06-05 20:58 UTC (permalink / raw) To: linux-arm-kernel Caesar, On Fri, Jun 5, 2015 at 10:05 AM, Caesar Wang <wxt@rock-chips.com> wrote: > Use the below scripts to check: > scripts/checkpatch.pl -f --subject arch/arm/mach-rockchip/platsmp.c > Although there is a check, it's no matter. > > CHECK: usleep_range is preferred over udelay; see > Documentation/timers/timers-howto.txt > +167udelay(10); > total: 0 errors, 0 warnings, 1 checks, 362 lines checked > > Changes in v4: > - Add reset_control_put(rstc) for the non-error case. > - Fix commit information in PATCH [1/3] > > Changes in v3: > - FIx the PATCH v2, it doesn't work on chromium 3.14. > > Changes in v2: > - As Kever points out, Fix the subject typo WIF/WFI in PATCH [2/3]. > - As Heiko suggestion, re-adjust the cpu on/off flow in PATCH [1/3]. > - Use the checkpatch.pl -f --subjective to check in PATCH [3/3]. The change log should (ideally) be with each patch. If that's too hard and you want to put it in one place, please put it in the cover letter (the 0/3 email). Also: the change log should be "below the cut". That is, it should be below the "---" and above the diffstat. Other than those problems: Reviewed-by: Douglas Anderson <dianders@chromium.org> -Doug ^ permalink raw reply [flat|nested] 11+ messages in thread
* [PATCH v4 0/3] ARM: rockchip: fix the SMP
@ 2015-06-05 17:03 Caesar Wang
2015-06-05 17:03 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang
0 siblings, 1 reply; 11+ messages in thread
From: Caesar Wang @ 2015-06-05 17:03 UTC (permalink / raw)
To: linux-arm-kernel
Verified on url =
https://chromium.googlesource.com/chromiumos/third_party/kernel/+/chromeos-3.14
Caesar Wang (3):
ARM: rockchip: fix the CPU soft reset
ARM: rockchip: ensure CPU to enter WFI/WFE state
ARM: rockchip: fix the SMP code style
arch/arm/mach-rockchip/platsmp.c | 36 ++++++++++++++++++++++++------------
1 file changed, 24 insertions(+), 12 deletions(-)
--
1.9.1
^ permalink raw reply [flat|nested] 11+ messages in thread* [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset 2015-06-05 17:03 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang @ 2015-06-05 17:03 ` Caesar Wang 0 siblings, 0 replies; 11+ messages in thread From: Caesar Wang @ 2015-06-05 17:03 UTC (permalink / raw) To: linux-arm-kernel We need different orderings when turning a core on and turning a core off. In one case we need to assert reset before turning power off. In ther other case we need to turn power on and the deassert reset. In general, the correct flow is: CPU off: reset_control_assert regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), BIT(pd)) ensure power domain is on CPU on: regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), 0) reset_control_deassert ensure power domain is on This is needed for stressing CPU up/down, as per: cd /sys/devices/system/cpu/ for i in $(seq 1000); do echo "================= $i ============" for j in $(seq 100); do while [[ "$(cat cpu1/online)$(cat cpu2/online)$(cat cpu3/online)" != "000"" ]] echo 0 > cpu1/online echo 0 > cpu2/online echo 0 > cpu3/online done while [[ "$(cat cpu1/online)$(cat cpu2/online)$(cat cpu3/online)" != "111" ]]; do echo 1 > cpu1/online echo 1 > cpu2/online echo 1 > cpu3/online done done done The following is reproducile log: [34466.186812] PM: noirq suspend of devices complete after 0.669 msecs [34466.186824] Disabling non-boot CPUs ... [34466.187509] CPU1: shutdown [34466.188672] CPU2: shutdown [34473.736627] Kernel panic - not syncing:Watchdog detected hard LOCKUP on cpu 0 ....... Signed-off-by: Caesar Wang <wxt@rock-chips.com> Reviewed-by: Doug Anderson <dianders@chromium.org> --- arch/arm/mach-rockchip/platsmp.c | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/arch/arm/mach-rockchip/platsmp.c b/arch/arm/mach-rockchip/platsmp.c index 5b4ca3c..a297b86 100644 --- a/arch/arm/mach-rockchip/platsmp.c +++ b/arch/arm/mach-rockchip/platsmp.c @@ -88,18 +88,26 @@ static int pmu_set_power_domain(int pd, bool on) return PTR_ERR(rstc); } + if (!on) + reset_control_assert(rstc); + + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); + if (ret < 0) { + pr_err("%s: could not update power domain\n", __func__); + reset_control_put(rstc); + return ret; + } + if (on) reset_control_deassert(rstc); - else - reset_control_assert(rstc); reset_control_put(rstc); - } - - ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); - if (ret < 0) { - pr_err("%s: could not update power domain\n", __func__); - return ret; + } else { + ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val); + if (ret < 0) { + pr_err("%s: could not update power domain\n", __func__); + return ret; + } } ret = -1; -- 1.9.1 ^ permalink raw reply related [flat|nested] 11+ messages in thread
end of thread, other threads:[~2015-06-07 9:02 UTC | newest] Thread overview: 11+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-06-05 17:05 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang 2015-06-05 17:05 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang 2015-06-05 20:55 ` Doug Anderson 2015-06-07 2:51 ` Caesar Wang 2015-06-07 3:43 ` Doug Anderson 2015-06-07 5:51 ` Caesar Wang 2015-06-07 9:02 ` Heiko Stübner 2015-06-05 17:05 ` [PATCH v4 2/3] ARM: rockchip: ensure CPU to enter WFI/WFE state Caesar Wang 2015-06-05 17:05 ` [PATCH v4 3/3] ARM: rockchip: fix the SMP code style Caesar Wang 2015-06-05 20:58 ` Doug Anderson -- strict thread matches above, loose matches on Subject: below -- 2015-06-05 17:03 [PATCH v4 0/3] ARM: rockchip: fix the SMP Caesar Wang 2015-06-05 17:03 ` [PATCH v4 1/3] ARM: rockchip: fix the CPU soft reset Caesar Wang
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).