am437x.cfg 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003
  1. # SPDX-License-Identifier: GPL-2.0-or-later
  2. source [find target/icepick.cfg]
  3. source [find mem_helper.tcl]
  4. ###############################################################################
  5. ## AM437x Registers ##
  6. ###############################################################################
  7. set PRCM_BASE_ADDR 0x44df0000
  8. set REVISION_PRM [expr {$PRCM_BASE_ADDR + 0x0000}]
  9. set PRM_IRQSTATUS_MPU [expr {$PRCM_BASE_ADDR + 0x0004}]
  10. set PRM_IRQENABLE_MPU [expr {$PRCM_BASE_ADDR + 0x0008}]
  11. set PRM_IRQSTATUS_M3 [expr {$PRCM_BASE_ADDR + 0x000c}]
  12. set PRM_IRQENABLE_M3 [expr {$PRCM_BASE_ADDR + 0x0010}]
  13. set PM_MPU_PWRSTCTRL [expr {$PRCM_BASE_ADDR + 0x0300}]
  14. set PM_MPU_PWRSTST [expr {$PRCM_BASE_ADDR + 0x0304}]
  15. set RM_MPU_RSTST [expr {$PRCM_BASE_ADDR + 0x0314}]
  16. set RM_MPU_CONTEXT [expr {$PRCM_BASE_ADDR + 0x0324}]
  17. set PM_GFX_PWRSTCTRL [expr {$PRCM_BASE_ADDR + 0x0400}]
  18. set PM_GFX_PWRSTST [expr {$PRCM_BASE_ADDR + 0x0404}]
  19. set RM_GFX_RSTCTRL [expr {$PRCM_BASE_ADDR + 0x0410}]
  20. set RM_GFX_RSTST [expr {$PRCM_BASE_ADDR + 0x0414}]
  21. set RM_GFX_CONTEXT [expr {$PRCM_BASE_ADDR + 0x0424}]
  22. set RM_RTC_CONTEXT [expr {$PRCM_BASE_ADDR + 0x0524}]
  23. set RM_WKUP_RSTCTRL [expr {$PRCM_BASE_ADDR + 0x2010}]
  24. set RM_WKUP_RSTST [expr {$PRCM_BASE_ADDR + 0x2014}]
  25. set CM_L3_AON_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x2800}]
  26. set CM_WKUP_DEBUGSS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2820}]
  27. set CM_L3S_TSC_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x2900}]
  28. set CM_WKUP_ADC_TSC_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2920}]
  29. set CM_L4_WKUP_AON_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x2a00}]
  30. set CM_WKUP_L4WKUP_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a20}]
  31. set CM_WKUP_WKUP_M3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a28}]
  32. set CM_WKUP_SYNCTIMER_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a30}]
  33. set CM_WKUP_CLKDIV32K_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a38}]
  34. set CM_WKUP_USBPHY0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a40}]
  35. set CM_WKUP_USBPHY1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2a48}]
  36. set CM_WKUP_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x2b00}]
  37. set CM_WKUP_TIMER0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b20}]
  38. set CM_WKUP_TIMER1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b28}]
  39. set CM_WKUP_WDT0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b30}]
  40. set CM_WKUP_WDT1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b38}]
  41. set CM_WKUP_I2C0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b40}]
  42. set CM_WKUP_UART0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b48}]
  43. set CM_WKUP_SMARTREFLEX0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b50}]
  44. set CM_WKUP_SMARTREFLEX1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b58}]
  45. set CM_WKUP_CONTROL_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b60}]
  46. set CM_WKUP_GPIO0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x2b68}]
  47. set CM_CLKMODE_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d20}]
  48. set CM_IDLEST_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d24}]
  49. set CM_CLKSEL_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d2c}]
  50. set CM_DIV_M4_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d38}]
  51. set CM_DIV_M5_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d3c}]
  52. set CM_DIV_M6_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d40}]
  53. set CM_SSC_DELTAMSTEP_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d48}]
  54. set CM_SSC_MODFREQDIV_DPLL_CORE [expr {$PRCM_BASE_ADDR + 0x2d4c}]
  55. set CM_CLKMODE_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d60}]
  56. set CM_IDLEST_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d64}]
  57. set CM_CLKSEL_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d6c}]
  58. set CM_DIV_M2_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d70}]
  59. set CM_SSC_DELTAMSTEP_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d88}]
  60. set CM_SSC_MODFREQDIV_DPLL_MPU [expr {$PRCM_BASE_ADDR + 0x2d8c}]
  61. set CM_CLKMODE_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2da0}]
  62. set CM_IDLEST_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2da4}]
  63. set CM_CLKSEL_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2dac}]
  64. set CM_DIV_M2_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2db0}]
  65. set CM_DIV_M4_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2db8}]
  66. set CM_SSC_DELTAMSTEP_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2dc8}]
  67. set CM_SSC_MODFREQDIV_DPLL_DDR [expr {$PRCM_BASE_ADDR + 0x2dcc}]
  68. set CM_CLKMODE_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2de0}]
  69. set CM_IDLEST_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2de4}]
  70. set CM_CLKSEL_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2dec}]
  71. set CM_DIV_M2_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2df0}]
  72. set CM_CLKSEL2_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2e04}]
  73. set CM_SSC_DELTAMSTEP_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2e08}]
  74. set CM_SSC_MODFREQDIV_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2e0c}]
  75. set CM_CLKDCOLDO_DPLL_PER [expr {$PRCM_BASE_ADDR + 0x2e14}]
  76. set CM_CLKMODE_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e20}]
  77. set CM_IDLEST_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e24}]
  78. set CM_CLKSEL_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e2c}]
  79. set CM_DIV_M2_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e30}]
  80. set CM_SSC_DELTAMSTEP_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e48}]
  81. set CM_SSC_MODFREQDIV_DPLL_DISP [expr {$PRCM_BASE_ADDR + 0x2e4c}]
  82. set CM_CLKMODE_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e60}]
  83. set CM_IDLEST_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e64}]
  84. set CM_CLKSEL_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e6c}]
  85. set CM_DIV_M2_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e70}]
  86. set CM_CLKSEL2_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e84}]
  87. set CM_SSC_DELTAMSTEP_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e88}]
  88. set CM_SSC_MODFREQDIV_DPLL_EXTDEV [expr {$PRCM_BASE_ADDR + 0x2e8c}]
  89. set CM_SHADOW_FREQ_CONFIG1 [expr {$PRCM_BASE_ADDR + 0x2fa0}]
  90. set CM_SHADOW_FREQ_CONFIG2 [expr {$PRCM_BASE_ADDR + 0x2fa4}]
  91. set CM_CLKOUT1_CTRL [expr {$PRCM_BASE_ADDR + 0x4100}]
  92. set CM_DLL_CTRL [expr {$PRCM_BASE_ADDR + 0x4104}]
  93. set CM_CLKOUT2_CTRL [expr {$PRCM_BASE_ADDR + 0x4108}]
  94. set CLKSEL_TIMER1MS_CLK [expr {$PRCM_BASE_ADDR + 0x4200}]
  95. set CLKSEL_TIMER2_CLK [expr {$PRCM_BASE_ADDR + 0x4204}]
  96. set CLKSEL_TIMER3_CLK [expr {$PRCM_BASE_ADDR + 0x4208}]
  97. set CLKSEL_TIMER4_CLK [expr {$PRCM_BASE_ADDR + 0x420c}]
  98. set CLKSEL_TIMER5_CLK [expr {$PRCM_BASE_ADDR + 0x4210}]
  99. set CLKSEL_TIMER6_CLK [expr {$PRCM_BASE_ADDR + 0x4214}]
  100. set CLKSEL_TIMER7_CLK [expr {$PRCM_BASE_ADDR + 0x4218}]
  101. set CLKSEL_TIMER8_CLK [expr {$PRCM_BASE_ADDR + 0x421c}]
  102. set CLKSEL_TIMER9_CLK [expr {$PRCM_BASE_ADDR + 0x4220}]
  103. set CLKSEL_TIMER10_CLK [expr {$PRCM_BASE_ADDR + 0x4224}]
  104. set CLKSEL_TIMER11_CLK [expr {$PRCM_BASE_ADDR + 0x4228}]
  105. set CLKSEL_WDT1_CLK [expr {$PRCM_BASE_ADDR + 0x422c}]
  106. set CLKSEL_SYNCTIMER_CLK [expr {$PRCM_BASE_ADDR + 0x4230}]
  107. set CLKSEL_MAC_CLK [expr {$PRCM_BASE_ADDR + 0x4234}]
  108. set CLKSEL_CPTS_RFT_CLK [expr {$PRCM_BASE_ADDR + 0x4238}]
  109. set CLKSEL_GFX_FCLK [expr {$PRCM_BASE_ADDR + 0x423c}]
  110. set CLKSEL_GPIO0_DBCLK [expr {$PRCM_BASE_ADDR + 0x4240}]
  111. set CLKSEL_LCDC_PIXEL_CLK [expr {$PRCM_BASE_ADDR + 0x4244}]
  112. set CLKSEL_ICSS_OCP_CLK [expr {$PRCM_BASE_ADDR + 0x4248}]
  113. set CLKSEL_DLL_AGING_CLK [expr {$PRCM_BASE_ADDR + 0x4250}]
  114. set CLKSEL_USBPHY32KHZ_GCLK [expr {$PRCM_BASE_ADDR + 0x4260}]
  115. set CM_MPU_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8300}]
  116. set CM_MPU_MPU_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8320}]
  117. set CM_GFX_L3_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8400}]
  118. set CM_GFX_GFX_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8420}]
  119. set CM_RTC_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8500}]
  120. set CM_RTC_RTC_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8520}]
  121. set CM_PER_L3_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8800}]
  122. set CM_PER_L3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8820}]
  123. set CM_PER_AES0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8828}]
  124. set CM_PER_DES_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8830}]
  125. set CM_PER_CRYPTODMA_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8838}]
  126. set CM_PER_L3_INSTR_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8840}]
  127. set CM_PER_MSTR_EXPS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8848}]
  128. set CM_PER_OCMCRAM_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8850}]
  129. set CM_PER_SHA0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8858}]
  130. set CM_PER_SLV_EXPS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8860}]
  131. set CM_PER_VPFE0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8868}]
  132. set CM_PER_VPFE1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8870}]
  133. set CM_PER_TPCC_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8878}]
  134. set CM_PER_TPTC0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8880}]
  135. set CM_PER_TPTC1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8888}]
  136. set CM_PER_TPTC2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8890}]
  137. set CM_PER_DLL_AGING_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8898}]
  138. set CM_PER_L4HS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x88a0}]
  139. set CM_PER_L4FW_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x88a8}]
  140. set CM_PER_L3S_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8a00}]
  141. set CM_PER_GPMC_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a20}]
  142. set CM_PER_IEEE5000_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a28}]
  143. set CM_PER_MCASP0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a38}]
  144. set CM_PER_MCASP1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a40}]
  145. set CM_PER_MMC2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a48}]
  146. set CM_PER_QSPI_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a58}]
  147. set CM_PER_USB_OTG_SS0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a60}]
  148. set CM_PER_USB_OTG_SS1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8a68}]
  149. set CM_PER_ICSS_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8b00}]
  150. set CM_PER_ICSS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8b20}]
  151. set CM_PER_L4LS_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8c00}]
  152. set CM_PER_L4LS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c20}]
  153. set CM_PER_DCAN0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c28}]
  154. set CM_PER_DCAN1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c30}]
  155. set CM_PER_EPWMSS0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c38}]
  156. set CM_PER_EPWMSS1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c40}]
  157. set CM_PER_EPWMSS2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c48}]
  158. set CM_PER_EPWMSS3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c50}]
  159. set CM_PER_EPWMSS4_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c58}]
  160. set CM_PER_EPWMSS5_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c60}]
  161. set CM_PER_ELM_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c68}]
  162. set CM_PER_GPIO1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c78}]
  163. set CM_PER_GPIO2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c80}]
  164. set CM_PER_GPIO3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c88}]
  165. set CM_PER_GPIO4_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c90}]
  166. set CM_PER_GPIO5_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8c98}]
  167. set CM_PER_HDQ1W_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8ca0}]
  168. set CM_PER_I2C1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8ca8}]
  169. set CM_PER_I2C2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cb0}]
  170. set CM_PER_MAILBOX0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cb8}]
  171. set CM_PER_MMC0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cc0}]
  172. set CM_PER_MMC1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cc8}]
  173. set CM_PER_PKA_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cd0}]
  174. set CM_PER_RNG_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8ce0}]
  175. set CM_PER_SPARE0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8ce8}]
  176. set CM_PER_SPARE1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8cf0}]
  177. set CM_PER_SPI0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d00}]
  178. set CM_PER_SPI1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d08}]
  179. set CM_PER_SPI2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d10}]
  180. set CM_PER_SPI3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d18}]
  181. set CM_PER_SPI4_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d20}]
  182. set CM_PER_SPINLOCK_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d28}]
  183. set CM_PER_TIMER2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d30}]
  184. set CM_PER_TIMER3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d38}]
  185. set CM_PER_TIMER4_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d40}]
  186. set CM_PER_TIMER5_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d48}]
  187. set CM_PER_TIMER6_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d50}]
  188. set CM_PER_TIMER7_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d58}]
  189. set CM_PER_TIMER8_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d60}]
  190. set CM_PER_TIMER9_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d68}]
  191. set CM_PER_TIMER10_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d70}]
  192. set CM_PER_TIMER11_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d78}]
  193. set CM_PER_UART1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d80}]
  194. set CM_PER_UART2_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d88}]
  195. set CM_PER_UART3_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d90}]
  196. set CM_PER_UART4_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8d98}]
  197. set CM_PER_UART5_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8da0}]
  198. set CM_PER_USBPHYOCP2SCP0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8db8}]
  199. set CM_PER_USBPHYOCP2SCP1_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8dc0}]
  200. set CM_PER_EMIF_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x8f00}]
  201. set CM_PER_EMIF_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8f20}]
  202. set CM_PER_DLL_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8f28}]
  203. set CM_PER_EMIF_FW_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8f30}]
  204. set CM_PER_OTFA_EMIF_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x8f38}]
  205. set CM_PER_DSS_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x9200}]
  206. set CM_PER_DSS_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x9220}]
  207. set CM_PER_CPSW_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x9300}]
  208. set CM_PER_CPGMAC0_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x9320}]
  209. set CM_PER_OCPWP_L3_CLKSTCTRL [expr {$PRCM_BASE_ADDR + 0x9400}]
  210. set CM_PER_OCPWP_CLKCTRL [expr {$PRCM_BASE_ADDR + 0x9420}]
  211. set CONTROL_BASE_ADDR 0x44e10000
  212. set CONTROL_STATUS [expr {$CONTROL_BASE_ADDR + 0x0040}]
  213. set DEVICE_ID [expr {$CONTROL_BASE_ADDR + 0x0600}]
  214. set DEV_FEATURE [expr {$CONTROL_BASE_ADDR + 0x0604}]
  215. set DEV_ATTRIBUTE [expr {$CONTROL_BASE_ADDR + 0x0610}]
  216. set MAC_ID0_LO [expr {$CONTROL_BASE_ADDR + 0x0630}]
  217. set MAC_ID0_HI [expr {$CONTROL_BASE_ADDR + 0x0634}]
  218. set MAC_ID1_LO [expr {$CONTROL_BASE_ADDR + 0x0638}]
  219. set MAC_ID1_HI [expr {$CONTROL_BASE_ADDR + 0x063c}]
  220. set USB_VID_PID [expr {$CONTROL_BASE_ADDR + 0x07f4}]
  221. set CONTROL_CONF_ECAP0_IN_PWM0_OUT [expr {$CONTROL_BASE_ADDR + 0x0964}]
  222. set CONTROL_CONF_SPI4_CS0 [expr {$CONTROL_BASE_ADDR + 0x0a5c}]
  223. set CONTROL_CONF_SPI2_SCLK [expr {$CONTROL_BASE_ADDR + 0x0a60}]
  224. set CONTROL_CONF_SPI2_D0 [expr {$CONTROL_BASE_ADDR + 0x0a64}]
  225. set CONTROL_CONF_XDMA_EVENT_INTR0 [expr {$CONTROL_BASE_ADDR + 0x0a70}]
  226. set CONTROL_CONF_XDMA_EVENT_INTR1 [expr {$CONTROL_BASE_ADDR + 0x0a74}]
  227. set CONTROL_CONF_GPMC_A0 [expr {$CONTROL_BASE_ADDR + 0x0840}]
  228. set DDR_IO_CTRL [expr {$CONTROL_BASE_ADDR + 0x0e04}]
  229. set VTP_CTRL_REG [expr {$CONTROL_BASE_ADDR + 0x0e0c}]
  230. set VREF_CTRL [expr {$CONTROL_BASE_ADDR + 0x0e14}]
  231. set DDR_CKE_CTRL [expr {$CONTROL_BASE_ADDR + 0x131c}]
  232. set DDR_ADDRCTRL_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x1404}]
  233. set DDR_ADDRCTRL_WD0_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x1408}]
  234. set DDR_ADDRCTRL_WD1_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x140c}]
  235. set DDR_DATA0_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x1440}]
  236. set DDR_DATA1_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x1444}]
  237. set DDR_DATA2_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x1448}]
  238. set DDR_DATA3_IOCTRL [expr {$CONTROL_BASE_ADDR + 0x144c}]
  239. set EMIF_SDRAM_CONFIG_EXT [expr {$CONTROL_BASE_ADDR + 0x1460}]
  240. set EMIF_SDRAM_STATUS_EXT [expr {$CONTROL_BASE_ADDR + 0x1464}]
  241. set GPIO0_BASE_ADDR 0x44e07000
  242. set GPIO0_SYSCONFIG [expr {$GPIO0_BASE_ADDR + 0x0010}]
  243. set GPIO0_SYSSTATUS [expr {$GPIO0_BASE_ADDR + 0x0114}]
  244. set GPIO0_CTRL [expr {$GPIO0_BASE_ADDR + 0x0130}]
  245. set GPIO0_OE [expr {$GPIO0_BASE_ADDR + 0x0134}]
  246. set GPIO0_CLEARDATAOUT [expr {$GPIO0_BASE_ADDR + 0x0190}]
  247. set GPIO0_SETDATAOUT [expr {$GPIO0_BASE_ADDR + 0x0194}]
  248. set GPIO5_BASE_ADDR 0x48322000
  249. set GPIO5_SYSCONFIG [expr {$GPIO5_BASE_ADDR + 0x0010}]
  250. set GPIO5_SYSSTATUS [expr {$GPIO5_BASE_ADDR + 0x0114}]
  251. set GPIO5_CTRL [expr {$GPIO5_BASE_ADDR + 0x0130}]
  252. set GPIO5_OE [expr {$GPIO5_BASE_ADDR + 0x0134}]
  253. set GPIO5_CLEARDATAOUT [expr {$GPIO5_BASE_ADDR + 0x0190}]
  254. set GPIO5_SETDATAOUT [expr {$GPIO5_BASE_ADDR + 0x0194}]
  255. set GPIO1_BASE_ADDR 0x4804c000
  256. set GPIO1_SYSCONFIG [expr {$GPIO1_BASE_ADDR + 0x0010}]
  257. set GPIO1_SYSSTATUS [expr {$GPIO1_BASE_ADDR + 0x0114}]
  258. set GPIO1_CTRL [expr {$GPIO1_BASE_ADDR + 0x0130}]
  259. set GPIO1_OE [expr {$GPIO1_BASE_ADDR + 0x0134}]
  260. set GPIO1_CLEARDATAOUT [expr {$GPIO1_BASE_ADDR + 0x0190}]
  261. set GPIO1_SETDATAOUT [expr {$GPIO1_BASE_ADDR + 0x0194}]
  262. set EMIF_BASE_ADDR 0x4c000000
  263. set EMIF_STATUS [expr {$EMIF_BASE_ADDR + 0x0004}]
  264. set EMIF_SDRAM_CONFIG [expr {$EMIF_BASE_ADDR + 0x0008}]
  265. set EMIF_SDRAM_CONFIG_2 [expr {$EMIF_BASE_ADDR + 0x000c}]
  266. set EMIF_SDRAM_REF_CTRL [expr {$EMIF_BASE_ADDR + 0x0010}]
  267. set EMIF_SDRAM_REF_CTRL_SHDW [expr {$EMIF_BASE_ADDR + 0x0014}]
  268. set EMIF_SDRAM_TIM_1 [expr {$EMIF_BASE_ADDR + 0x0018}]
  269. set EMIF_SDRAM_TIM_1_SHDW [expr {$EMIF_BASE_ADDR + 0x001c}]
  270. set EMIF_SDRAM_TIM_2 [expr {$EMIF_BASE_ADDR + 0x0020}]
  271. set EMIF_SDRAM_TIM_2_SHDW [expr {$EMIF_BASE_ADDR + 0x0024}]
  272. set EMIF_SDRAM_TIM_3 [expr {$EMIF_BASE_ADDR + 0x0028}]
  273. set EMIF_SDRAM_TIM_3_SHDW [expr {$EMIF_BASE_ADDR + 0x002c}]
  274. set EMIF_LPDDR2_NVM_TIM [expr {$EMIF_BASE_ADDR + 0x0030}]
  275. set EMIF_LPDDR2_NVM_TIM_SHDW [expr {$EMIF_BASE_ADDR + 0x0034}]
  276. set EMIF_PWR_MGMT_CTRL [expr {$EMIF_BASE_ADDR + 0x0038}]
  277. set EMIF_PWR_MGMT_CTRL_SHDW [expr {$EMIF_BASE_ADDR + 0x003c}]
  278. set EMIF_LPDDR2_MODE_REG_DATA [expr {$EMIF_BASE_ADDR + 0x0040}]
  279. set EMIF_LPDDR2_MODE_REG_CFG [expr {$EMIF_BASE_ADDR + 0x0050}]
  280. set EMIF_OCP_CONFIG [expr {$EMIF_BASE_ADDR + 0x0054}]
  281. set EMIF_OCP_CFG_VAL_1 [expr {$EMIF_BASE_ADDR + 0x0058}]
  282. set EMIF_OCP_CFG_VAL_2 [expr {$EMIF_BASE_ADDR + 0x005c}]
  283. set EMIF_IODFT_TLGC [expr {$EMIF_BASE_ADDR + 0x0060}]
  284. set EMIF_IODFT_CTRL_MISR_RSLT [expr {$EMIF_BASE_ADDR + 0x0064}]
  285. set EMIF_IODFT_ADDR_MISR_RSLT [expr {$EMIF_BASE_ADDR + 0x0068}]
  286. set EMIF_IODFT_DATA_MISR_RSLT_1 [expr {$EMIF_BASE_ADDR + 0x006c}]
  287. set EMIF_IODFT_DATA_MISR_RSLT_2 [expr {$EMIF_BASE_ADDR + 0x0070}]
  288. set EMIF_IODFT_DATA_MISR_RSLT_3 [expr {$EMIF_BASE_ADDR + 0x0074}]
  289. set EMIF_PERF_CNT_1 [expr {$EMIF_BASE_ADDR + 0x0080}]
  290. set EMIF_PERF_CNT_2 [expr {$EMIF_BASE_ADDR + 0x0084}]
  291. set EMIF_PERF_CNT_CFG [expr {$EMIF_BASE_ADDR + 0x0088}]
  292. set EMIF_PERF_CNT_SEL [expr {$EMIF_BASE_ADDR + 0x008c}]
  293. set EMIF_PERF_CNT_TIM [expr {$EMIF_BASE_ADDR + 0x0090}]
  294. set EMIF_MISC_REG [expr {$EMIF_BASE_ADDR + 0x0094}]
  295. set EMIF_DLL_CALIB_CTRL [expr {$EMIF_BASE_ADDR + 0x0098}]
  296. set EMIF_DLL_CALIB_CTRL_SHDW [expr {$EMIF_BASE_ADDR + 0x009c}]
  297. set EMIF_IRQ_EOI [expr {$EMIF_BASE_ADDR + 0x00a0}]
  298. set EMIF_IRQSTATUS_RAW_SYS [expr {$EMIF_BASE_ADDR + 0x00a4}]
  299. set EMIF_IRQSTATUS_SYS [expr {$EMIF_BASE_ADDR + 0x00ac}]
  300. set EMIF_IRQENABLE_SET_SYS [expr {$EMIF_BASE_ADDR + 0x00b4}]
  301. set EMIF_IRQENABLE_CLR_SYS [expr {$EMIF_BASE_ADDR + 0x00bc}]
  302. set EMIF_ZQ_CONFIG [expr {$EMIF_BASE_ADDR + 0x00c8}]
  303. set EMIF_TEMP_ALERT_CONFIG [expr {$EMIF_BASE_ADDR + 0x00cc}]
  304. set EMIF_OCP_ERR_LOG [expr {$EMIF_BASE_ADDR + 0x00d0}]
  305. set EMIF_RDWR_LVL_RMP_WIN [expr {$EMIF_BASE_ADDR + 0x00d4}]
  306. set EMIF_RDWR_LVL_RMP_CTRL [expr {$EMIF_BASE_ADDR + 0x00d8}]
  307. set EMIF_RDWR_LVL_CTRL [expr {$EMIF_BASE_ADDR + 0x00dc}]
  308. set EMIF_DDR_PHY_CTRL_1 [expr {$EMIF_BASE_ADDR + 0x00e4}]
  309. set EMIF_DDR_PHY_CTRL_1_SHDW [expr {$EMIF_BASE_ADDR + 0x00e8}]
  310. set EMIF_DDR_PHY_CTRL_2 [expr {$EMIF_BASE_ADDR + 0x00ec}]
  311. set EMIF_PRI_COS_MAP [expr {$EMIF_BASE_ADDR + 0x0100}]
  312. set EMIF_CONNID_COS_1_MAP [expr {$EMIF_BASE_ADDR + 0x0104}]
  313. set EMIF_CONNID_COS_2_MAP [expr {$EMIF_BASE_ADDR + 0x0108}]
  314. set ECC_CTRL [expr {$EMIF_BASE_ADDR + 0x0110}]
  315. set ECC_ADDR_RNG_1 [expr {$EMIF_BASE_ADDR + 0x0114}]
  316. set ECC_ADDR_RNG_2 [expr {$EMIF_BASE_ADDR + 0x0118}]
  317. set EMIF_RD_WR_EXEC_THRSH [expr {$EMIF_BASE_ADDR + 0x0120}]
  318. set COS_CONFIG [expr {$EMIF_BASE_ADDR + 0x0124}]
  319. set PHY_STATUS_1 [expr {$EMIF_BASE_ADDR + 0x0144}]
  320. set PHY_STATUS_2 [expr {$EMIF_BASE_ADDR + 0x0148}]
  321. set PHY_STATUS_3 [expr {$EMIF_BASE_ADDR + 0x014c}]
  322. set PHY_STATUS_4 [expr {$EMIF_BASE_ADDR + 0x0150}]
  323. set PHY_STATUS_5 [expr {$EMIF_BASE_ADDR + 0x0154}]
  324. set PHY_STATUS_6 [expr {$EMIF_BASE_ADDR + 0x0158}]
  325. set PHY_STATUS_7 [expr {$EMIF_BASE_ADDR + 0x015c}]
  326. set PHY_STATUS_8 [expr {$EMIF_BASE_ADDR + 0x0160}]
  327. set PHY_STATUS_9 [expr {$EMIF_BASE_ADDR + 0x0164}]
  328. set PHY_STATUS_10 [expr {$EMIF_BASE_ADDR + 0x0168}]
  329. set PHY_STATUS_11 [expr {$EMIF_BASE_ADDR + 0x016c}]
  330. set PHY_STATUS_12 [expr {$EMIF_BASE_ADDR + 0x0170}]
  331. set PHY_STATUS_13 [expr {$EMIF_BASE_ADDR + 0x0174}]
  332. set PHY_STATUS_14 [expr {$EMIF_BASE_ADDR + 0x0178}]
  333. set PHY_STATUS_15 [expr {$EMIF_BASE_ADDR + 0x017c}]
  334. set PHY_STATUS_16 [expr {$EMIF_BASE_ADDR + 0x0180}]
  335. set PHY_STATUS_17 [expr {$EMIF_BASE_ADDR + 0x0184}]
  336. set PHY_STATUS_18 [expr {$EMIF_BASE_ADDR + 0x0188}]
  337. set PHY_STATUS_19 [expr {$EMIF_BASE_ADDR + 0x018c}]
  338. set PHY_STATUS_20 [expr {$EMIF_BASE_ADDR + 0x0190}]
  339. set PHY_STATUS_21 [expr {$EMIF_BASE_ADDR + 0x0194}]
  340. set PHY_STATUS_22 [expr {$EMIF_BASE_ADDR + 0x0198}]
  341. set PHY_STATUS_23 [expr {$EMIF_BASE_ADDR + 0x019c}]
  342. set PHY_STATUS_24 [expr {$EMIF_BASE_ADDR + 0x01a0}]
  343. set PHY_STATUS_25 [expr {$EMIF_BASE_ADDR + 0x01a4}]
  344. set PHY_STATUS_26 [expr {$EMIF_BASE_ADDR + 0x01a8}]
  345. set PHY_STATUS_27 [expr {$EMIF_BASE_ADDR + 0x01ac}]
  346. set PHY_STATUS_28 [expr {$EMIF_BASE_ADDR + 0x01b0}]
  347. set EXT_PHY_CTRL_1 [expr {$EMIF_BASE_ADDR + 0x0200}]
  348. set EXT_PHY_CTRL_1_SHDW [expr {$EMIF_BASE_ADDR + 0x0204}]
  349. set EXT_PHY_CTRL_2 [expr {$EMIF_BASE_ADDR + 0x0208}]
  350. set EXT_PHY_CTRL_2_SHDW [expr {$EMIF_BASE_ADDR + 0x020c}]
  351. set EXT_PHY_CTRL_3 [expr {$EMIF_BASE_ADDR + 0x0210}]
  352. set EXT_PHY_CTRL_3_SHDW [expr {$EMIF_BASE_ADDR + 0x0214}]
  353. set EXT_PHY_CTRL_4 [expr {$EMIF_BASE_ADDR + 0x0218}]
  354. set EXT_PHY_CTRL_4_SHDW [expr {$EMIF_BASE_ADDR + 0x021c}]
  355. set EXT_PHY_CTRL_5 [expr {$EMIF_BASE_ADDR + 0x0220}]
  356. set EXT_PHY_CTRL_5_SHDW [expr {$EMIF_BASE_ADDR + 0x0224}]
  357. set EXT_PHY_CTRL_6 [expr {$EMIF_BASE_ADDR + 0x0228}]
  358. set EXT_PHY_CTRL_6_SHDW [expr {$EMIF_BASE_ADDR + 0x022c}]
  359. set EXT_PHY_CTRL_7 [expr {$EMIF_BASE_ADDR + 0x0230}]
  360. set EXT_PHY_CTRL_7_SHDW [expr {$EMIF_BASE_ADDR + 0x0234}]
  361. set EXT_PHY_CTRL_8 [expr {$EMIF_BASE_ADDR + 0x0238}]
  362. set EXT_PHY_CTRL_8_SHDW [expr {$EMIF_BASE_ADDR + 0x023c}]
  363. set EXT_PHY_CTRL_9 [expr {$EMIF_BASE_ADDR + 0x0240}]
  364. set EXT_PHY_CTRL_9_SHDW [expr {$EMIF_BASE_ADDR + 0x0244}]
  365. set EXT_PHY_CTRL_10 [expr {$EMIF_BASE_ADDR + 0x0248}]
  366. set EXT_PHY_CTRL_10_SHDW [expr {$EMIF_BASE_ADDR + 0x024c}]
  367. set EXT_PHY_CTRL_11 [expr {$EMIF_BASE_ADDR + 0x0250}]
  368. set EXT_PHY_CTRL_11_SHDW [expr {$EMIF_BASE_ADDR + 0x0254}]
  369. set EXT_PHY_CTRL_12 [expr {$EMIF_BASE_ADDR + 0x0258}]
  370. set EXT_PHY_CTRL_12_SHDW [expr {$EMIF_BASE_ADDR + 0x025c}]
  371. set EXT_PHY_CTRL_13 [expr {$EMIF_BASE_ADDR + 0x0260}]
  372. set EXT_PHY_CTRL_13_SHDW [expr {$EMIF_BASE_ADDR + 0x0264}]
  373. set EXT_PHY_CTRL_14 [expr {$EMIF_BASE_ADDR + 0x0268}]
  374. set EXT_PHY_CTRL_14_SHDW [expr {$EMIF_BASE_ADDR + 0x026c}]
  375. set EXT_PHY_CTRL_15 [expr {$EMIF_BASE_ADDR + 0x0270}]
  376. set EXT_PHY_CTRL_15_SHDW [expr {$EMIF_BASE_ADDR + 0x0274}]
  377. set EXT_PHY_CTRL_16 [expr {$EMIF_BASE_ADDR + 0x0278}]
  378. set EXT_PHY_CTRL_16_SHDW [expr {$EMIF_BASE_ADDR + 0x027c}]
  379. set EXT_PHY_CTRL_17 [expr {$EMIF_BASE_ADDR + 0x0280}]
  380. set EXT_PHY_CTRL_17_SHDW [expr {$EMIF_BASE_ADDR + 0x0284}]
  381. set EXT_PHY_CTRL_18 [expr {$EMIF_BASE_ADDR + 0x0288}]
  382. set EXT_PHY_CTRL_18_SHDW [expr {$EMIF_BASE_ADDR + 0x028c}]
  383. set EXT_PHY_CTRL_19 [expr {$EMIF_BASE_ADDR + 0x0290}]
  384. set EXT_PHY_CTRL_19_SHDW [expr {$EMIF_BASE_ADDR + 0x0294}]
  385. set EXT_PHY_CTRL_20 [expr {$EMIF_BASE_ADDR + 0x0298}]
  386. set EXT_PHY_CTRL_20_SHDW [expr {$EMIF_BASE_ADDR + 0x029c}]
  387. set EXT_PHY_CTRL_21 [expr {$EMIF_BASE_ADDR + 0x02a0}]
  388. set EXT_PHY_CTRL_21_SHDW [expr {$EMIF_BASE_ADDR + 0x02a4}]
  389. set EXT_PHY_CTRL_22 [expr {$EMIF_BASE_ADDR + 0x02a8}]
  390. set EXT_PHY_CTRL_22_SHDW [expr {$EMIF_BASE_ADDR + 0x02ac}]
  391. set EXT_PHY_CTRL_23 [expr {$EMIF_BASE_ADDR + 0x02b0}]
  392. set EXT_PHY_CTRL_23_SHDW [expr {$EMIF_BASE_ADDR + 0x02b4}]
  393. set EXT_PHY_CTRL_24 [expr {$EMIF_BASE_ADDR + 0x02b8}]
  394. set EXT_PHY_CTRL_24_SHDW [expr {$EMIF_BASE_ADDR + 0x02bc}]
  395. set EXT_PHY_CTRL_25 [expr {$EMIF_BASE_ADDR + 0x02c0}]
  396. set EXT_PHY_CTRL_25_SHDW [expr {$EMIF_BASE_ADDR + 0x02c4}]
  397. set EXT_PHY_CTRL_26 [expr {$EMIF_BASE_ADDR + 0x02c8}]
  398. set EXT_PHY_CTRL_26_SHDW [expr {$EMIF_BASE_ADDR + 0x02cc}]
  399. set EXT_PHY_CTRL_27 [expr {$EMIF_BASE_ADDR + 0x02d0}]
  400. set EXT_PHY_CTRL_27_SHDW [expr {$EMIF_BASE_ADDR + 0x02d4}]
  401. set EXT_PHY_CTRL_28 [expr {$EMIF_BASE_ADDR + 0x02d8}]
  402. set EXT_PHY_CTRL_28_SHDW [expr {$EMIF_BASE_ADDR + 0x02dc}]
  403. set EXT_PHY_CTRL_29 [expr {$EMIF_BASE_ADDR + 0x02e0}]
  404. set EXT_PHY_CTRL_29_SHDW [expr {$EMIF_BASE_ADDR + 0x02e4}]
  405. set EXT_PHY_CTRL_30 [expr {$EMIF_BASE_ADDR + 0x02e8}]
  406. set EXT_PHY_CTRL_30_SHDW [expr {$EMIF_BASE_ADDR + 0x02ec}]
  407. set EXT_PHY_CTRL_31 [expr {$EMIF_BASE_ADDR + 0x02f0}]
  408. set EXT_PHY_CTRL_31_SHDW [expr {$EMIF_BASE_ADDR + 0x02f4}]
  409. set EXT_PHY_CTRL_32 [expr {$EMIF_BASE_ADDR + 0x02f8}]
  410. set EXT_PHY_CTRL_32_SHDW [expr {$EMIF_BASE_ADDR + 0x02fc}]
  411. set EXT_PHY_CTRL_33 [expr {$EMIF_BASE_ADDR + 0x0300}]
  412. set EXT_PHY_CTRL_33_SHDW [expr {$EMIF_BASE_ADDR + 0x0304}]
  413. set EXT_PHY_CTRL_34 [expr {$EMIF_BASE_ADDR + 0x0308}]
  414. set EXT_PHY_CTRL_34_SHDW [expr {$EMIF_BASE_ADDR + 0x030c}]
  415. set EXT_PHY_CTRL_35 [expr {$EMIF_BASE_ADDR + 0x0310}]
  416. set EXT_PHY_CTRL_35_SHDW [expr {$EMIF_BASE_ADDR + 0x0314}]
  417. set EXT_PHY_CTRL_36 [expr {$EMIF_BASE_ADDR + 0x0318}]
  418. set EXT_PHY_CTRL_36_SHDW [expr {$EMIF_BASE_ADDR + 0x031c}]
  419. set WDT1_BASE_ADDR 0x44e35000
  420. set WDT1_W_PEND_WSPR [expr {$WDT1_BASE_ADDR + 0x0034}]
  421. set WDT1_WSPR [expr {$WDT1_BASE_ADDR + 0x0048}]
  422. set RTC_BASE_ADDR 0x44e3e000
  423. set RTC_KICK0R [expr {$RTC_BASE_ADDR + 0x6c}]
  424. set RTC_KICK1R [expr {$RTC_BASE_ADDR + 0x70}]
  425. if { [info exists CHIPNAME] } {
  426. set _CHIPNAME $CHIPNAME
  427. } else {
  428. set _CHIPNAME am437x
  429. }
  430. set JRC_MODULE icepick_d
  431. set DEBUGSS_MODULE debugss
  432. set M3_MODULE m3_wakeupss
  433. set JRC_NAME $_CHIPNAME.$JRC_MODULE
  434. set DEBUGSS_NAME $_CHIPNAME.$DEBUGSS_MODULE
  435. set M3_NAME $_CHIPNAME.$M3_MODULE
  436. set _TARGETNAME $_CHIPNAME.mpuss
  437. #
  438. # M3 WakeupSS DAP
  439. #
  440. if { [info exists M3_DAP_TAPID] } {
  441. set _M3_DAP_TAPID $M3_DAP_TAPID
  442. } else {
  443. set _M3_DAP_TAPID 0x4b6b902f
  444. }
  445. jtag newtap $_CHIPNAME $M3_MODULE -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_M3_DAP_TAPID -disable
  446. jtag configure $M3_NAME -event tap-enable "icepick_d_tapenable $JRC_NAME 11 0"
  447. dap create $M3_NAME.dap -chain-position $M3_NAME
  448. #
  449. # DebugSS DAP
  450. #
  451. if { [info exists DAP_TAPID] } {
  452. set _DAP_TAPID $DAP_TAPID
  453. } else {
  454. set _DAP_TAPID 0x46b6902f
  455. }
  456. jtag newtap $_CHIPNAME $DEBUGSS_MODULE -irlen 4 -ircapture 0x1 -irmask 0xf -expected-id $_DAP_TAPID -disable
  457. jtag configure $DEBUGSS_NAME -event tap-enable "icepick_d_tapenable $JRC_NAME 12 0"
  458. dap create $DEBUGSS_NAME.dap -chain-position $DEBUGSS_NAME
  459. #
  460. # ICEpick-D (JTAG route controller)
  461. #
  462. if { [info exists JRC_TAPID] } {
  463. set _JRC_TAPID $JRC_TAPID
  464. } else {
  465. set _JRC_TAPID 0x0b98c02f
  466. }
  467. jtag newtap $_CHIPNAME $JRC_MODULE -irlen 6 -ircapture 0x1 -irmask 0x3f -expected-id $_JRC_TAPID -ignore-version
  468. jtag configure $JRC_NAME -event setup "jtag tapenable $DEBUGSS_NAME"
  469. # some TCK tycles are required to activate the DEBUG power domain
  470. jtag configure $JRC_NAME -event post-reset "runtest 100"
  471. #
  472. # Cortex-A9 target
  473. #
  474. target create $_TARGETNAME cortex_a -dap $DEBUGSS_NAME.dap -coreid 0 -dbgbase 0x80000000
  475. # SRAM: 256K at 0x4030.0000
  476. $_TARGETNAME configure -work-area-phys 0x40300000 -work-area-size 0x40000
  477. # Disables watchdog timer after reset otherwise board won't stay in
  478. # halted state.
  479. proc disable_watchdog { } {
  480. global WDT1_WSPR
  481. global WDT1_W_PEND_WSPR
  482. global _TARGETNAME
  483. set curstate [$_TARGETNAME curstate]
  484. if { [string compare $curstate halted] == 0 } {
  485. set WDT_DISABLE_SEQ1 0xaaaa
  486. set WDT_DISABLE_SEQ2 0x5555
  487. mww phys $WDT1_WSPR $WDT_DISABLE_SEQ1
  488. # Empty body to make sure this executes as fast as possible.
  489. # We don't want any delays here otherwise romcode might start
  490. # executing and end up changing state of certain IPs.
  491. while { [expr {[mrw $WDT1_W_PEND_WSPR] & 0x10}] } { }
  492. mww phys $WDT1_WSPR $WDT_DISABLE_SEQ2
  493. while { [expr {[mrw $WDT1_W_PEND_WSPR] & 0x10}] } { }
  494. }
  495. }
  496. proc ceil { x y } {
  497. return [ expr {($x + $y - 1) / $y} ]
  498. }
  499. proc device_type { } {
  500. global CONTROL_STATUS
  501. set tmp [ mrw $CONTROL_STATUS ]
  502. set tmp [ expr {$tmp & 0x700} ]
  503. set tmp [ expr {$tmp >> 8} ]
  504. return $tmp
  505. }
  506. proc get_input_clock_frequency { } {
  507. global CONTROL_STATUS
  508. if { [ device_type ] != 3 } {
  509. error "Unknown device type\n"
  510. return -1
  511. }
  512. set freq [ mrw $CONTROL_STATUS ]
  513. set freq [ expr {$freq & 0x00c00000} ]
  514. set freq [ expr {$freq >> 22} ]
  515. switch $freq {
  516. 0 {
  517. set CLKIN 19200000
  518. }
  519. 1 {
  520. set CLKIN 24000000
  521. }
  522. 2 {
  523. set CLKIN 25000000
  524. }
  525. 3 {
  526. set CLKIN 26000000
  527. }
  528. }
  529. return $CLKIN
  530. }
  531. proc mpu_pll_config { CLKIN N M M2 } {
  532. global CM_CLKMODE_DPLL_MPU
  533. global CM_CLKSEL_DPLL_MPU
  534. global CM_DIV_M2_DPLL_MPU
  535. global CM_IDLEST_DPLL_MPU
  536. set clksel [ mrw $CM_CLKSEL_DPLL_MPU ]
  537. set div_m2 [ mrw $CM_DIV_M2_DPLL_MPU ]
  538. mww $CM_CLKMODE_DPLL_MPU 0x4
  539. while { !([ mrw $CM_IDLEST_DPLL_MPU ] & 0x0100) } { }
  540. set clksel [ expr {$clksel & (~0x7ffff)} ]
  541. set clksel [ expr {$clksel | ($M << 0x8) | $N} ]
  542. mww $CM_CLKSEL_DPLL_MPU $clksel
  543. set div_m2 [ expr {$div_m2 & (~0x1f)} ]
  544. set div_m2 [ expr {$div_m2 | $M2} ]
  545. mww $CM_DIV_M2_DPLL_MPU $div_m2
  546. mww $CM_CLKMODE_DPLL_MPU 0x7
  547. while { [ mrw $CM_IDLEST_DPLL_MPU ] != 1 } { }
  548. echo "MPU DPLL locked"
  549. }
  550. proc core_pll_config { CLKIN N M M4 M5 M6 } {
  551. global CM_CLKMODE_DPLL_CORE
  552. global CM_CLKSEL_DPLL_CORE
  553. global CM_DIV_M4_DPLL_CORE
  554. global CM_DIV_M5_DPLL_CORE
  555. global CM_DIV_M6_DPLL_CORE
  556. global CM_IDLEST_DPLL_CORE
  557. set clksel [ mrw $CM_CLKSEL_DPLL_CORE ]
  558. mww $CM_CLKMODE_DPLL_CORE 0x4
  559. while { !([ mrw $CM_IDLEST_DPLL_CORE ] & 0x0100) } { }
  560. set clksel [ expr {$clksel & (~0x7ffff)} ]
  561. set clksel [ expr {$clksel | ($M << 0x8) | $N} ]
  562. mww $CM_CLKSEL_DPLL_CORE $clksel
  563. mww $CM_DIV_M4_DPLL_CORE $M4
  564. mww $CM_DIV_M5_DPLL_CORE $M5
  565. mww $CM_DIV_M6_DPLL_CORE $M6
  566. mww $CM_CLKMODE_DPLL_CORE 0x7
  567. while { !([ mrw $CM_IDLEST_DPLL_CORE ] & 0x01) } { }
  568. echo "CORE DPLL locked"
  569. }
  570. proc per_pll_config { CLKIN N M M2 } {
  571. global CM_CLKMODE_DPLL_PER
  572. global CM_CLKSEL_DPLL_PER
  573. global CM_DIV_M2_DPLL_PER
  574. global CM_IDLEST_DPLL_PER
  575. set x [ expr {$M * $CLKIN / 1000000} ]
  576. set y [ expr {($N + 1) * 250} ]
  577. set sd [ ceil $x $y ]
  578. set clksel [ mrw $CM_CLKSEL_DPLL_PER ]
  579. set div_m2 [ mrw $CM_DIV_M2_DPLL_PER ]
  580. mww $CM_CLKMODE_DPLL_PER 0x4
  581. while { !([ mrw $CM_IDLEST_DPLL_PER ] & 0x0100) } { }
  582. set clksel [ expr {$clksel & (~0xff0fffff)} ]
  583. set clksel [ expr {$clksel | ($M << 0x8) | $N} ]
  584. set clksel [ expr {$clksel | ($sd << 24)} ]
  585. mww $CM_CLKSEL_DPLL_PER $clksel
  586. set div_m2 [ expr {0xffffff80 | $M2} ]
  587. mww $CM_CLKMODE_DPLL_PER 0x7
  588. while { !([ mrw $CM_IDLEST_DPLL_PER ] & 0x01) } { }
  589. echo "PER DPLL locked"
  590. }
  591. proc ddr_pll_config { CLKIN N M M2 M4 } {
  592. global CM_CLKMODE_DPLL_DDR
  593. global CM_CLKSEL_DPLL_DDR
  594. global CM_DIV_M2_DPLL_DDR
  595. global CM_DIV_M4_DPLL_DDR
  596. global CM_IDLEST_DPLL_DDR
  597. set clksel [ mrw $CM_CLKSEL_DPLL_DDR ]
  598. set div_m2 [ mrw $CM_DIV_M2_DPLL_DDR ]
  599. mww $CM_CLKMODE_DPLL_DDR 0x4
  600. while { !([ mrw $CM_IDLEST_DPLL_DDR ] & 0x0100) } { }
  601. set clksel [ expr {$clksel & (~0x7ffff)} ]
  602. set clksel [ expr {$clksel | ($M << 8) | $N} ]
  603. mww $CM_CLKSEL_DPLL_DDR $clksel
  604. set div_m2 [ expr {($div_m2 & 0xffffffe0) | $M2} ]
  605. mww $CM_DIV_M2_DPLL_DDR $div_m2
  606. mww $CM_DIV_M4_DPLL_DDR $M4
  607. mww $CM_CLKMODE_DPLL_DDR 0x7
  608. while { !([ mrw $CM_IDLEST_DPLL_DDR ] & 0x01) } { }
  609. echo "DDR DPLL Locked"
  610. }
  611. proc config_opp100 { } {
  612. set CLKIN [ get_input_clock_frequency ]
  613. if { $CLKIN == -1 } {
  614. return -1
  615. }
  616. switch $CLKIN {
  617. 24000000 {
  618. mpu_pll_config $CLKIN 0 25 1
  619. core_pll_config $CLKIN 2 125 10 8 4
  620. per_pll_config $CLKIN 9 400 5
  621. ddr_pll_config $CLKIN 2 50 1 2
  622. }
  623. 25000000 {
  624. mpu_pll_config $CLKIN 0 24 1
  625. core_pll_config $CLKIN 0 40 10 8 4
  626. per_pll_config $CLKIN 9 384 5
  627. ddr_pll_config $CLKIN 0 16 1 2
  628. }
  629. 26000000 {
  630. mpu_pll_config $CLKIN 12 300 1
  631. core_pll_config $CLKIN 12 500 10 8 4
  632. per_pll_config $CLKIN 12 480 5
  633. ddr_pll_config $CLKIN 12 200 1 2
  634. }
  635. 19200000 {
  636. mpu_pll_config $CLKIN 3 125 1
  637. core_pll_config $CLKIN 11 625 10 8 4
  638. per_pll_config $CLKIN 7 400 5
  639. ddr_pll_config $CLKIN 2 125 1 2
  640. }
  641. }
  642. }
  643. proc emif_prcm_clk_enable { } {
  644. global CM_PER_EMIF_FW_CLKCTRL
  645. global CM_PER_EMIF_CLKCTRL
  646. mww $CM_PER_EMIF_FW_CLKCTRL 0x02
  647. mww $CM_PER_EMIF_CLKCTRL 0x02
  648. while { [ mrw $CM_PER_EMIF_CLKCTRL ] != 0x02 } { }
  649. }
  650. proc vtp_enable { } {
  651. global VTP_CTRL_REG
  652. set vtp [ expr {[ mrw $VTP_CTRL_REG ] | 0x40 }]
  653. mww $VTP_CTRL_REG $vtp
  654. set vtp [ expr {[ mrw $VTP_CTRL_REG ] & ~0x01 }]
  655. mww $VTP_CTRL_REG $vtp
  656. set vtp [ expr {[ mrw $VTP_CTRL_REG ] | 0x01 }]
  657. mww $VTP_CTRL_REG $vtp
  658. }
  659. proc config_ddr_ioctrl { } {
  660. global DDR_ADDRCTRL_IOCTRL
  661. global DDR_ADDRCTRL_WD0_IOCTRL
  662. global DDR_ADDRCTRL_WD1_IOCTRL
  663. global DDR_CKE_CTRL
  664. global DDR_DATA0_IOCTRL
  665. global DDR_DATA1_IOCTRL
  666. global DDR_DATA2_IOCTRL
  667. global DDR_DATA3_IOCTRL
  668. global DDR_IO_CTRL
  669. mww $DDR_ADDRCTRL_IOCTRL 0x84
  670. mww $DDR_ADDRCTRL_WD0_IOCTRL 0x00
  671. mww $DDR_ADDRCTRL_WD1_IOCTRL 0x00
  672. mww $DDR_DATA0_IOCTRL 0x84
  673. mww $DDR_DATA1_IOCTRL 0x84
  674. mww $DDR_DATA2_IOCTRL 0x84
  675. mww $DDR_DATA3_IOCTRL 0x84
  676. mww $DDR_IO_CTRL 0x00
  677. mww $DDR_CKE_CTRL 0x03
  678. }
  679. proc config_ddr_phy { } {
  680. global EMIF_DDR_PHY_CTRL_1
  681. global EMIF_DDR_PHY_CTRL_1_SHDW
  682. global EXT_PHY_CTRL_1
  683. global EXT_PHY_CTRL_1_SHDW
  684. global EXT_PHY_CTRL_2
  685. global EXT_PHY_CTRL_2_SHDW
  686. global EXT_PHY_CTRL_3
  687. global EXT_PHY_CTRL_3_SHDW
  688. global EXT_PHY_CTRL_4
  689. global EXT_PHY_CTRL_4_SHDW
  690. global EXT_PHY_CTRL_5
  691. global EXT_PHY_CTRL_5_SHDW
  692. global EXT_PHY_CTRL_6
  693. global EXT_PHY_CTRL_6_SHDW
  694. global EXT_PHY_CTRL_7
  695. global EXT_PHY_CTRL_7_SHDW
  696. global EXT_PHY_CTRL_8
  697. global EXT_PHY_CTRL_8_SHDW
  698. global EXT_PHY_CTRL_9
  699. global EXT_PHY_CTRL_9_SHDW
  700. global EXT_PHY_CTRL_10
  701. global EXT_PHY_CTRL_10_SHDW
  702. global EXT_PHY_CTRL_11
  703. global EXT_PHY_CTRL_11_SHDW
  704. global EXT_PHY_CTRL_12
  705. global EXT_PHY_CTRL_12_SHDW
  706. global EXT_PHY_CTRL_13
  707. global EXT_PHY_CTRL_13_SHDW
  708. global EXT_PHY_CTRL_14
  709. global EXT_PHY_CTRL_14_SHDW
  710. global EXT_PHY_CTRL_15
  711. global EXT_PHY_CTRL_15_SHDW
  712. global EXT_PHY_CTRL_16
  713. global EXT_PHY_CTRL_16_SHDW
  714. global EXT_PHY_CTRL_17
  715. global EXT_PHY_CTRL_17_SHDW
  716. global EXT_PHY_CTRL_18
  717. global EXT_PHY_CTRL_18_SHDW
  718. global EXT_PHY_CTRL_19
  719. global EXT_PHY_CTRL_19_SHDW
  720. global EXT_PHY_CTRL_20
  721. global EXT_PHY_CTRL_20_SHDW
  722. global EXT_PHY_CTRL_21
  723. global EXT_PHY_CTRL_21_SHDW
  724. global EXT_PHY_CTRL_22
  725. global EXT_PHY_CTRL_22_SHDW
  726. global EXT_PHY_CTRL_23
  727. global EXT_PHY_CTRL_23_SHDW
  728. global EXT_PHY_CTRL_24
  729. global EXT_PHY_CTRL_24_SHDW
  730. global EXT_PHY_CTRL_25
  731. global EXT_PHY_CTRL_25_SHDW
  732. global EXT_PHY_CTRL_26
  733. global EXT_PHY_CTRL_26_SHDW
  734. global EXT_PHY_CTRL_27
  735. global EXT_PHY_CTRL_27_SHDW
  736. global EXT_PHY_CTRL_28
  737. global EXT_PHY_CTRL_28_SHDW
  738. global EXT_PHY_CTRL_29
  739. global EXT_PHY_CTRL_29_SHDW
  740. global EXT_PHY_CTRL_30
  741. global EXT_PHY_CTRL_30_SHDW
  742. global EXT_PHY_CTRL_31
  743. global EXT_PHY_CTRL_31_SHDW
  744. global EXT_PHY_CTRL_32
  745. global EXT_PHY_CTRL_32_SHDW
  746. global EXT_PHY_CTRL_33
  747. global EXT_PHY_CTRL_33_SHDW
  748. global EXT_PHY_CTRL_34
  749. global EXT_PHY_CTRL_34_SHDW
  750. global EXT_PHY_CTRL_35
  751. global EXT_PHY_CTRL_35_SHDW
  752. global EXT_PHY_CTRL_36
  753. global EXT_PHY_CTRL_36_SHDW
  754. mww $EMIF_DDR_PHY_CTRL_1 0x8009
  755. mww $EMIF_DDR_PHY_CTRL_1_SHDW 0x8009
  756. set slave_ratio 0x80
  757. set gatelvl_init_ratio 0x20
  758. set wr_dqs_slave_delay 0x60
  759. set rd_dqs_slave_delay 0x60
  760. set dq_offset 0x40
  761. set gatelvl_init_mode 0x01
  762. set wr_data_slave_delay 0x80
  763. set gatelvl_num_dq0 0x0f
  764. set wrlvl_num_dq0 0x0f
  765. mww $EXT_PHY_CTRL_1 [ expr {($slave_ratio << 20) | ($slave_ratio << 10) | $slave_ratio} ]
  766. mww $EXT_PHY_CTRL_1_SHDW [ expr {($slave_ratio << 20) | ($slave_ratio << 10) | $slave_ratio} ]
  767. mww $EXT_PHY_CTRL_26 [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  768. mww $EXT_PHY_CTRL_26_SHDW [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  769. mww $EXT_PHY_CTRL_27 [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  770. mww $EXT_PHY_CTRL_27_SHDW [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  771. mww $EXT_PHY_CTRL_28 [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  772. mww $EXT_PHY_CTRL_28_SHDW [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  773. mww $EXT_PHY_CTRL_29 [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  774. mww $EXT_PHY_CTRL_29_SHDW [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  775. mww $EXT_PHY_CTRL_30 [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  776. mww $EXT_PHY_CTRL_30_SHDW [ expr {($gatelvl_init_ratio << 16) | $gatelvl_init_ratio} ]
  777. mww $EXT_PHY_CTRL_31 0x00
  778. mww $EXT_PHY_CTRL_31_SHDW 0x00
  779. mww $EXT_PHY_CTRL_32 0x00
  780. mww $EXT_PHY_CTRL_32_SHDW 0x00
  781. mww $EXT_PHY_CTRL_33 0x00
  782. mww $EXT_PHY_CTRL_33_SHDW 0x00
  783. mww $EXT_PHY_CTRL_34 0x00
  784. mww $EXT_PHY_CTRL_34_SHDW 0x00
  785. mww $EXT_PHY_CTRL_35 0x00
  786. mww $EXT_PHY_CTRL_35_SHDW 0x00
  787. mww $EXT_PHY_CTRL_22 0x00
  788. mww $EXT_PHY_CTRL_22_SHDW 0x00
  789. mww $EXT_PHY_CTRL_23 [ expr {($wr_dqs_slave_delay << 16) | $rd_dqs_slave_delay} ]
  790. mww $EXT_PHY_CTRL_23_SHDW [ expr {($wr_dqs_slave_delay << 16) | $rd_dqs_slave_delay} ]
  791. mww $EXT_PHY_CTRL_24 [ expr {($dq_offset << 24) | ($gatelvl_init_mode << 16) | $wr_data_slave_delay} ]
  792. mww $EXT_PHY_CTRL_24_SHDW [ expr {($dq_offset << 24) | ($gatelvl_init_mode << 16) | $wr_data_slave_delay << 0} ]
  793. mww $EXT_PHY_CTRL_25 [ expr {($dq_offset << 21) | ($dq_offset << 14) | ($dq_offset << 7) | $dq_offset} ]
  794. mww $EXT_PHY_CTRL_25_SHDW [ expr {($dq_offset << 21) | ($dq_offset << 14) | ($dq_offset << 7) | $dq_offset} ]
  795. mww $EXT_PHY_CTRL_36 [ expr {($wrlvl_num_dq0 << 4) | $gatelvl_num_dq0} ]
  796. mww $EXT_PHY_CTRL_36_SHDW [ expr {($wrlvl_num_dq0 << 4) | $gatelvl_num_dq0} ]
  797. }
  798. proc config_ddr_timing { } {
  799. global EMIF_SDRAM_TIM_1
  800. global EMIF_SDRAM_TIM_2
  801. global EMIF_SDRAM_TIM_3
  802. global EMIF_SDRAM_TIM_1_SHDW
  803. global EMIF_SDRAM_TIM_2_SHDW
  804. global EMIF_SDRAM_TIM_3_SHDW
  805. global EMIF_ZQ_CONFIG
  806. mww $EMIF_SDRAM_TIM_1 0xeaaad4db
  807. mww $EMIF_SDRAM_TIM_1_SHDW 0xeaaad4db
  808. mww $EMIF_SDRAM_TIM_2 0x266b7fda
  809. mww $EMIF_SDRAM_TIM_2_SHDW 0x266b7fda
  810. mww $EMIF_SDRAM_TIM_3 0x107f8678
  811. mww $EMIF_SDRAM_TIM_3_SHDW 0x107f8678
  812. mww $EMIF_ZQ_CONFIG 0x50074be4
  813. }
  814. proc config_ddr_pm { } {
  815. global EMIF_PWR_MGMT_CTRL
  816. global EMIF_PWR_MGMT_CTRL_SHDW
  817. global EMIF_DLL_CALIB_CTRL
  818. global EMIF_DLL_CALIB_CTRL_SHDW
  819. global EMIF_TEMP_ALERT_CONFIG
  820. mww $EMIF_PWR_MGMT_CTRL 0x00
  821. mww $EMIF_PWR_MGMT_CTRL_SHDW 0x00
  822. mww $EMIF_DLL_CALIB_CTRL 0x00050000
  823. mww $EMIF_DLL_CALIB_CTRL_SHDW 0x00050000
  824. mww $EMIF_TEMP_ALERT_CONFIG 0x00
  825. }
  826. proc config_ddr_priority { } {
  827. global EMIF_PRI_COS_MAP
  828. global EMIF_CONNID_COS_1_MAP
  829. global EMIF_CONNID_COS_2_MAP
  830. global EMIF_RD_WR_EXEC_THRSH
  831. global COS_CONFIG
  832. mww $EMIF_PRI_COS_MAP 0x00
  833. mww $EMIF_CONNID_COS_1_MAP 0x00
  834. mww $EMIF_CONNID_COS_2_MAP 0x0
  835. mww $EMIF_RD_WR_EXEC_THRSH 0x0405
  836. mww $COS_CONFIG 0x00ffffff
  837. }
  838. proc config_ddr3 { SDRAM_CONFIG } {
  839. global CM_DLL_CTRL
  840. global EMIF_IODFT_TLGC
  841. global EMIF_RDWR_LVL_CTRL
  842. global EMIF_RDWR_LVL_RMP_CTRL
  843. global EMIF_SDRAM_CONFIG
  844. global EMIF_SDRAM_CONFIG_EXT
  845. global EMIF_SDRAM_REF_CTRL
  846. global EMIF_SDRAM_REF_CTRL_SHDW
  847. global EMIF_STATUS
  848. global EXT_PHY_CTRL_36
  849. global EXT_PHY_CTRL_36_SHDW
  850. emif_prcm_clk_enable
  851. vtp_enable
  852. set dll [ expr {[ mrw $CM_DLL_CTRL ] & ~0x01 }]
  853. mww $CM_DLL_CTRL $dll
  854. while { !([ mrw $CM_DLL_CTRL ] & 0x04) } { }
  855. config_ddr_ioctrl
  856. mww $EMIF_SDRAM_CONFIG_EXT 0xc163
  857. mww $EMIF_IODFT_TLGC 0x2011
  858. mww $EMIF_IODFT_TLGC 0x2411
  859. mww $EMIF_IODFT_TLGC 0x2011
  860. mww $EMIF_SDRAM_REF_CTRL 0x80003000
  861. config_ddr_phy
  862. mww $EMIF_IODFT_TLGC 0x2011
  863. mww $EMIF_IODFT_TLGC 0x2411
  864. mww $EMIF_IODFT_TLGC 0x2011
  865. config_ddr_timing
  866. config_ddr_pm
  867. config_ddr_priority
  868. mww $EMIF_SDRAM_REF_CTRL 0x3000
  869. mww $EMIF_SDRAM_CONFIG $SDRAM_CONFIG
  870. mww $EMIF_SDRAM_REF_CTRL 0x0c30
  871. mww $EMIF_SDRAM_REF_CTRL_SHDW 0x0c30
  872. sleep 10
  873. set tmp [ expr {[ mrw $EXT_PHY_CTRL_36 ] | 0x0100 }]
  874. mww $EXT_PHY_CTRL_36 $tmp
  875. mww $EXT_PHY_CTRL_36_SHDW $tmp
  876. mww $EMIF_RDWR_LVL_RMP_CTRL 0x80000000
  877. mww $EMIF_RDWR_LVL_CTRL 0x80000000
  878. while { [ mrw $EMIF_RDWR_LVL_CTRL ] & 0x80000000 } { }
  879. if { [ mrw $EMIF_STATUS ] & 0x70 } {
  880. error "DDR3 Hardware Leveling incomplete!!!"
  881. }
  882. }
  883. proc init_platform { SDRAM_CONFIG } {
  884. config_opp100
  885. config_ddr3 $SDRAM_CONFIG
  886. }
  887. $_TARGETNAME configure -event reset-init { init_platform 0x61a013b2 }
  888. $_TARGETNAME configure -event reset-end { disable_watchdog }