pm_suspend.S 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. /*
  2. * arch/arm/mach-at91/pm_slow_clock.S
  3. *
  4. * Copyright (C) 2006 Savin Zlobec
  5. *
  6. * AT91SAM9 support:
  7. * Copyright (C) 2007 Anti Sullin <anti.sullin@artecdesign.ee
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License version 2 as
  11. * published by the Free Software Foundation.
  12. *
  13. */
  14. #include <linux/linkage.h>
  15. #include <linux/clk/at91_pmc.h>
  16. #include "pm.h"
  17. #define SRAMC_SELF_FRESH_ACTIVE 0x01
  18. #define SRAMC_SELF_FRESH_EXIT 0x00
  19. pmc .req r0
  20. tmp1 .req r4
  21. tmp2 .req r5
  22. /*
  23. * Wait until master clock is ready (after switching master clock source)
  24. */
  25. .macro wait_mckrdy
  26. 1: ldr tmp1, [pmc, #AT91_PMC_SR]
  27. tst tmp1, #AT91_PMC_MCKRDY
  28. beq 1b
  29. .endm
  30. /*
  31. * Wait until master oscillator has stabilized.
  32. */
  33. .macro wait_moscrdy
  34. 1: ldr tmp1, [pmc, #AT91_PMC_SR]
  35. tst tmp1, #AT91_PMC_MOSCS
  36. beq 1b
  37. .endm
  38. /*
  39. * Wait until PLLA has locked.
  40. */
  41. .macro wait_pllalock
  42. 1: ldr tmp1, [pmc, #AT91_PMC_SR]
  43. tst tmp1, #AT91_PMC_LOCKA
  44. beq 1b
  45. .endm
  46. /*
  47. * Put the processor to enter the idle state
  48. */
  49. .macro at91_cpu_idle
  50. #if defined(CONFIG_CPU_V7)
  51. mov tmp1, #AT91_PMC_PCK
  52. str tmp1, [pmc, #AT91_PMC_SCDR]
  53. dsb
  54. wfi @ Wait For Interrupt
  55. #else
  56. mcr p15, 0, tmp1, c7, c0, 4
  57. #endif
  58. .endm
  59. .text
  60. .arm
  61. /*
  62. * void at91_pm_suspend_in_sram(void __iomem *pmc, void __iomem *sdramc,
  63. * void __iomem *ramc1, int memctrl)
  64. * @input param:
  65. * @r0: base address of AT91_PMC
  66. * @r1: base address of SDRAM Controller (SDRAM, DDRSDR, or AT91_SYS)
  67. * @r2: base address of second SDRAM Controller or 0 if not present
  68. * @r3: pm information
  69. */
  70. ENTRY(at91_pm_suspend_in_sram)
  71. /* Save registers on stack */
  72. stmfd sp!, {r4 - r12, lr}
  73. /* Drain write buffer */
  74. mov tmp1, #0
  75. mcr p15, 0, tmp1, c7, c10, 4
  76. str r0, .pmc_base
  77. str r1, .sramc_base
  78. str r2, .sramc1_base
  79. and r0, r3, #AT91_PM_MEMTYPE_MASK
  80. str r0, .memtype
  81. lsr r0, r3, #AT91_PM_MODE_OFFSET
  82. and r0, r0, #AT91_PM_MODE_MASK
  83. str r0, .pm_mode
  84. /* Active the self-refresh mode */
  85. mov r0, #SRAMC_SELF_FRESH_ACTIVE
  86. bl at91_sramc_self_refresh
  87. ldr r0, .pm_mode
  88. tst r0, #AT91_PM_SLOW_CLOCK
  89. beq skip_disable_main_clock
  90. ldr pmc, .pmc_base
  91. /* Save Master clock setting */
  92. ldr tmp1, [pmc, #AT91_PMC_MCKR]
  93. str tmp1, .saved_mckr
  94. /*
  95. * Set the Master clock source to slow clock
  96. */
  97. bic tmp1, tmp1, #AT91_PMC_CSS
  98. str tmp1, [pmc, #AT91_PMC_MCKR]
  99. wait_mckrdy
  100. /* Save PLLA setting and disable it */
  101. ldr tmp1, [pmc, #AT91_CKGR_PLLAR]
  102. str tmp1, .saved_pllar
  103. mov tmp1, #AT91_PMC_PLLCOUNT
  104. orr tmp1, tmp1, #(1 << 29) /* bit 29 always set */
  105. str tmp1, [pmc, #AT91_CKGR_PLLAR]
  106. /* Turn off the main oscillator */
  107. ldr tmp1, [pmc, #AT91_CKGR_MOR]
  108. bic tmp1, tmp1, #AT91_PMC_MOSCEN
  109. orr tmp1, tmp1, #AT91_PMC_KEY
  110. str tmp1, [pmc, #AT91_CKGR_MOR]
  111. skip_disable_main_clock:
  112. ldr pmc, .pmc_base
  113. /* Wait for interrupt */
  114. at91_cpu_idle
  115. ldr r0, .pm_mode
  116. tst r0, #AT91_PM_SLOW_CLOCK
  117. beq skip_enable_main_clock
  118. ldr pmc, .pmc_base
  119. /* Turn on the main oscillator */
  120. ldr tmp1, [pmc, #AT91_CKGR_MOR]
  121. orr tmp1, tmp1, #AT91_PMC_MOSCEN
  122. orr tmp1, tmp1, #AT91_PMC_KEY
  123. str tmp1, [pmc, #AT91_CKGR_MOR]
  124. wait_moscrdy
  125. /* Restore PLLA setting */
  126. ldr tmp1, .saved_pllar
  127. str tmp1, [pmc, #AT91_CKGR_PLLAR]
  128. tst tmp1, #(AT91_PMC_MUL & 0xff0000)
  129. bne 3f
  130. tst tmp1, #(AT91_PMC_MUL & ~0xff0000)
  131. beq 4f
  132. 3:
  133. wait_pllalock
  134. 4:
  135. /*
  136. * Restore master clock setting
  137. */
  138. ldr tmp1, .saved_mckr
  139. str tmp1, [pmc, #AT91_PMC_MCKR]
  140. wait_mckrdy
  141. skip_enable_main_clock:
  142. /* Exit the self-refresh mode */
  143. mov r0, #SRAMC_SELF_FRESH_EXIT
  144. bl at91_sramc_self_refresh
  145. /* Restore registers, and return */
  146. ldmfd sp!, {r4 - r12, pc}
  147. ENDPROC(at91_pm_suspend_in_sram)
  148. /*
  149. * void at91_sramc_self_refresh(unsigned int is_active)
  150. *
  151. * @input param:
  152. * @r0: 1 - active self-refresh mode
  153. * 0 - exit self-refresh mode
  154. * register usage:
  155. * @r1: memory type
  156. * @r2: base address of the sram controller
  157. */
  158. ENTRY(at91_sramc_self_refresh)
  159. ldr r1, .memtype
  160. ldr r2, .sramc_base
  161. cmp r1, #AT91_MEMCTRL_MC
  162. bne ddrc_sf
  163. /*
  164. * at91rm9200 Memory controller
  165. */
  166. /*
  167. * For exiting the self-refresh mode, do nothing,
  168. * automatically exit the self-refresh mode.
  169. */
  170. tst r0, #SRAMC_SELF_FRESH_ACTIVE
  171. beq exit_sramc_sf
  172. /* Active SDRAM self-refresh mode */
  173. mov r3, #1
  174. str r3, [r2, #AT91_MC_SDRAMC_SRR]
  175. b exit_sramc_sf
  176. ddrc_sf:
  177. cmp r1, #AT91_MEMCTRL_DDRSDR
  178. bne sdramc_sf
  179. /*
  180. * DDR Memory controller
  181. */
  182. tst r0, #SRAMC_SELF_FRESH_ACTIVE
  183. beq ddrc_exit_sf
  184. /* LPDDR1 --> force DDR2 mode during self-refresh */
  185. ldr r3, [r2, #AT91_DDRSDRC_MDR]
  186. str r3, .saved_sam9_mdr
  187. bic r3, r3, #~AT91_DDRSDRC_MD
  188. cmp r3, #AT91_DDRSDRC_MD_LOW_POWER_DDR
  189. ldreq r3, [r2, #AT91_DDRSDRC_MDR]
  190. biceq r3, r3, #AT91_DDRSDRC_MD
  191. orreq r3, r3, #AT91_DDRSDRC_MD_DDR2
  192. streq r3, [r2, #AT91_DDRSDRC_MDR]
  193. /* Active DDRC self-refresh mode */
  194. ldr r3, [r2, #AT91_DDRSDRC_LPR]
  195. str r3, .saved_sam9_lpr
  196. bic r3, r3, #AT91_DDRSDRC_LPCB
  197. orr r3, r3, #AT91_DDRSDRC_LPCB_SELF_REFRESH
  198. str r3, [r2, #AT91_DDRSDRC_LPR]
  199. /* If using the 2nd ddr controller */
  200. ldr r2, .sramc1_base
  201. cmp r2, #0
  202. beq no_2nd_ddrc
  203. ldr r3, [r2, #AT91_DDRSDRC_MDR]
  204. str r3, .saved_sam9_mdr1
  205. bic r3, r3, #~AT91_DDRSDRC_MD
  206. cmp r3, #AT91_DDRSDRC_MD_LOW_POWER_DDR
  207. ldreq r3, [r2, #AT91_DDRSDRC_MDR]
  208. biceq r3, r3, #AT91_DDRSDRC_MD
  209. orreq r3, r3, #AT91_DDRSDRC_MD_DDR2
  210. streq r3, [r2, #AT91_DDRSDRC_MDR]
  211. /* Active DDRC self-refresh mode */
  212. ldr r3, [r2, #AT91_DDRSDRC_LPR]
  213. str r3, .saved_sam9_lpr1
  214. bic r3, r3, #AT91_DDRSDRC_LPCB
  215. orr r3, r3, #AT91_DDRSDRC_LPCB_SELF_REFRESH
  216. str r3, [r2, #AT91_DDRSDRC_LPR]
  217. no_2nd_ddrc:
  218. b exit_sramc_sf
  219. ddrc_exit_sf:
  220. /* Restore MDR in case of LPDDR1 */
  221. ldr r3, .saved_sam9_mdr
  222. str r3, [r2, #AT91_DDRSDRC_MDR]
  223. /* Restore LPR on AT91 with DDRAM */
  224. ldr r3, .saved_sam9_lpr
  225. str r3, [r2, #AT91_DDRSDRC_LPR]
  226. /* If using the 2nd ddr controller */
  227. ldr r2, .sramc1_base
  228. cmp r2, #0
  229. ldrne r3, .saved_sam9_mdr1
  230. strne r3, [r2, #AT91_DDRSDRC_MDR]
  231. ldrne r3, .saved_sam9_lpr1
  232. strne r3, [r2, #AT91_DDRSDRC_LPR]
  233. b exit_sramc_sf
  234. /*
  235. * SDRAMC Memory controller
  236. */
  237. sdramc_sf:
  238. tst r0, #SRAMC_SELF_FRESH_ACTIVE
  239. beq sdramc_exit_sf
  240. /* Active SDRAMC self-refresh mode */
  241. ldr r3, [r2, #AT91_SDRAMC_LPR]
  242. str r3, .saved_sam9_lpr
  243. bic r3, r3, #AT91_SDRAMC_LPCB
  244. orr r3, r3, #AT91_SDRAMC_LPCB_SELF_REFRESH
  245. str r3, [r2, #AT91_SDRAMC_LPR]
  246. sdramc_exit_sf:
  247. ldr r3, .saved_sam9_lpr
  248. str r3, [r2, #AT91_SDRAMC_LPR]
  249. exit_sramc_sf:
  250. mov pc, lr
  251. ENDPROC(at91_sramc_self_refresh)
  252. .pmc_base:
  253. .word 0
  254. .sramc_base:
  255. .word 0
  256. .sramc1_base:
  257. .word 0
  258. .memtype:
  259. .word 0
  260. .pm_mode:
  261. .word 0
  262. .saved_mckr:
  263. .word 0
  264. .saved_pllar:
  265. .word 0
  266. .saved_sam9_lpr:
  267. .word 0
  268. .saved_sam9_lpr1:
  269. .word 0
  270. .saved_sam9_mdr:
  271. .word 0
  272. .saved_sam9_mdr1:
  273. .word 0
  274. ENTRY(at91_pm_suspend_in_sram_sz)
  275. .word .-at91_pm_suspend_in_sram