This allows platform suspend code to re-use the generic state saving code, passing a pointer to the low-level suspend code.
The resume path is modified so that non-hibernate callers skip hibernate-specific bits, and so that callers can specify that the MMU is off (and thus BATs should be restored). The _GLOBAL around swsusp_save_area is changed to .global, as the former puts the data in the text section, which causes an oops with page debugging enabled. Signed-off-by: Scott Wood <[EMAIL PROTECTED]> --- Sorry, this one got left out of the previous PM patchset. arch/powerpc/Kconfig | 11 +++++++ arch/powerpc/kernel/Makefile | 2 +- arch/powerpc/kernel/swsusp_32.S | 60 ++++++++++++++++++++++---------------- 3 files changed, 47 insertions(+), 26 deletions(-) diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 00099ef..b8c6fa2 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig @@ -123,6 +123,17 @@ config DEFAULT_UIMAGE Used to allow a board to specify it wants a uImage built by default default n +config PPC32_SUSPEND + bool + depends on PPC32 + default n + +config PPC32_SWSUSP + bool + depends on PPC32 && HIBERNATION + select PPC32_SUSPEND + default y + config PPC64_SWSUSP bool depends on PPC64 && (BROKEN || (PPC_PMAC64 && EXPERIMENTAL)) diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile index 967afc5..d95b09f 100644 --- a/arch/powerpc/kernel/Makefile +++ b/arch/powerpc/kernel/Makefile @@ -38,7 +38,7 @@ obj-$(CONFIG_CRASH_DUMP) += crash_dump.o obj-$(CONFIG_6xx) += idle_6xx.o l2cr_6xx.o cpu_setup_6xx.o obj-$(CONFIG_TAU) += tau_6xx.o obj-$(CONFIG_HIBERNATION) += swsusp.o suspend.o -obj32-$(CONFIG_HIBERNATION) += swsusp_32.o +obj32-$(CONFIG_PPC32_SUSPEND) += swsusp_32.o obj64-$(CONFIG_HIBERNATION) += swsusp_64.o swsusp_asm64.o obj32-$(CONFIG_MODULES) += module_32.o diff --git a/arch/powerpc/kernel/swsusp_32.S b/arch/powerpc/kernel/swsusp_32.S index 69e8f86..ed1c95b 100644 --- a/arch/powerpc/kernel/swsusp_32.S +++ b/arch/powerpc/kernel/swsusp_32.S @@ -33,15 +33,21 @@ .section .data .align 5 -_GLOBAL(swsusp_save_area) + .global swsusp_save_area +swsusp_save_area: .space SL_SIZE .section .text .align 5 +#ifdef CONFIG_SOFTWARE_SUSPEND _GLOBAL(swsusp_arch_suspend) + lis r3, [EMAIL PROTECTED] + ori r3, r3, [EMAIL PROTECTED] +#endif +_GLOBAL(do_suspend) lis r11,[EMAIL PROTECTED] ori r11,r11,[EMAIL PROTECTED] @@ -64,8 +70,8 @@ _GLOBAL(swsusp_arch_suspend) stw r4,SL_TB(r11) mftb r5 stw r5,SL_TB+4(r11) - mftbu r3 - cmpw r3,r4 + mftbu r6 + cmpw r6,r4 bne 1b /* Save SPRGs */ @@ -119,7 +125,8 @@ _GLOBAL(swsusp_arch_suspend) /* Call the low level suspend stuff (we should probably have made * a stackframe... */ - bl swsusp_save + mtctr r3 + bctrl /* Restore LR from the save area */ lis r11,[EMAIL PROTECTED] @@ -129,7 +136,7 @@ _GLOBAL(swsusp_arch_suspend) blr - +#ifdef CONFIG_SOFTWARE_SUSPEND /* Resume code */ _GLOBAL(swsusp_arch_resume) @@ -212,6 +219,13 @@ END_FTR_SECTION_IFSET(CPU_FTR_ALTIVEC) bdnz 1b sync + li r3, 0 +#endif + + /* r3 = nonzero if the MMU is completely disabled and + * BATs may be restored, zero otherwise. + */ +_GLOBAL(do_resume) /* Ok, we are now running with the kernel data of the old * kernel fully restored. We can get to the save area * easily now. As for the rest of the code, it assumes the @@ -226,10 +240,8 @@ END_FTR_SECTION_IFSET(CPU_FTR_ALTIVEC) bl __restore_cpu_setup #endif /* Restore the BATs, and SDR1. Then we can turn on the MMU. - * This is a bit hairy as we are running out of those BATs, - * but first, our code is probably in the icache, and we are - * writing the same value to the BAT, so that should be fine, - * though a better solution will have to be found long-term + * This can only be done when r3 != 0 (and thus the MMU is + * off). */ lwz r4,SL_SDR1(r11) mtsdr1 r4 @@ -242,7 +254,9 @@ END_FTR_SECTION_IFSET(CPU_FTR_ALTIVEC) lwz r4,SL_SPRG0+12(r11) mtsprg 3,r4 -#if 0 + cmpw r3, 0 + beq 1f + lwz r4,SL_DBAT0(r11) mtdbatu 0,r4 lwz r4,SL_DBAT0+4(r11) @@ -275,8 +289,8 @@ END_FTR_SECTION_IFSET(CPU_FTR_ALTIVEC) mtibatu 3,r4 lwz r4,SL_IBAT3+4(r11) mtibatl 3,r4 -#endif +1: BEGIN_FTR_SECTION li r4,0 mtspr SPRN_DBAT4U,r4 @@ -306,8 +320,16 @@ END_FTR_SECTION_IFSET(CPU_FTR_HAS_HIGH_BATS) /* restore the MSR and turn on the MMU */ lwz r3,SL_MSR(r11) - bl turn_on_mmu - tovirt(r11,r11) + lis r4, [EMAIL PROTECTED] + ori r4, r4, [EMAIL PROTECTED] + + mtsrr0 r4 + mtsrr1 r3 + sync + isync + rfi + +1: tovirt(r11, r11) /* Restore TB */ li r3,0 @@ -334,15 +356,3 @@ END_FTR_SECTION_IFSET(CPU_FTR_HAS_HIGH_BATS) li r3,0 blr - -/* FIXME:This construct is actually not useful since we don't shut - * down the instruction MMU, we could just flip back MSR-DR on. - */ -turn_on_mmu: - mflr r4 - mtsrr0 r4 - mtsrr1 r3 - sync - isync - rfi - -- 1.5.3 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev