ddr_rk3288.h 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484
  1. /*
  2. * (C) Copyright 2015 Google, Inc
  3. *
  4. * SPDX-License-Identifier: GPL-2.0
  5. */
  6. #ifndef _ASM_ARCH_DDR_RK3288_H
  7. #define _ASM_ARCH_DDR_RK3288_H
  8. struct rk3288_ddr_pctl {
  9. u32 scfg;
  10. u32 sctl;
  11. u32 stat;
  12. u32 intrstat;
  13. u32 reserved0[12];
  14. u32 mcmd;
  15. u32 powctl;
  16. u32 powstat;
  17. u32 cmdtstat;
  18. u32 tstaten;
  19. u32 reserved1[3];
  20. u32 mrrcfg0;
  21. u32 mrrstat0;
  22. u32 mrrstat1;
  23. u32 reserved2[4];
  24. u32 mcfg1;
  25. u32 mcfg;
  26. u32 ppcfg;
  27. u32 mstat;
  28. u32 lpddr2zqcfg;
  29. u32 reserved3;
  30. u32 dtupdes;
  31. u32 dtuna;
  32. u32 dtune;
  33. u32 dtuprd0;
  34. u32 dtuprd1;
  35. u32 dtuprd2;
  36. u32 dtuprd3;
  37. u32 dtuawdt;
  38. u32 reserved4[3];
  39. u32 togcnt1u;
  40. u32 tinit;
  41. u32 trsth;
  42. u32 togcnt100n;
  43. u32 trefi;
  44. u32 tmrd;
  45. u32 trfc;
  46. u32 trp;
  47. u32 trtw;
  48. u32 tal;
  49. u32 tcl;
  50. u32 tcwl;
  51. u32 tras;
  52. u32 trc;
  53. u32 trcd;
  54. u32 trrd;
  55. u32 trtp;
  56. u32 twr;
  57. u32 twtr;
  58. u32 texsr;
  59. u32 txp;
  60. u32 txpdll;
  61. u32 tzqcs;
  62. u32 tzqcsi;
  63. u32 tdqs;
  64. u32 tcksre;
  65. u32 tcksrx;
  66. u32 tcke;
  67. u32 tmod;
  68. u32 trstl;
  69. u32 tzqcl;
  70. u32 tmrr;
  71. u32 tckesr;
  72. u32 tdpd;
  73. u32 reserved5[14];
  74. u32 ecccfg;
  75. u32 ecctst;
  76. u32 eccclr;
  77. u32 ecclog;
  78. u32 reserved6[28];
  79. u32 dtuwactl;
  80. u32 dturactl;
  81. u32 dtucfg;
  82. u32 dtuectl;
  83. u32 dtuwd0;
  84. u32 dtuwd1;
  85. u32 dtuwd2;
  86. u32 dtuwd3;
  87. u32 dtuwdm;
  88. u32 dturd0;
  89. u32 dturd1;
  90. u32 dturd2;
  91. u32 dturd3;
  92. u32 dtulfsrwd;
  93. u32 dtulfsrrd;
  94. u32 dtueaf;
  95. u32 dfitctrldelay;
  96. u32 dfiodtcfg;
  97. u32 dfiodtcfg1;
  98. u32 dfiodtrankmap;
  99. u32 dfitphywrdata;
  100. u32 dfitphywrlat;
  101. u32 reserved7[2];
  102. u32 dfitrddataen;
  103. u32 dfitphyrdlat;
  104. u32 reserved8[2];
  105. u32 dfitphyupdtype0;
  106. u32 dfitphyupdtype1;
  107. u32 dfitphyupdtype2;
  108. u32 dfitphyupdtype3;
  109. u32 dfitctrlupdmin;
  110. u32 dfitctrlupdmax;
  111. u32 dfitctrlupddly;
  112. u32 reserved9;
  113. u32 dfiupdcfg;
  114. u32 dfitrefmski;
  115. u32 dfitctrlupdi;
  116. u32 reserved10[4];
  117. u32 dfitrcfg0;
  118. u32 dfitrstat0;
  119. u32 dfitrwrlvlen;
  120. u32 dfitrrdlvlen;
  121. u32 dfitrrdlvlgateen;
  122. u32 dfiststat0;
  123. u32 dfistcfg0;
  124. u32 dfistcfg1;
  125. u32 reserved11;
  126. u32 dfitdramclken;
  127. u32 dfitdramclkdis;
  128. u32 dfistcfg2;
  129. u32 dfistparclr;
  130. u32 dfistparlog;
  131. u32 reserved12[3];
  132. u32 dfilpcfg0;
  133. u32 reserved13[3];
  134. u32 dfitrwrlvlresp0;
  135. u32 dfitrwrlvlresp1;
  136. u32 dfitrwrlvlresp2;
  137. u32 dfitrrdlvlresp0;
  138. u32 dfitrrdlvlresp1;
  139. u32 dfitrrdlvlresp2;
  140. u32 dfitrwrlvldelay0;
  141. u32 dfitrwrlvldelay1;
  142. u32 dfitrwrlvldelay2;
  143. u32 dfitrrdlvldelay0;
  144. u32 dfitrrdlvldelay1;
  145. u32 dfitrrdlvldelay2;
  146. u32 dfitrrdlvlgatedelay0;
  147. u32 dfitrrdlvlgatedelay1;
  148. u32 dfitrrdlvlgatedelay2;
  149. u32 dfitrcmd;
  150. u32 reserved14[46];
  151. u32 ipvr;
  152. u32 iptr;
  153. };
  154. check_member(rk3288_ddr_pctl, iptr, 0x03fc);
  155. struct rk3288_ddr_publ_datx {
  156. u32 dxgcr;
  157. u32 dxgsr[2];
  158. u32 dxdllcr;
  159. u32 dxdqtr;
  160. u32 dxdqstr;
  161. u32 reserved[10];
  162. };
  163. struct rk3288_ddr_publ {
  164. u32 ridr;
  165. u32 pir;
  166. u32 pgcr;
  167. u32 pgsr;
  168. u32 dllgcr;
  169. u32 acdllcr;
  170. u32 ptr[3];
  171. u32 aciocr;
  172. u32 dxccr;
  173. u32 dsgcr;
  174. u32 dcr;
  175. u32 dtpr[3];
  176. u32 mr[4];
  177. u32 odtcr;
  178. u32 dtar;
  179. u32 dtdr[2];
  180. u32 reserved1[24];
  181. u32 dcuar;
  182. u32 dcudr;
  183. u32 dcurr;
  184. u32 dculr;
  185. u32 dcugcr;
  186. u32 dcutpr;
  187. u32 dcusr[2];
  188. u32 reserved2[8];
  189. u32 bist[17];
  190. u32 reserved3[15];
  191. u32 zq0cr[2];
  192. u32 zq0sr[2];
  193. u32 zq1cr[2];
  194. u32 zq1sr[2];
  195. u32 zq2cr[2];
  196. u32 zq2sr[2];
  197. u32 zq3cr[2];
  198. u32 zq3sr[2];
  199. struct rk3288_ddr_publ_datx datx8[4];
  200. };
  201. check_member(rk3288_ddr_publ, datx8[3].dxdqstr, 0x0294);
  202. struct rk3288_msch {
  203. u32 coreid;
  204. u32 revisionid;
  205. u32 ddrconf;
  206. u32 ddrtiming;
  207. u32 ddrmode;
  208. u32 readlatency;
  209. u32 reserved1[8];
  210. u32 activate;
  211. u32 devtodev;
  212. };
  213. check_member(rk3288_msch, devtodev, 0x003c);
  214. /* PCT_DFISTCFG0 */
  215. #define DFI_INIT_START (1 << 0)
  216. /* PCT_DFISTCFG1 */
  217. #define DFI_DRAM_CLK_SR_EN (1 << 0)
  218. #define DFI_DRAM_CLK_DPD_EN (1 << 1)
  219. /* PCT_DFISTCFG2 */
  220. #define DFI_PARITY_INTR_EN (1 << 0)
  221. #define DFI_PARITY_EN (1 << 1)
  222. /* PCT_DFILPCFG0 */
  223. #define TLP_RESP_TIME_SHIFT 16
  224. #define LP_SR_EN (1 << 8)
  225. #define LP_PD_EN (1 << 0)
  226. /* PCT_DFITCTRLDELAY */
  227. #define TCTRL_DELAY_TIME_SHIFT 0
  228. /* PCT_DFITPHYWRDATA */
  229. #define TPHY_WRDATA_TIME_SHIFT 0
  230. /* PCT_DFITPHYRDLAT */
  231. #define TPHY_RDLAT_TIME_SHIFT 0
  232. /* PCT_DFITDRAMCLKDIS */
  233. #define TDRAM_CLK_DIS_TIME_SHIFT 0
  234. /* PCT_DFITDRAMCLKEN */
  235. #define TDRAM_CLK_EN_TIME_SHIFT 0
  236. /* PCTL_DFIODTCFG */
  237. #define RANK0_ODT_WRITE_SEL (1 << 3)
  238. #define RANK1_ODT_WRITE_SEL (1 << 11)
  239. /* PCTL_DFIODTCFG1 */
  240. #define ODT_LEN_BL8_W_SHIFT 16
  241. /* PUBL_ACDLLCR */
  242. #define ACDLLCR_DLLDIS (1 << 31)
  243. #define ACDLLCR_DLLSRST (1 << 30)
  244. /* PUBL_DXDLLCR */
  245. #define DXDLLCR_DLLDIS (1 << 31)
  246. #define DXDLLCR_DLLSRST (1 << 30)
  247. /* PUBL_DLLGCR */
  248. #define DLLGCR_SBIAS (1 << 30)
  249. /* PUBL_DXGCR */
  250. #define DQSRTT (1 << 9)
  251. #define DQRTT (1 << 10)
  252. /* PIR */
  253. #define PIR_INIT (1 << 0)
  254. #define PIR_DLLSRST (1 << 1)
  255. #define PIR_DLLLOCK (1 << 2)
  256. #define PIR_ZCAL (1 << 3)
  257. #define PIR_ITMSRST (1 << 4)
  258. #define PIR_DRAMRST (1 << 5)
  259. #define PIR_DRAMINIT (1 << 6)
  260. #define PIR_QSTRN (1 << 7)
  261. #define PIR_RVTRN (1 << 8)
  262. #define PIR_ICPC (1 << 16)
  263. #define PIR_DLLBYP (1 << 17)
  264. #define PIR_CTLDINIT (1 << 18)
  265. #define PIR_CLRSR (1 << 28)
  266. #define PIR_LOCKBYP (1 << 29)
  267. #define PIR_ZCALBYP (1 << 30)
  268. #define PIR_INITBYP (1u << 31)
  269. /* PGCR */
  270. #define PGCR_DFTLMT_SHIFT 3
  271. #define PGCR_DFTCMP_SHIFT 2
  272. #define PGCR_DQSCFG_SHIFT 1
  273. #define PGCR_ITMDMD_SHIFT 0
  274. /* PGSR */
  275. #define PGSR_IDONE (1 << 0)
  276. #define PGSR_DLDONE (1 << 1)
  277. #define PGSR_ZCDONE (1 << 2)
  278. #define PGSR_DIDONE (1 << 3)
  279. #define PGSR_DTDONE (1 << 4)
  280. #define PGSR_DTERR (1 << 5)
  281. #define PGSR_DTIERR (1 << 6)
  282. #define PGSR_DFTERR (1 << 7)
  283. #define PGSR_RVERR (1 << 8)
  284. #define PGSR_RVEIRR (1 << 9)
  285. /* PTR0 */
  286. #define PRT_ITMSRST_SHIFT 18
  287. #define PRT_DLLLOCK_SHIFT 6
  288. #define PRT_DLLSRST_SHIFT 0
  289. /* PTR1 */
  290. #define PRT_DINIT0_SHIFT 0
  291. #define PRT_DINIT1_SHIFT 19
  292. /* PTR2 */
  293. #define PRT_DINIT2_SHIFT 0
  294. #define PRT_DINIT3_SHIFT 17
  295. /* DCR */
  296. #define DDRMD_LPDDR 0
  297. #define DDRMD_DDR 1
  298. #define DDRMD_DDR2 2
  299. #define DDRMD_DDR3 3
  300. #define DDRMD_LPDDR2_LPDDR3 4
  301. #define DDRMD_MASK 7
  302. #define DDRMD_SHIFT 0
  303. #define PDQ_MASK 7
  304. #define PDQ_SHIFT 4
  305. /* DXCCR */
  306. #define DQSNRES_MASK 0xf
  307. #define DQSNRES_SHIFT 8
  308. #define DQSRES_MASK 0xf
  309. #define DQSRES_SHIFT 4
  310. /* DTPR */
  311. #define TDQSCKMAX_SHIFT 27
  312. #define TDQSCKMAX_MASK 7
  313. #define TDQSCK_SHIFT 24
  314. #define TDQSCK_MASK 7
  315. /* DSGCR */
  316. #define DQSGX_SHIFT 5
  317. #define DQSGX_MASK 7
  318. #define DQSGE_SHIFT 8
  319. #define DQSGE_MASK 7
  320. /* SCTL */
  321. #define INIT_STATE 0
  322. #define CFG_STATE 1
  323. #define GO_STATE 2
  324. #define SLEEP_STATE 3
  325. #define WAKEUP_STATE 4
  326. /* STAT */
  327. #define LP_TRIG_SHIFT 4
  328. #define LP_TRIG_MASK 7
  329. #define PCTL_STAT_MSK 7
  330. #define INIT_MEM 0
  331. #define CONFIG 1
  332. #define CONFIG_REQ 2
  333. #define ACCESS 3
  334. #define ACCESS_REQ 4
  335. #define LOW_POWER 5
  336. #define LOW_POWER_ENTRY_REQ 6
  337. #define LOW_POWER_EXIT_REQ 7
  338. /* ZQCR*/
  339. #define PD_OUTPUT_SHIFT 0
  340. #define PU_OUTPUT_SHIFT 5
  341. #define PD_ONDIE_SHIFT 10
  342. #define PU_ONDIE_SHIFT 15
  343. #define ZDEN_SHIFT 28
  344. /* DDLGCR */
  345. #define SBIAS_BYPASS (1 << 23)
  346. /* MCFG */
  347. #define MDDR_LPDDR2_CLK_STOP_IDLE_SHIFT 24
  348. #define PD_IDLE_SHIFT 8
  349. #define MDDR_EN (2 << 22)
  350. #define LPDDR2_EN (3 << 22)
  351. #define DDR2_EN (0 << 5)
  352. #define DDR3_EN (1 << 5)
  353. #define LPDDR2_S2 (0 << 6)
  354. #define LPDDR2_S4 (1 << 6)
  355. #define MDDR_LPDDR2_BL_2 (0 << 20)
  356. #define MDDR_LPDDR2_BL_4 (1 << 20)
  357. #define MDDR_LPDDR2_BL_8 (2 << 20)
  358. #define MDDR_LPDDR2_BL_16 (3 << 20)
  359. #define DDR2_DDR3_BL_4 0
  360. #define DDR2_DDR3_BL_8 1
  361. #define TFAW_SHIFT 18
  362. #define PD_EXIT_SLOW (0 << 17)
  363. #define PD_EXIT_FAST (1 << 17)
  364. #define PD_TYPE_SHIFT 16
  365. #define BURSTLENGTH_SHIFT 20
  366. /* POWCTL */
  367. #define POWER_UP_START (1 << 0)
  368. /* POWSTAT */
  369. #define POWER_UP_DONE (1 << 0)
  370. /* MCMD */
  371. enum {
  372. DESELECT_CMD = 0,
  373. PREA_CMD,
  374. REF_CMD,
  375. MRS_CMD,
  376. ZQCS_CMD,
  377. ZQCL_CMD,
  378. RSTL_CMD,
  379. MRR_CMD = 8,
  380. DPDE_CMD,
  381. };
  382. #define LPDDR2_MA_SHIFT 4
  383. #define LPDDR2_MA_MASK 0xff
  384. #define LPDDR2_OP_SHIFT 12
  385. #define LPDDR2_OP_MASK 0xff
  386. #define START_CMD (1u << 31)
  387. /* DEVTODEV */
  388. #define BUSWRTORD_SHIFT 4
  389. #define BUSRDTOWR_SHIFT 2
  390. #define BUSRDTORD_SHIFT 0
  391. /* mr1 for ddr3 */
  392. #define DDR3_DLL_DISABLE 1
  393. /*
  394. *TODO(sjg@chromium.org): We use a PMU register to store SDRAM information for
  395. * passing from SPL to U-Boot. It would probably be better to use a normal C
  396. * structure in SRAM.
  397. *
  398. * sys_reg bitfield struct
  399. * [31] row_3_4_ch1
  400. * [30] row_3_4_ch0
  401. * [29:28] chinfo
  402. * [27] rank_ch1
  403. * [26:25] col_ch1
  404. * [24] bk_ch1
  405. * [23:22] cs0_row_ch1
  406. * [21:20] cs1_row_ch1
  407. * [19:18] bw_ch1
  408. * [17:16] dbw_ch1;
  409. * [15:13] ddrtype
  410. * [12] channelnum
  411. * [11] rank_ch0
  412. * [10:9] col_ch0
  413. * [8] bk_ch0
  414. * [7:6] cs0_row_ch0
  415. * [5:4] cs1_row_ch0
  416. * [3:2] bw_ch0
  417. * [1:0] dbw_ch0
  418. */
  419. #define SYS_REG_DDRTYPE_SHIFT 13
  420. #define SYS_REG_DDRTYPE_MASK 7
  421. #define SYS_REG_NUM_CH_SHIFT 12
  422. #define SYS_REG_NUM_CH_MASK 1
  423. #define SYS_REG_ROW_3_4_SHIFT(ch) (30 + (ch))
  424. #define SYS_REG_ROW_3_4_MASK 1
  425. #define SYS_REG_CHINFO_SHIFT(ch) (28 + (ch))
  426. #define SYS_REG_RANK_SHIFT(ch) (11 + (ch) * 16)
  427. #define SYS_REG_RANK_MASK 1
  428. #define SYS_REG_COL_SHIFT(ch) (9 + (ch) * 16)
  429. #define SYS_REG_COL_MASK 3
  430. #define SYS_REG_BK_SHIFT(ch) (8 + (ch) * 16)
  431. #define SYS_REG_BK_MASK 1
  432. #define SYS_REG_CS0_ROW_SHIFT(ch) (6 + (ch) * 16)
  433. #define SYS_REG_CS0_ROW_MASK 3
  434. #define SYS_REG_CS1_ROW_SHIFT(ch) (4 + (ch) * 16)
  435. #define SYS_REG_CS1_ROW_MASK 3
  436. #define SYS_REG_BW_SHIFT(ch) (2 + (ch) * 16)
  437. #define SYS_REG_BW_MASK 3
  438. #define SYS_REG_DBW_SHIFT(ch) ((ch) * 16)
  439. #define SYS_REG_DBW_MASK 3
  440. #endif