dcd.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*
  2. * Copyright (c) 2010-2012, Freescale Semiconductor, Inc.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without modification,
  6. * are permitted provided that the following conditions are met:
  7. *
  8. * o Redistributions of source code must retain the above copyright notice, this list
  9. * of conditions and the following disclaimer.
  10. *
  11. * o Redistributions in binary form must reproduce the above copyright notice, this
  12. * list of conditions and the following disclaimer in the documentation and/or
  13. * other materials provided with the distribution.
  14. *
  15. * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
  16. * contributors may be used to endorse or promote products derived from this
  17. * software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  20. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  21. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  22. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
  23. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  24. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  25. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
  26. * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  28. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. */
  30. #include "hab_defines.h"
  31. #include "soc_memory_map.h"
  32. //! @brief dcd data, list of (register, value) pairs to initialize ddr
  33. uint8_t input_dcd[] __attribute__ ((section (".dcd_data")))= {
  34. /*DDR clk to 400MHz*/
  35. /*CCM_BASE_ADDR = 0x020c4000*/
  36. EXPAND_UINT32(CCM_BASE_ADDR + 0x018), EXPAND_UINT32(0x00260324),
  37. /*========================================================================*/
  38. /* IOMUX*/
  39. /*========================================================================*/
  40. /* Megrez note: IOMUX configs specify absolute addr in Arik IOMUXC. Changes to
  41. Megrez addr.*/
  42. /* Megrez note: Good chance that drive strength change is required. to change
  43. them all by editing the LSB value "38"-> ""30" or "28"*/
  44. /* Megrez note: Timing also can be tweaked by drive strength values. It is
  45. mainly by giving SDCLk and SDQS different values than the sampled signals*/
  46. /*IOMUXC_BASE_ADDR = 0x020e0000*/
  47. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS0*/
  48. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x344), EXPAND_UINT32(0x00003030),
  49. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS1*/
  50. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x348), EXPAND_UINT32(0x00003030),
  51. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS2*/
  52. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x34c), EXPAND_UINT32(0x00003030),
  53. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDQS3*/
  54. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x350), EXPAND_UINT32(0x00003030),
  55. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM0*/
  56. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x30c), EXPAND_UINT32(0x00000030),
  57. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM1*/
  58. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x310), EXPAND_UINT32(0x00000030),
  59. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM2*/
  60. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x314), EXPAND_UINT32(0x00000030),
  61. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_DQM3*/
  62. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x318), EXPAND_UINT32(0x00000030),
  63. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_CAS*/
  64. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x300), EXPAND_UINT32(0x00000030),
  65. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_RAS*/
  66. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x31c), EXPAND_UINT32(0x00000030),
  67. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDCLK_0*/
  68. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x338), EXPAND_UINT32(0x00000028),
  69. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_RESET*/
  70. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x320), EXPAND_UINT32(0x00000030),
  71. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDBA2 - DSE can be configured using Group Control
  72. Register: IOMUXC_SW_PAD_CTL_GRP_CTLDS*/
  73. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x32c), EXPAND_UINT32(0x00000000),
  74. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDODT0*/
  75. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x33c), EXPAND_UINT32(0x00000008),
  76. /*IOMUXC_SW_PAD_CTL_PAD_DRAM_SDODT1*/
  77. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x340), EXPAND_UINT32(0x00000008),
  78. /*IOMUXC_SW_PAD_CTL_GRP_B0DS*/
  79. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5c4), EXPAND_UINT32(0x00000030),
  80. /*IOMUXC_SW_PAD_CTL_GRP_B1DS*/
  81. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5cc), EXPAND_UINT32(0x00000030),
  82. /*IOMUXC_SW_PAD_CTL_GRP_B2DS*/
  83. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5d4), EXPAND_UINT32(0x00000030),
  84. /*IOMUXC_SW_PAD_CTL_GRP_B3DS*/
  85. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5d8), EXPAND_UINT32(0x00000030),
  86. /*IOMUXC_SW_PAD_CTL_GRP_ADDDS*/
  87. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5ac), EXPAND_UINT32(0x00000030),
  88. /*IOMUXC_SW_PAD_CTL_GRP_CTLDS*/
  89. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5c8), EXPAND_UINT32(0x00000030),
  90. /*IOMUXC_SW_PAD_CTL_GRP_DDRMODE_CTL*/
  91. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5b0), EXPAND_UINT32(0x00020000),
  92. /*IOMUXC_SW_PAD_CTL_GRP_DDRPKE*/
  93. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5b4), EXPAND_UINT32(0x00000000),
  94. /*IOMUXC_SW_PAD_CTL_GRP_DDRMODE*/
  95. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5c0), EXPAND_UINT32(0x00020000),
  96. /*IOMUXC_SW_PAD_CTL_GRP_DDR_TYPE*/
  97. EXPAND_UINT32(IOMUXC_BASE_ADDR + 0x5d0), EXPAND_UINT32(0x00080000),
  98. /*========================================================================*/
  99. /* DDR Controller Registers*/
  100. /*========================================================================*/
  101. /* Manufacturer: Samsung*/
  102. /* Device Part Number: K4P8G304EB-AGC1*/
  103. /* Clock Freq.: 400MMHz*/
  104. /* MMDC channels: MMDC0*/
  105. /* Density per CS in Gb: 512M*/
  106. /* Chip Selects used: 2*/
  107. /* Number of Banks: 8*/
  108. /* Row address: 14*/
  109. /* Column address: 10*/
  110. /* Data bus width 32*/
  111. /*========================================================================*/
  112. /*MMDC_P0_BASE_ADDR = 0x021b0000*/
  113. /*MMDC0_MDSCR, set the Configuration request bit during MMDC set up*/
  114. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x00008000),
  115. /*setmem /32 0x021b085c = 0x1b5f01ff*/
  116. /*LPDDR2 ZQ params*/
  117. /*LPDDR2 ZQ params*/
  118. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x85c), EXPAND_UINT32(0x1b4700c7),
  119. /*========================================================================*/
  120. /* Calibration setup.*/
  121. /**/
  122. /*========================================================================*/
  123. /*DDR_PHY_P0_MPZQHWCTRL, enable on time ZQ calibration*/
  124. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x800), EXPAND_UINT32(0xa1390003),
  125. /* Megrez note: If entire word fails, CA bus might be involved. Try changing
  126. this:*/
  127. /*ca bus abs delay*/
  128. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x890), EXPAND_UINT32(0x00300000),
  129. /* values of 20,40,50,60,7f tried. no difference seen*/
  130. /* Megrez note: This is also for CA bus. A bit-bit fine tuning.*/
  131. /*setmem /32 0x021b48bc = 0x00055555*/
  132. /*DDR_PHY_P1_MPWRCADL*/
  133. /*frc_msr.*/
  134. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x8b8), EXPAND_UINT32(0x00000800),
  135. /*DDR_PHY_P0_MPREDQBY0DL3*/
  136. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x81c), EXPAND_UINT32(0x33333333),
  137. /*DDR_PHY_P0_MPREDQBY1DL3*/
  138. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x820), EXPAND_UINT32(0x33333333),
  139. /*DDR_PHY_P0_MPREDQBY2DL3*/
  140. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x824), EXPAND_UINT32(0x33333333),
  141. /*DDR_PHY_P0_MPREDQBY3DL3*/
  142. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x828), EXPAND_UINT32(0x33333333),
  143. /*write delayes:*/
  144. /*all byte 0 data & dm delayed by 3*/
  145. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x82c), EXPAND_UINT32(0xf3333333),
  146. /*all byte 1 data & dm delayed by 3*/
  147. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x830), EXPAND_UINT32(0xf3333333),
  148. /*all byte 2 data & dm delayed by 3*/
  149. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x834), EXPAND_UINT32(0xf3333333),
  150. /*all byte 3 data & dm delayed by 3*/
  151. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x838), EXPAND_UINT32(0xf3333333),
  152. /* Read and write data delay, per byte.*/
  153. /* For optimized DDR operation it is recommended to run mmdc_calibration on your
  154. board, and replace 4 delay register assigns with resulted values*/
  155. /* Note:*/
  156. /* a. DQS gating is not relevant for LPDDR2. DSQ gating calibration section
  157. should be skipped, or the write/read calibration comming after that will
  158. stall*/
  159. /* b. The calibration code that runs for both MMDC0 & MMDC1 should be used.*/
  160. /*it is strongly recommended to run calibration on your board, and replace
  161. bellow values:*/
  162. /* Megrez note: New set of values is required for the following 2 delay
  163. registers. Try running calibration code as in Arik APN.*/
  164. /*Read calibration*/
  165. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x848), EXPAND_UINT32(0x4241444a),
  166. /*Write calibration*/
  167. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x850), EXPAND_UINT32(0x3030312b),
  168. /*dqs gating dis*/
  169. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x83c), EXPAND_UINT32(0x20000000),
  170. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x840), EXPAND_UINT32(0x00000000),
  171. /* Megrez note: Try enabling and changing the clock delay, as part of the
  172. calibration:*/
  173. /*setmem /32 0x021b0858 = 0xa00*/
  174. /*clk delay*/
  175. /*fine tune duty cyc to low*/
  176. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x8c0), EXPAND_UINT32(0x24911492),
  177. /*frc_msr*/
  178. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x8b8), EXPAND_UINT32(0x00000800),
  179. /*========================================================================*/
  180. /* Calibration setup end*/
  181. /*========================================================================*/
  182. /* Channel0 - startng address 0x80000000*/
  183. /*setmem /32 0x021b000c = 0x3f436133*/
  184. /* MMDC0_MDCFG0*/
  185. /*MMDC0_MDCFG0*/
  186. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x00c), EXPAND_UINT32(0x33374133),
  187. /*MMDC0_MDPDC - where is tCKSRX and tCKSRE defined in LPDDR2 data sheet?????*/
  188. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x004), EXPAND_UINT32(0x00020024),
  189. /*MMDC0_MDCFG1*/
  190. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x010), EXPAND_UINT32(0x00100A82),
  191. /*MMDC0_MDCFG2*/
  192. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x014), EXPAND_UINT32(0x00000093),
  193. /*MMDC0_MDMISC. RALAT=3. Try increasing RALAT if case of failures at higher DDR
  194. freq*/
  195. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x018), EXPAND_UINT32(0x00001688),
  196. /*MMDC0_MDRWD;*/
  197. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x02c), EXPAND_UINT32(0x0f9f26d2),
  198. /*MMDC0_MDOR*/
  199. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x030), EXPAND_UINT32(0x0000020e),
  200. /*setmem /32 0x021b0038 = 0x001a099a*/
  201. /* MMDC0_MDCFG3LP*/
  202. /*MMDC0_MDCFG3LP*/
  203. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x038), EXPAND_UINT32(0x00190778),
  204. /*MMDC0_MDOTC*/
  205. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x008), EXPAND_UINT32(0x00000000),
  206. /*CS0_END = 0x8fffffff*/
  207. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x040), EXPAND_UINT32(0x0000004f),
  208. /*MMDC0_MDCTL*/
  209. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x000), EXPAND_UINT32(0xc3110000),
  210. /* Channel0 : Configure DDR device:*/
  211. /* Megrez note: Device drive strength change might help, consult device/JEDEC
  212. for the values.*/
  213. /*MRW: BA=0 CS=0 MR_ADDR=63 MR_OP=0 //reset*/
  214. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x003f8030),
  215. /*MRW: BA=0 CS=0 MR_ADDR=10 MR_OP=ff /zq*/
  216. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0xff0a8030),
  217. /*MRW: BA=0 CS=0 MR_ADDR=1 MR_OP=c2*/
  218. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x82018030),
  219. /*MRW: BA=0 CS=0 MR_ADDR=2 MR_OP=4. tcl=6, tcwl=3*/
  220. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x04028030),
  221. /*MRW: BA=0 CS=0 MR_ADDR=3 MR_OP=2.drive=240/6*/
  222. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x02038030),
  223. /* Need to comment out MRW reset command to CS1 - investigating this*/
  224. /* Also, adding delays before and after this makes no difference*/
  225. /*setmem /32 0x021b001c = 0x003f8038*/
  226. /* MRW: BA=0 CS=1 MR_ADDR=63 MR_OP=0*/
  227. /*reset*/
  228. /*MRW: BA=0 CS=1 MR_ADDR=10 MR_OP=ff*/
  229. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0xff0a8038),
  230. /*MRW: BA=0 CS=1 MR_ADDR=1 MR_OP=c2*/
  231. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x82018038),
  232. /*MRW: BA=0 CS=1 MR_ADDR=2 MR_OP=4. tcl=6, tcwl=3*/
  233. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x04028038),
  234. /*MRW: BA=0 CS=1 MR_ADDR=3 MR_OP=2.drive=240/6*/
  235. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x02038038),
  236. /*######################################################*/
  237. /*final DDR setup, before operation start:*/
  238. /*DDR_PHY_P0_MPZQHWCTRL, enable automatic ZQ calibration*/
  239. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x800), EXPAND_UINT32(0xa1310003),
  240. /*MMDC0_MDREF*/
  241. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x020), EXPAND_UINT32(0x00001800),
  242. /*DDR_PHY_P0_MPODTCTRL*/
  243. /*setmem /32 0x021b0818 = 0*/
  244. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x818), EXPAND_UINT32(0x00000000),
  245. /*DDR_PHY_P0_MPMUR0, frc_msr*/
  246. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x8b8), EXPAND_UINT32(0x00000800),
  247. /*MMDC0_MDPDC now SDCTL power down enabled*/
  248. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x004), EXPAND_UINT32(0x00025564),
  249. /*MMDC0_MAPSR ADOPT power down enabled*/
  250. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x404), EXPAND_UINT32(0x00011006),
  251. /*MMDC0_MDSCR, clear this register (especially the configuration bit as
  252. initialization is complete),*/
  253. EXPAND_UINT32(MMDC_P0_BASE_ADDR + 0x01c), EXPAND_UINT32(0x00000000),
  254. };
  255. //! @brief HAB command write data header, with tag,
  256. //! size of dcd data with hdr,
  257. //! parameter field (size of register value and flag)
  258. uint8_t input_dcd_wrt_cmd[] __attribute__ ((section (".dcd_wrt_cmd")))= {
  259. HAB_CMD_WRT_DAT,
  260. EXPAND_UINT16(sizeof(input_dcd) + HDR_BYTES),
  261. WRT_DAT_PAR(0, HAB_DATA_WIDTH_WORD) //!< flag 0, width 4
  262. };
  263. //! @brief HAB dcd header with dcd tag, size of entire dcd and version.
  264. uint8_t input_dcd_hdr[] __attribute__ ((section (".dcd_hdr")))= {
  265. HAB_TAG_DCD,
  266. EXPAND_UINT16(sizeof(input_dcd) + sizeof(input_dcd_wrt_cmd) + HDR_BYTES),
  267. HAB_VER(4,0)
  268. };