|
@@ -30,6 +30,8 @@ LEAF(swsusp_arch_suspend)
|
|
END(swsusp_arch_suspend)
|
|
END(swsusp_arch_suspend)
|
|
|
|
|
|
LEAF(swsusp_arch_resume)
|
|
LEAF(swsusp_arch_resume)
|
|
|
|
+ /* Avoid TLB mismatch during and after kernel resume */
|
|
|
|
+ jal local_flush_tlb_all
|
|
PTR_L t0, restore_pblist
|
|
PTR_L t0, restore_pblist
|
|
0:
|
|
0:
|
|
PTR_L t1, PBE_ADDRESS(t0) /* source */
|
|
PTR_L t1, PBE_ADDRESS(t0) /* source */
|
|
@@ -43,7 +45,6 @@ LEAF(swsusp_arch_resume)
|
|
bne t1, t3, 1b
|
|
bne t1, t3, 1b
|
|
PTR_L t0, PBE_NEXT(t0)
|
|
PTR_L t0, PBE_NEXT(t0)
|
|
bnez t0, 0b
|
|
bnez t0, 0b
|
|
- jal local_flush_tlb_all /* Avoid TLB mismatch after kernel resume */
|
|
|
|
PTR_LA t0, saved_regs
|
|
PTR_LA t0, saved_regs
|
|
PTR_L ra, PT_R31(t0)
|
|
PTR_L ra, PT_R31(t0)
|
|
PTR_L sp, PT_R29(t0)
|
|
PTR_L sp, PT_R29(t0)
|