lowlevel_init.S 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693
  1. /*
  2. * Low-level board setup code for TI DaVinci SoC based boards.
  3. *
  4. * Copyright (C) 2007 Sergey Kubushyn <ksi@koi8.net>
  5. *
  6. * Partially based on TI sources, original copyrights follow:
  7. */
  8. /*
  9. * Board specific setup info
  10. *
  11. * (C) Copyright 2003
  12. * Texas Instruments, <www.ti.com>
  13. * Kshitij Gupta <Kshitij@ti.com>
  14. *
  15. * Modified for OMAP 1610 H2 board by Nishant Kamat, Jan 2004
  16. *
  17. * Modified for OMAP 5912 OSK board by Rishi Bhattacharya, Apr 2004
  18. *
  19. * Modified for DV-EVM board by Rishi Bhattacharya, Apr 2005
  20. *
  21. * Modified for DV-EVM board by Swaminathan S, Nov 2005
  22. *
  23. * SPDX-License-Identifier: GPL-2.0+
  24. */
  25. #include <config.h>
  26. #define MDSTAT_STATE 0x3f
  27. .globl lowlevel_init
  28. lowlevel_init:
  29. #ifdef CONFIG_SOC_DM644X
  30. /*-------------------------------------------------------*
  31. * Mask all IRQs by setting all bits in the EINT default *
  32. *-------------------------------------------------------*/
  33. mov r1, $0
  34. ldr r0, =EINT_ENABLE0
  35. str r1, [r0]
  36. ldr r0, =EINT_ENABLE1
  37. str r1, [r0]
  38. /*------------------------------------------------------*
  39. * Put the GEM in reset *
  40. *------------------------------------------------------*/
  41. /* Put the GEM in reset */
  42. ldr r8, PSC_GEM_FLAG_CLEAR
  43. ldr r6, MDCTL_GEM
  44. ldr r7, [r6]
  45. and r7, r7, r8
  46. str r7, [r6]
  47. /* Enable the Power Domain Transition Command */
  48. ldr r6, PTCMD
  49. ldr r7, [r6]
  50. orr r7, r7, $0x02
  51. str r7, [r6]
  52. /* Check for Transition Complete(PTSTAT) */
  53. checkStatClkStopGem:
  54. ldr r6, PTSTAT
  55. ldr r7, [r6]
  56. ands r7, r7, $0x02
  57. bne checkStatClkStopGem
  58. /* Check for GEM Reset Completion */
  59. checkGemStatClkStop:
  60. ldr r6, MDSTAT_GEM
  61. ldr r7, [r6]
  62. ands r7, r7, $0x100
  63. bne checkGemStatClkStop
  64. /* Do this for enabling a WDT initiated reset this is a workaround
  65. for a chip bug. Not required under normal situations */
  66. ldr r6, P1394
  67. mov r10, $0
  68. str r10, [r6]
  69. /*------------------------------------------------------*
  70. * Enable L1 & L2 Memories in Fast mode *
  71. *------------------------------------------------------*/
  72. ldr r6, DFT_ENABLE
  73. mov r10, $0x01
  74. str r10, [r6]
  75. ldr r6, MMARG_BRF0
  76. ldr r10, MMARG_BRF0_VAL
  77. str r10, [r6]
  78. ldr r6, DFT_ENABLE
  79. mov r10, $0
  80. str r10, [r6]
  81. /*------------------------------------------------------*
  82. * DDR2 PLL Initialization *
  83. *------------------------------------------------------*/
  84. /* Select the Clock Mode Depending on the Value written in the Boot Table by the run script */
  85. mov r10, $0
  86. ldr r6, PLL2_CTL
  87. ldr r7, PLL_CLKSRC_MASK
  88. ldr r8, [r6]
  89. and r8, r8, r7
  90. mov r9, r10, lsl $8
  91. orr r8, r8, r9
  92. str r8, [r6]
  93. /* Select the PLLEN source */
  94. ldr r7, PLL_ENSRC_MASK
  95. and r8, r8, r7
  96. str r8, [r6]
  97. /* Bypass the PLL */
  98. ldr r7, PLL_BYPASS_MASK
  99. and r8, r8, r7
  100. str r8, [r6]
  101. /* Wait for few cycles to allow PLLEN Mux switch properly to bypass Clock */
  102. mov r10, $0x20
  103. WaitPPL2Loop:
  104. subs r10, r10, $1
  105. bne WaitPPL2Loop
  106. /* Reset the PLL */
  107. ldr r7, PLL_RESET_MASK
  108. and r8, r8, r7
  109. str r8, [r6]
  110. /* Power up the PLL */
  111. ldr r7, PLL_PWRUP_MASK
  112. and r8, r8, r7
  113. str r8, [r6]
  114. /* Enable the PLL from Disable Mode */
  115. ldr r7, PLL_DISABLE_ENABLE_MASK
  116. and r8, r8, r7
  117. str r8, [r6]
  118. /* Program the PLL Multiplier */
  119. ldr r6, PLL2_PLLM
  120. mov r2, $0x17 /* 162 MHz */
  121. str r2, [r6]
  122. /* Program the PLL2 Divisor Value */
  123. ldr r6, PLL2_DIV2
  124. mov r3, $0x01
  125. str r3, [r6]
  126. /* Program the PLL2 Divisor Value */
  127. ldr r6, PLL2_DIV1
  128. mov r4, $0x0b /* 54 MHz */
  129. str r4, [r6]
  130. /* PLL2 DIV2 MMR */
  131. ldr r8, PLL2_DIV_MASK
  132. ldr r6, PLL2_DIV2
  133. ldr r9, [r6]
  134. and r8, r8, r9
  135. mov r9, $0x01
  136. mov r9, r9, lsl $15
  137. orr r8, r8, r9
  138. str r8, [r6]
  139. /* Program the GOSET bit to take new divider values */
  140. ldr r6, PLL2_PLLCMD
  141. ldr r7, [r6]
  142. orr r7, r7, $0x01
  143. str r7, [r6]
  144. /* Wait for Done */
  145. ldr r6, PLL2_PLLSTAT
  146. doneLoop_0:
  147. ldr r7, [r6]
  148. ands r7, r7, $0x01
  149. bne doneLoop_0
  150. /* PLL2 DIV1 MMR */
  151. ldr r8, PLL2_DIV_MASK
  152. ldr r6, PLL2_DIV1
  153. ldr r9, [r6]
  154. and r8, r8, r9
  155. mov r9, $0x01
  156. mov r9, r9, lsl $15
  157. orr r8, r8, r9
  158. str r8, [r6]
  159. /* Program the GOSET bit to take new divider values */
  160. ldr r6, PLL2_PLLCMD
  161. ldr r7, [r6]
  162. orr r7, r7, $0x01
  163. str r7, [r6]
  164. /* Wait for Done */
  165. ldr r6, PLL2_PLLSTAT
  166. doneLoop:
  167. ldr r7, [r6]
  168. ands r7, r7, $0x01
  169. bne doneLoop
  170. /* Wait for PLL to Reset Properly */
  171. mov r10, $0x218
  172. ResetPPL2Loop:
  173. subs r10, r10, $1
  174. bne ResetPPL2Loop
  175. /* Bring PLL out of Reset */
  176. ldr r6, PLL2_CTL
  177. ldr r8, [r6]
  178. orr r8, r8, $0x08
  179. str r8, [r6]
  180. /* Wait for PLL to Lock */
  181. ldr r10, PLL_LOCK_COUNT
  182. PLL2Lock:
  183. subs r10, r10, $1
  184. bne PLL2Lock
  185. /* Enable the PLL */
  186. ldr r6, PLL2_CTL
  187. ldr r8, [r6]
  188. orr r8, r8, $0x01
  189. str r8, [r6]
  190. /*------------------------------------------------------*
  191. * Issue Soft Reset to DDR Module *
  192. *------------------------------------------------------*/
  193. /* Shut down the DDR2 LPSC Module */
  194. ldr r8, PSC_FLAG_CLEAR
  195. ldr r6, MDCTL_DDR2
  196. ldr r7, [r6]
  197. and r7, r7, r8
  198. orr r7, r7, $0x03
  199. str r7, [r6]
  200. /* Enable the Power Domain Transition Command */
  201. ldr r6, PTCMD
  202. ldr r7, [r6]
  203. orr r7, r7, $0x01
  204. str r7, [r6]
  205. /* Check for Transition Complete(PTSTAT) */
  206. checkStatClkStop:
  207. ldr r6, PTSTAT
  208. ldr r7, [r6]
  209. ands r7, r7, $0x01
  210. bne checkStatClkStop
  211. /* Check for DDR2 Controller Enable Completion */
  212. checkDDRStatClkStop:
  213. ldr r6, MDSTAT_DDR2
  214. ldr r7, [r6]
  215. and r7, r7, $MDSTAT_STATE
  216. cmp r7, $0x03
  217. bne checkDDRStatClkStop
  218. /*------------------------------------------------------*
  219. * Program DDR2 MMRs for 162MHz Setting *
  220. *------------------------------------------------------*/
  221. /* Program PHY Control Register */
  222. ldr r6, DDRCTL
  223. ldr r7, DDRCTL_VAL
  224. str r7, [r6]
  225. /* Program SDRAM Bank Config Register */
  226. ldr r6, SDCFG
  227. ldr r7, SDCFG_VAL
  228. str r7, [r6]
  229. /* Program SDRAM TIM-0 Config Register */
  230. ldr r6, SDTIM0
  231. ldr r7, SDTIM0_VAL_162MHz
  232. str r7, [r6]
  233. /* Program SDRAM TIM-1 Config Register */
  234. ldr r6, SDTIM1
  235. ldr r7, SDTIM1_VAL_162MHz
  236. str r7, [r6]
  237. /* Program the SDRAM Bank Config Control Register */
  238. ldr r10, MASK_VAL
  239. ldr r8, SDCFG
  240. ldr r9, SDCFG_VAL
  241. and r9, r9, r10
  242. str r9, [r8]
  243. /* Program SDRAM SDREF Config Register */
  244. ldr r6, SDREF
  245. ldr r7, SDREF_VAL
  246. str r7, [r6]
  247. /*------------------------------------------------------*
  248. * Issue Soft Reset to DDR Module *
  249. *------------------------------------------------------*/
  250. /* Issue a Dummy DDR2 read/write */
  251. ldr r8, DDR2_START_ADDR
  252. ldr r7, DUMMY_VAL
  253. str r7, [r8]
  254. ldr r7, [r8]
  255. /* Shut down the DDR2 LPSC Module */
  256. ldr r8, PSC_FLAG_CLEAR
  257. ldr r6, MDCTL_DDR2
  258. ldr r7, [r6]
  259. and r7, r7, r8
  260. orr r7, r7, $0x01
  261. str r7, [r6]
  262. /* Enable the Power Domain Transition Command */
  263. ldr r6, PTCMD
  264. ldr r7, [r6]
  265. orr r7, r7, $0x01
  266. str r7, [r6]
  267. /* Check for Transition Complete(PTSTAT) */
  268. checkStatClkStop2:
  269. ldr r6, PTSTAT
  270. ldr r7, [r6]
  271. ands r7, r7, $0x01
  272. bne checkStatClkStop2
  273. /* Check for DDR2 Controller Enable Completion */
  274. checkDDRStatClkStop2:
  275. ldr r6, MDSTAT_DDR2
  276. ldr r7, [r6]
  277. and r7, r7, $MDSTAT_STATE
  278. cmp r7, $0x01
  279. bne checkDDRStatClkStop2
  280. /*------------------------------------------------------*
  281. * Turn DDR2 Controller Clocks On *
  282. *------------------------------------------------------*/
  283. /* Enable the DDR2 LPSC Module */
  284. ldr r6, MDCTL_DDR2
  285. ldr r7, [r6]
  286. orr r7, r7, $0x03
  287. str r7, [r6]
  288. /* Enable the Power Domain Transition Command */
  289. ldr r6, PTCMD
  290. ldr r7, [r6]
  291. orr r7, r7, $0x01
  292. str r7, [r6]
  293. /* Check for Transition Complete(PTSTAT) */
  294. checkStatClkEn2:
  295. ldr r6, PTSTAT
  296. ldr r7, [r6]
  297. ands r7, r7, $0x01
  298. bne checkStatClkEn2
  299. /* Check for DDR2 Controller Enable Completion */
  300. checkDDRStatClkEn2:
  301. ldr r6, MDSTAT_DDR2
  302. ldr r7, [r6]
  303. and r7, r7, $MDSTAT_STATE
  304. cmp r7, $0x03
  305. bne checkDDRStatClkEn2
  306. /* DDR Writes and Reads */
  307. ldr r6, CFGTEST
  308. mov r3, $0x01
  309. str r3, [r6]
  310. /*------------------------------------------------------*
  311. * System PLL Initialization *
  312. *------------------------------------------------------*/
  313. /* Select the Clock Mode Depending on the Value written in the Boot Table by the run script */
  314. mov r2, $0
  315. ldr r6, PLL1_CTL
  316. ldr r7, PLL_CLKSRC_MASK
  317. ldr r8, [r6]
  318. and r8, r8, r7
  319. mov r9, r2, lsl $8
  320. orr r8, r8, r9
  321. str r8, [r6]
  322. /* Select the PLLEN source */
  323. ldr r7, PLL_ENSRC_MASK
  324. and r8, r8, r7
  325. str r8, [r6]
  326. /* Bypass the PLL */
  327. ldr r7, PLL_BYPASS_MASK
  328. and r8, r8, r7
  329. str r8, [r6]
  330. /* Wait for few cycles to allow PLLEN Mux switch properly to bypass Clock */
  331. mov r10, $0x20
  332. WaitLoop:
  333. subs r10, r10, $1
  334. bne WaitLoop
  335. /* Reset the PLL */
  336. ldr r7, PLL_RESET_MASK
  337. and r8, r8, r7
  338. str r8, [r6]
  339. /* Disable the PLL */
  340. orr r8, r8, $0x10
  341. str r8, [r6]
  342. /* Power up the PLL */
  343. ldr r7, PLL_PWRUP_MASK
  344. and r8, r8, r7
  345. str r8, [r6]
  346. /* Enable the PLL from Disable Mode */
  347. ldr r7, PLL_DISABLE_ENABLE_MASK
  348. and r8, r8, r7
  349. str r8, [r6]
  350. /* Program the PLL Multiplier */
  351. ldr r6, PLL1_PLLM
  352. mov r3, $0x15 /* For 594MHz */
  353. str r3, [r6]
  354. /* Wait for PLL to Reset Properly */
  355. mov r10, $0xff
  356. ResetLoop:
  357. subs r10, r10, $1
  358. bne ResetLoop
  359. /* Bring PLL out of Reset */
  360. ldr r6, PLL1_CTL
  361. orr r8, r8, $0x08
  362. str r8, [r6]
  363. /* Wait for PLL to Lock */
  364. ldr r10, PLL_LOCK_COUNT
  365. PLL1Lock:
  366. subs r10, r10, $1
  367. bne PLL1Lock
  368. /* Enable the PLL */
  369. orr r8, r8, $0x01
  370. str r8, [r6]
  371. nop
  372. nop
  373. nop
  374. nop
  375. /*------------------------------------------------------*
  376. * AEMIF configuration for NOR Flash (double check) *
  377. *------------------------------------------------------*/
  378. ldr r0, _PINMUX0
  379. ldr r1, _DEV_SETTING
  380. str r1, [r0]
  381. ldr r0, WAITCFG
  382. ldr r1, WAITCFG_VAL
  383. ldr r2, [r0]
  384. orr r2, r2, r1
  385. str r2, [r0]
  386. ldr r0, ACFG3
  387. ldr r1, ACFG3_VAL
  388. ldr r2, [r0]
  389. and r1, r2, r1
  390. str r1, [r0]
  391. ldr r0, ACFG4
  392. ldr r1, ACFG4_VAL
  393. ldr r2, [r0]
  394. and r1, r2, r1
  395. str r1, [r0]
  396. ldr r0, ACFG5
  397. ldr r1, ACFG5_VAL
  398. ldr r2, [r0]
  399. and r1, r2, r1
  400. str r1, [r0]
  401. /*--------------------------------------*
  402. * VTP manual Calibration *
  403. *--------------------------------------*/
  404. ldr r0, VTPIOCR
  405. ldr r1, VTP_MMR0
  406. str r1, [r0]
  407. ldr r0, VTPIOCR
  408. ldr r1, VTP_MMR1
  409. str r1, [r0]
  410. /* Wait for 33 VTP CLK cycles. VRP operates at 27 MHz */
  411. ldr r10, VTP_LOCK_COUNT
  412. VTPLock:
  413. subs r10, r10, $1
  414. bne VTPLock
  415. ldr r6, DFT_ENABLE
  416. mov r10, $0x01
  417. str r10, [r6]
  418. ldr r6, DDRVTPR
  419. ldr r7, [r6]
  420. mov r8, r7, LSL #32-10
  421. mov r8, r8, LSR #32-10 /* grab low 10 bits */
  422. ldr r7, VTP_RECAL
  423. orr r8, r7, r8
  424. ldr r7, VTP_EN
  425. orr r8, r7, r8
  426. str r8, [r0]
  427. /* Wait for 33 VTP CLK cycles. VRP operates at 27 MHz */
  428. ldr r10, VTP_LOCK_COUNT
  429. VTP1Lock:
  430. subs r10, r10, $1
  431. bne VTP1Lock
  432. ldr r1, [r0]
  433. ldr r2, VTP_MASK
  434. and r2, r1, r2
  435. str r2, [r0]
  436. ldr r6, DFT_ENABLE
  437. mov r10, $0
  438. str r10, [r6]
  439. /*
  440. * Call board-specific lowlevel init.
  441. * That MUST be present and THAT returns
  442. * back to arch calling code with "mov pc, lr."
  443. */
  444. b dv_board_init
  445. .ltorg
  446. _PINMUX0:
  447. .word 0x01c40000 /* Device Configuration Registers */
  448. _PINMUX1:
  449. .word 0x01c40004 /* Device Configuration Registers */
  450. _DEV_SETTING:
  451. .word 0x00000c1f
  452. WAITCFG:
  453. .word 0x01e00004
  454. WAITCFG_VAL:
  455. .word 0
  456. ACFG3:
  457. .word 0x01e00014
  458. ACFG3_VAL:
  459. .word 0x3ffffffd
  460. ACFG4:
  461. .word 0x01e00018
  462. ACFG4_VAL:
  463. .word 0x3ffffffd
  464. ACFG5:
  465. .word 0x01e0001c
  466. ACFG5_VAL:
  467. .word 0x3ffffffd
  468. MDCTL_DDR2:
  469. .word 0x01c41a34
  470. MDSTAT_DDR2:
  471. .word 0x01c41834
  472. PTCMD:
  473. .word 0x01c41120
  474. PTSTAT:
  475. .word 0x01c41128
  476. EINT_ENABLE0:
  477. .word 0x01c48018
  478. EINT_ENABLE1:
  479. .word 0x01c4801c
  480. PSC_FLAG_CLEAR:
  481. .word 0xffffffe0
  482. PSC_GEM_FLAG_CLEAR:
  483. .word 0xfffffeff
  484. /* DDR2 MMR & CONFIGURATION VALUES, 162 MHZ clock */
  485. DDRCTL:
  486. .word 0x200000e4
  487. DDRCTL_VAL:
  488. .word 0x50006405
  489. SDREF:
  490. .word 0x2000000c
  491. SDREF_VAL:
  492. .word 0x000005c3
  493. SDCFG:
  494. .word 0x20000008
  495. SDCFG_VAL:
  496. #ifdef DDR_4BANKS
  497. .word 0x00178622
  498. #elif defined DDR_8BANKS
  499. .word 0x00178632
  500. #else
  501. #error "Unknown DDR configuration!!!"
  502. #endif
  503. SDTIM0:
  504. .word 0x20000010
  505. SDTIM0_VAL_162MHz:
  506. .word 0x28923211
  507. SDTIM1:
  508. .word 0x20000014
  509. SDTIM1_VAL_162MHz:
  510. .word 0x0016c722
  511. VTPIOCR:
  512. .word 0x200000f0 /* VTP IO Control register */
  513. DDRVTPR:
  514. .word 0x01c42030 /* DDR VPTR MMR */
  515. VTP_MMR0:
  516. .word 0x201f
  517. VTP_MMR1:
  518. .word 0xa01f
  519. DFT_ENABLE:
  520. .word 0x01c4004c
  521. VTP_LOCK_COUNT:
  522. .word 0x5b0
  523. VTP_MASK:
  524. .word 0xffffdfff
  525. VTP_RECAL:
  526. .word 0x08000
  527. VTP_EN:
  528. .word 0x02000
  529. CFGTEST:
  530. .word 0x80010000
  531. MASK_VAL:
  532. .word 0x00000fff
  533. /* GEM Power Up & LPSC Control Register */
  534. MDCTL_GEM:
  535. .word 0x01c41a9c
  536. MDSTAT_GEM:
  537. .word 0x01c4189c
  538. /* For WDT reset chip bug */
  539. P1394:
  540. .word 0x01c41a20
  541. PLL_CLKSRC_MASK:
  542. .word 0xfffffeff /* Mask the Clock Mode bit */
  543. PLL_ENSRC_MASK:
  544. .word 0xffffffdf /* Select the PLLEN source */
  545. PLL_BYPASS_MASK:
  546. .word 0xfffffffe /* Put the PLL in BYPASS */
  547. PLL_RESET_MASK:
  548. .word 0xfffffff7 /* Put the PLL in Reset Mode */
  549. PLL_PWRUP_MASK:
  550. .word 0xfffffffd /* PLL Power up Mask Bit */
  551. PLL_DISABLE_ENABLE_MASK:
  552. .word 0xffffffef /* Enable the PLL from Disable */
  553. PLL_LOCK_COUNT:
  554. .word 0x2000
  555. /* PLL1-SYSTEM PLL MMRs */
  556. PLL1_CTL:
  557. .word 0x01c40900
  558. PLL1_PLLM:
  559. .word 0x01c40910
  560. /* PLL2-SYSTEM PLL MMRs */
  561. PLL2_CTL:
  562. .word 0x01c40d00
  563. PLL2_PLLM:
  564. .word 0x01c40d10
  565. PLL2_DIV1:
  566. .word 0x01c40d18
  567. PLL2_DIV2:
  568. .word 0x01c40d1c
  569. PLL2_PLLCMD:
  570. .word 0x01c40d38
  571. PLL2_PLLSTAT:
  572. .word 0x01c40d3c
  573. PLL2_DIV_MASK:
  574. .word 0xffff7fff
  575. MMARG_BRF0:
  576. .word 0x01c42010 /* BRF margin mode 0 (R/W)*/
  577. MMARG_BRF0_VAL:
  578. .word 0x00444400
  579. DDR2_START_ADDR:
  580. .word 0x80000000
  581. DUMMY_VAL:
  582. .word 0xa55aa55a
  583. #else /* CONFIG_SOC_DM644X */
  584. mov pc, lr
  585. #endif