diff options
Diffstat (limited to 'arch/arm/mach-pxa/sleep.S')
| -rw-r--r-- | arch/arm/mach-pxa/sleep.S | 218 | 
1 files changed, 9 insertions, 209 deletions
diff --git a/arch/arm/mach-pxa/sleep.S b/arch/arm/mach-pxa/sleep.S index 52c30b01a67..1e544be9905 100644 --- a/arch/arm/mach-pxa/sleep.S +++ b/arch/arm/mach-pxa/sleep.S @@ -14,7 +14,7 @@  #include <linux/linkage.h>  #include <asm/assembler.h>  #include <mach/hardware.h> - +#include <mach/smemc.h>  #include <mach/pxa2xx-regs.h>  #define MDREFR_KDIV	0x200a4000	// all banks @@ -22,164 +22,31 @@  		.text -pxa_cpu_save_cp: -	@ get coprocessor registers -	mrc	p14, 0, r3, c6, c0, 0		@ clock configuration, for turbo mode -	mrc	p15, 0, r4, c15, c1, 0		@ CP access reg -	mrc	p15, 0, r5, c13, c0, 0		@ PID -	mrc 	p15, 0, r6, c3, c0, 0		@ domain ID -	mrc 	p15, 0, r7, c2, c0, 0		@ translation table base addr -	mrc	p15, 0, r8, c1, c1, 0           @ auxiliary control reg -	mrc 	p15, 0, r9, c1, c0, 0		@ control reg - -	bic	r3, r3, #2			@ clear frequency change bit - -	@ store them plus current virtual stack ptr on stack -	mov	r10, sp -	stmfd	sp!, {r3 - r10} - -	mov	pc, lr - -pxa_cpu_save_sp: -	@ preserve phys address of stack -	mov	r0, sp -	str	lr, [sp, #-4]! -	bl	sleep_phys_sp -	ldr	r1, =sleep_save_sp -	str	r0, [r1] -	ldr	pc, [sp], #4 -  #ifdef CONFIG_PXA3xx  /* - * pxa3xx_cpu_suspend() - forces CPU into sleep state (S2D3C4) - * - * NOTE:  unfortunately, pxa_cpu_save_cp can not be reused here since - * the auxiliary control register address is different between pxa3xx - * and pxa{25x,27x} + * pxa3xx_finish_suspend() - forces CPU into sleep state (S2D3C4)   */ - -ENTRY(pxa3xx_cpu_suspend) - -#ifndef CONFIG_IWMMXT -	mra	r2, r3, acc0 -#endif -	stmfd	sp!, {r2 - r12, lr}	@ save registers on stack - -	mrc	p14, 0, r3, c6, c0, 0		@ clock configuration, for turbo mode -	mrc	p15, 0, r4, c15, c1, 0		@ CP access reg -	mrc	p15, 0, r5, c13, c0, 0		@ PID -	mrc 	p15, 0, r6, c3, c0, 0		@ domain ID -	mrc 	p15, 0, r7, c2, c0, 0		@ translation table base addr -	mrc	p15, 0, r8, c1, c0, 1           @ auxiliary control reg -	mrc 	p15, 0, r9, c1, c0, 0		@ control reg - -	bic	r3, r3, #2			@ clear frequency change bit - -	@ store them plus current virtual stack ptr on stack -	mov	r10, sp -	stmfd	sp!, {r3 - r10} - -	@ store physical address of stack pointer -	mov	r0, sp -	bl	sleep_phys_sp -	ldr	r1, =sleep_save_sp -	str	r0, [r1] - -	@ clean data cache -	bl	xsc3_flush_kern_cache_all - +ENTRY(pxa3xx_finish_suspend)  	mov	r0, #0x06		@ S2D3C4 mode  	mcr	p14, 0, r0, c7, c0, 0	@ enter sleep  20:	b	20b			@ waiting for sleep - -	.data -	.align 5 -/* - * pxa3xx_cpu_resume - */ - -ENTRY(pxa3xx_cpu_resume) - -	mov	r0, #PSR_I_BIT | PSR_F_BIT | SVC_MODE	@ set SVC, irqs off -	msr	cpsr_c, r0 - -	ldr	r0, sleep_save_sp		@ stack phys addr -	ldmfd	r0, {r3 - r9, sp}		@ CP regs + virt stack ptr - -	mov	r1, #0 -	mcr	p15, 0, r1, c7, c7, 0		@ invalidate I & D caches, BTB -	mcr	p15, 0, r1, c7, c10, 4		@ drain write (&fill) buffer -	mcr	p15, 0, r1, c7, c5, 4		@ flush prefetch buffer -	mcr	p15, 0, r1, c8, c7, 0   	@ invalidate I & D TLBs - -	mcr	p14, 0, r3, c6, c0, 0		@ clock configuration, turbo mode. -	mcr	p15, 0, r4, c15, c1, 0		@ CP access reg -	mcr	p15, 0, r5, c13, c0, 0		@ PID -	mcr 	p15, 0, r6, c3, c0, 0		@ domain ID -	mcr 	p15, 0, r7, c2, c0, 0		@ translation table base addr -	mcr	p15, 0, r8, c1, c0, 1           @ auxiliary control reg - -	@ temporarily map resume_turn_on_mmu into the page table, -	@ otherwise prefetch abort occurs after MMU is turned on -	mov	r1, r7 -	bic	r1, r1, #0x00ff -	bic	r1, r1, #0x3f00 -	ldr	r2, =0x542e - -	adr	r3, resume_turn_on_mmu -	mov	r3, r3, lsr #20 -	orr	r4, r2, r3, lsl #20 -	ldr	r5, [r1, r3, lsl #2] -	str     r4, [r1, r3, lsl #2] - -	@ Mapping page table address in the page table -	mov	r6, r1, lsr #20 -	orr	r7, r2, r6, lsl #20 -	ldr	r8, [r1, r6, lsl #2] -	str	r7, [r1, r6, lsl #2] - -	ldr	r2, =pxa3xx_resume_after_mmu	@ absolute virtual address -	b	resume_turn_on_mmu		@ cache align execution - -	.text -pxa3xx_resume_after_mmu: -	/* restore the temporary mapping */ -	str	r5, [r1, r3, lsl #2] -	str	r8, [r1, r6, lsl #2] -	b	resume_after_mmu -  #endif /* CONFIG_PXA3xx */  #ifdef CONFIG_PXA27x  /* - * pxa27x_cpu_suspend() + * pxa27x_finish_suspend()   *   * Forces CPU into sleep state.   *   * r0 = value for PWRMODE M field for desired sleep state   */ - -ENTRY(pxa27x_cpu_suspend) - -#ifndef CONFIG_IWMMXT -	mra	r2, r3, acc0 -#endif -	stmfd	sp!, {r2 - r12, lr}		@ save registers on stack - -	bl	pxa_cpu_save_cp - -	mov	r5, r0				@ save sleep mode -	bl	pxa_cpu_save_sp - -	@ clean data cache -	bl	xscale_flush_kern_cache_all - +ENTRY(pxa27x_finish_suspend)  	@ Put the processor to sleep  	@ (also workaround for sighting 28071)  	@ prepare value for sleep mode -	mov	r1, r5				@ sleep mode +	mov	r1, r0				@ sleep mode  	@ prepare pointer to physical address 0 (virtual mapping in generic.c)  	mov	r2, #UNCACHED_PHYS_0 @@ -211,26 +78,16 @@ ENTRY(pxa27x_cpu_suspend)  #ifdef CONFIG_PXA25x  /* - * pxa25x_cpu_suspend() + * pxa25x_finish_suspend()   *   * Forces CPU into sleep state.   *   * r0 = value for PWRMODE M field for desired sleep state   */ -ENTRY(pxa25x_cpu_suspend) -	stmfd	sp!, {r2 - r12, lr}		@ save registers on stack - -	bl	pxa_cpu_save_cp - -	mov	r5, r0				@ save sleep mode -	bl	pxa_cpu_save_sp - -	@ clean data cache -	bl	xscale_flush_kern_cache_all - +ENTRY(pxa25x_finish_suspend)  	@ prepare value for sleep mode -	mov	r1, r5				@ sleep mode +	mov	r1, r0				@ sleep mode  	@ prepare pointer to physical address 0 (virtual mapping in generic.c)  	mov	r2, #UNCACHED_PHYS_0 @@ -312,60 +169,3 @@ pxa_cpu_do_suspend:  	mcr	p14, 0, r1, c7, c0, 0		@ PWRMODE  20:	b	20b				@ loop waiting for sleep - -/* - * pxa_cpu_resume() - * - * entry point from bootloader into kernel during resume - * - * Note: Yes, part of the following code is located into the .data section. - *       This is to allow sleep_save_sp to be accessed with a relative load - *       while we can't rely on any MMU translation.  We could have put - *       sleep_save_sp in the .text section as well, but some setups might - *       insist on it to be truly read-only. - */ - -	.data -	.align 5 -ENTRY(pxa_cpu_resume) -	mov	r0, #PSR_I_BIT | PSR_F_BIT | SVC_MODE	@ set SVC, irqs off -	msr	cpsr_c, r0 - -	ldr	r0, sleep_save_sp		@ stack phys addr -	ldr	r2, =resume_after_mmu		@ its absolute virtual address -	ldmfd	r0, {r3 - r9, sp}		@ CP regs + virt stack ptr - -	mov	r1, #0 -	mcr	p15, 0, r1, c8, c7, 0   	@ invalidate I & D TLBs -	mcr	p15, 0, r1, c7, c7, 0		@ invalidate I & D caches, BTB - -	mcr	p14, 0, r3, c6, c0, 0		@ clock configuration, turbo mode. -	mcr	p15, 0, r4, c15, c1, 0		@ CP access reg -	mcr	p15, 0, r5, c13, c0, 0		@ PID -	mcr 	p15, 0, r6, c3, c0, 0		@ domain ID -	mcr 	p15, 0, r7, c2, c0, 0		@ translation table base addr -	mcr	p15, 0, r8, c1, c1, 0           @ auxiliary control reg -	b	resume_turn_on_mmu		@ cache align execution - -	.align 5 -resume_turn_on_mmu: -	mcr 	p15, 0, r9, c1, c0, 0		@ turn on MMU, caches, etc. - -	@ Let us ensure we jump to resume_after_mmu only when the mcr above -	@ actually took effect.  They call it the "cpwait" operation. -	mrc	p15, 0, r1, c2, c0, 0		@ queue a dependency on CP15 -	sub	pc, r2, r1, lsr #32		@ jump to virtual addr -	nop -	nop -	nop - -sleep_save_sp: -	.word	0				@ preserve stack phys ptr here - -	.text -resume_after_mmu: -	ldmfd	sp!, {r2, r3} -#ifndef CONFIG_IWMMXT -	mar	acc0, r2, r3 -#endif -	ldmfd	sp!, {r4 - r12, pc}		@ return to caller  | 
