⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sleep.s

📁 上传linux-jx2410的源代码
💻 S
字号:
/* * Low-level PXA250/210 sleep/wakeUp support * * Initial SA1110 code: * Copyright (c) 2001 Cliff Brake <cbrake@accelent.com> * * Adapted for PXA by Nicolas Pitre: * Copyright (c) 2002 Monta Vista Software, Inc. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License. */#include <linux/config.h>#include <linux/linkage.h>#include <asm/assembler.h>#include <asm/hardware.h>		.text/* * pxa_cpu_suspend() * * Forces CPU into sleep state */ENTRY(pxa_cpu_suspend)	mra	r2, r3, acc0	stmfd	sp!, {r2 - r12, lr}		@ save registers on stack	@ get coprocessor registers	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	@ store them plus current virtual stack ptr on stack	mov	r10, sp	stmfd	sp!, {r4 - r10}	@ preserve phys address of stack	mov	r0, sp	bl	sleep_phys_sp	ldr	r1, =sleep_save_sp	str	r0, [r1]	@ clean data cache 	bl	cpu_xscale_cache_clean_invalidate_all	@ Put the processor to sleep	@ (also workaround for sighting 28071)	@ prepare value for sleep mode	mov	r1, #3				@ sleep mode	@ prepare to put SDRAM into self-refresh manually	ldr	r4, =MDREFR	ldr	r5, [r4]	orr	r5, r5, #MDREFR_SLFRSH	@ prepare pointer to physical address 0 (virtual mapping in generic.c)	mov	r2, #UNCACHED_PHYS_0	@ align execution to a cache line	b	1f	.ltorg	.align	51:	@ All needed values are now in registers. 	@ These last instructions should be in cache	@ put SDRAM into self-refresh		str	r5, [r4]	@ force address lines low by reading at physical address 0	ldr	r3, [r2]	@ enter sleep mode	mcr	p14, 0, r1, c7, c0, 020:	nop	b	20b				@ loop waiting for sleep/* * cpu_pxa_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 truely read-only. */	.data	.align 5ENTRY(pxa_cpu_resume)	mov	r0, #I_BIT | F_BIT | MODE_SVC	@ 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, {r4 - 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#ifdef CONFIG_XSCALE_CACHE_ERRATA	bic     r9, r9, #0x0004			@ see cpu_xscale_proc_init#endif	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 5resume_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	nopsleep_save_sp:	.word	0				@ preserve stack phys ptr here	.textresume_after_mmu:#ifdef CONFIG_XSCALE_CACHE_ERRATA	bl	cpu_xscale_proc_init#endif	ldmfd	sp!, {r2, r3}	mar	acc0, r2, r3	ldmfd	sp!, {r4 - r12, pc}		@ return to caller

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -