diff options
| author | Alexander Kochetkov <al.kochet@gmail.com> | 2025-07-03 17:04:53 +0300 | 
|---|---|---|
| committer | Heiko Stuebner <heiko@sntech.de> | 2025-07-14 15:38:40 +0200 | 
| commit | 7cdb433bb44cdc87dc5260cdf15bf03cc1cd1814 (patch) | |
| tree | c84bd27ae5fe5a81ce4f3cc2af96ee414d528da7 /rust/helpers/pci.c | |
| parent | 19272b37aa4f83ca52bdf9c16d5d81bdd1354494 (diff) | |
ARM: rockchip: fix kernel hang during smp initialization
In order to bring up secondary CPUs main CPU write trampoline
code to SRAM. The trampoline code is written while secondary
CPUs are powered on (at least that true for RK3188 CPU).
Sometimes that leads to kernel hang. Probably because secondary
CPU execute trampoline code while kernel doesn't expect.
The patch moves SRAM initialization step to the point where all
secondary CPUs are powered down.
That fixes rarely hangs on RK3188:
[    0.091568] CPU0: thread -1, cpu 0, socket 0, mpidr 80000000
[    0.091996] rockchip_smp_prepare_cpus: ncores 4
Signed-off-by: Alexander Kochetkov <al.kochet@gmail.com>
Link: https://lore.kernel.org/r/20250703140453.1273027-1-al.kochet@gmail.com
Signed-off-by: Heiko Stuebner <heiko@sntech.de>
Diffstat (limited to 'rust/helpers/pci.c')
0 files changed, 0 insertions, 0 deletions
