diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-22 12:41:01 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-22 12:41:01 -0400 |
commit | cdd3a354a05b0c33fe33ab11a0fb0838396cad19 (patch) | |
tree | ea2c87bbc2dc5865a97e73e201661d69937b45d5 /arch/arm/mm/proc-mohawk.S | |
parent | 813a95e5b4fa936bbde10ef89188932745dcd7f4 (diff) | |
parent | ada2e35defe6c6f0a986ec8147e47726fbd0e7b1 (diff) |
Merge tag 'pm' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc
Pull arm-soc power management changes from Olof Johansson:
"Power management changes here are mostly for the omap platform, but
also include cpuidle changes for ux500 and suspend/resume code for
mmp."
* tag 'pm' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: (48 commits)
ARM: OMAP2+: WDTIMER integration: fix !PM boot crash, disarm timer after hwmod reset
ARM: OMAP2/3: hwmod data: Add 32k-sync timer data to hwmod database
ARM: OMAP4: hwmod_data: Name the common irq for McBSP ports
ARM: OMAP4: hwmod data: I2C: add flag for context restore
ARM: OMAP3: hwmod_data: Rename the common irq for McBSP ports
ARM: OMAP2xxx: hwmod data: add HDQ/1-wire hwmod
ARM: OMAP3: hwmod data: add HDQ/1-wire hwmod
ARM: OMAP2+: hwmod data: add HDQ/1-wire hwmod shared data
ARM: OMAP2+: HDQ1W: add custom reset function
ARM: OMAP2420: hwmod data: Add MMC hwmod data for 2420
arm: omap3: clockdomain data: Remove superfluous commas from gfx_sgx_3xxx_wkdeps[]
ARM: OMAP2+: powerdomain: Get rid off duplicate pwrdm_clkdm_state_switch() API
ARM: OMAP3: clock data: add clockdomain for HDQ functional clock
ARM: OMAP3+: dpll: Configure autoidle mode only if it's supported
ARM: OMAP2+: dmtimer: cleanup iclk usage
ARM: OMAP4+: Add prm and cm base init function.
ARM: OMAP2/3: Add idle_st bits for ST_32KSYNC timer to prcm-common header
ARM: OMAP3: Fix CM register bit masks
ARM: OMAP: clock: convert AM3517/3505 detection/flags to AM35xx
ARM: OMAP3: clock data: treat all AM35x devices the same
...
Diffstat (limited to 'arch/arm/mm/proc-mohawk.S')
-rw-r--r-- | arch/arm/mm/proc-mohawk.S | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/arch/arm/mm/proc-mohawk.S b/arch/arm/mm/proc-mohawk.S index b0475468c711..fbb2124a547d 100644 --- a/arch/arm/mm/proc-mohawk.S +++ b/arch/arm/mm/proc-mohawk.S | |||
@@ -345,6 +345,41 @@ ENTRY(cpu_mohawk_set_pte_ext) | |||
345 | mcr p15, 0, r0, c7, c10, 4 @ drain WB | 345 | mcr p15, 0, r0, c7, c10, 4 @ drain WB |
346 | mov pc, lr | 346 | mov pc, lr |
347 | 347 | ||
348 | .globl cpu_mohawk_suspend_size | ||
349 | .equ cpu_mohawk_suspend_size, 4 * 6 | ||
350 | #ifdef CONFIG_PM_SLEEP | ||
351 | ENTRY(cpu_mohawk_do_suspend) | ||
352 | stmfd sp!, {r4 - r9, lr} | ||
353 | mrc p14, 0, r4, c6, c0, 0 @ clock configuration, for turbo mode | ||
354 | mrc p15, 0, r5, c15, c1, 0 @ CP access reg | ||
355 | mrc p15, 0, r6, c13, c0, 0 @ PID | ||
356 | mrc p15, 0, r7, c3, c0, 0 @ domain ID | ||
357 | mrc p15, 0, r8, c1, c0, 1 @ auxiliary control reg | ||
358 | mrc p15, 0, r9, c1, c0, 0 @ control reg | ||
359 | bic r4, r4, #2 @ clear frequency change bit | ||
360 | stmia r0, {r4 - r9} @ store cp regs | ||
361 | ldmia sp!, {r4 - r9, pc} | ||
362 | ENDPROC(cpu_mohawk_do_suspend) | ||
363 | |||
364 | ENTRY(cpu_mohawk_do_resume) | ||
365 | ldmia r0, {r4 - r9} @ load cp regs | ||
366 | mov ip, #0 | ||
367 | mcr p15, 0, ip, c7, c7, 0 @ invalidate I & D caches, BTB | ||
368 | mcr p15, 0, ip, c7, c10, 4 @ drain write (&fill) buffer | ||
369 | mcr p15, 0, ip, c7, c5, 4 @ flush prefetch buffer | ||
370 | mcr p15, 0, ip, c8, c7, 0 @ invalidate I & D TLBs | ||
371 | mcr p14, 0, r4, c6, c0, 0 @ clock configuration, turbo mode. | ||
372 | mcr p15, 0, r5, c15, c1, 0 @ CP access reg | ||
373 | mcr p15, 0, r6, c13, c0, 0 @ PID | ||
374 | mcr p15, 0, r7, c3, c0, 0 @ domain ID | ||
375 | orr r1, r1, #0x18 @ cache the page table in L2 | ||
376 | mcr p15, 0, r1, c2, c0, 0 @ translation table base addr | ||
377 | mcr p15, 0, r8, c1, c0, 1 @ auxiliary control reg | ||
378 | mov r0, r9 @ control register | ||
379 | b cpu_resume_mmu | ||
380 | ENDPROC(cpu_mohawk_do_resume) | ||
381 | #endif | ||
382 | |||
348 | __CPUINIT | 383 | __CPUINIT |
349 | 384 | ||
350 | .type __mohawk_setup, #function | 385 | .type __mohawk_setup, #function |