powerpc/32: Fix hardlockup on vmap stack overflow

Since the commit c118c7303ad5 ("powerpc/32: Fix vmap stack - Do not
activate MMU before reading task struct") a vmap stack overflow
results in a hard lockup. This is because emergency_ctx is still
addressed with its virtual address allthough data MMU is not active
anymore at that time.

Fix it by using a physical address instead.

Fixes: c118c7303ad5 ("powerpc/32: Fix vmap stack - Do not activate MMU before reading task struct")
Cc: stable@vger.kernel.org # v5.10+
Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/ce30364fb7ccda489272af4a1612b6aa147e1d23.1637227521.git.christophe.leroy@csgroup.eu

authored by Christophe Leroy and committed by Michael Ellerman 5bb60ea6 cf0b0e37

+3 -3
+3 -3
arch/powerpc/kernel/head_32.h
··· 202 mfspr r1, SPRN_SPRG_THREAD 203 lwz r1, TASK_CPU - THREAD(r1) 204 slwi r1, r1, 3 205 - addis r1, r1, emergency_ctx@ha 206 #else 207 - lis r1, emergency_ctx@ha 208 #endif 209 - lwz r1, emergency_ctx@l(r1) 210 addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE 211 EXCEPTION_PROLOG_2 0 vmap_stack_overflow 212 prepare_transfer_to_handler
··· 202 mfspr r1, SPRN_SPRG_THREAD 203 lwz r1, TASK_CPU - THREAD(r1) 204 slwi r1, r1, 3 205 + addis r1, r1, emergency_ctx-PAGE_OFFSET@ha 206 #else 207 + lis r1, emergency_ctx-PAGE_OFFSET@ha 208 #endif 209 + lwz r1, emergency_ctx-PAGE_OFFSET@l(r1) 210 addi r1, r1, THREAD_SIZE - INT_FRAME_SIZE 211 EXCEPTION_PROLOG_2 0 vmap_stack_overflow 212 prepare_transfer_to_handler