sdram_rk322x.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * (C) Copyright 2017 Rockchip Electronics Co., Ltd
  4. */
  5. #ifndef _ASM_ARCH_SDRAM_RK322X_H
  6. #define _ASM_ARCH_SDRAM_RK322X_H
  7. #include <common.h>
  8. enum {
  9. DDR3 = 3,
  10. LPDDR2 = 5,
  11. LPDDR3 = 6,
  12. UNUSED = 0xFF,
  13. };
  14. struct rk322x_sdram_channel {
  15. /*
  16. * bit width in address, eg:
  17. * 8 banks using 3 bit to address,
  18. * 2 cs using 1 bit to address.
  19. */
  20. u8 rank;
  21. u8 col;
  22. u8 bk;
  23. u8 bw;
  24. u8 dbw;
  25. u8 row_3_4;
  26. u8 cs0_row;
  27. u8 cs1_row;
  28. #if CONFIG_IS_ENABLED(OF_PLATDATA)
  29. /*
  30. * For of-platdata, which would otherwise convert this into two
  31. * byte-swapped integers. With a size of 9 bytes, this struct will
  32. * appear in of-platdata as a byte array.
  33. *
  34. * If OF_PLATDATA enabled, need to add a dummy byte in dts.(i.e 0xff)
  35. */
  36. u8 dummy;
  37. #endif
  38. };
  39. struct rk322x_ddr_pctl {
  40. u32 scfg;
  41. u32 sctl;
  42. u32 stat;
  43. u32 intrstat;
  44. u32 reserved0[(0x40 - 0x10) / 4];
  45. u32 mcmd;
  46. u32 powctl;
  47. u32 powstat;
  48. u32 cmdtstat;
  49. u32 cmdtstaten;
  50. u32 reserved1[(0x60 - 0x54) / 4];
  51. u32 mrrcfg0;
  52. u32 mrrstat0;
  53. u32 mrrstat1;
  54. u32 reserved2[(0x7c - 0x6c) / 4];
  55. u32 mcfg1;
  56. u32 mcfg;
  57. u32 ppcfg;
  58. u32 mstat;
  59. u32 lpddr2zqcfg;
  60. u32 reserved3;
  61. u32 dtupdes;
  62. u32 dtuna;
  63. u32 dtune;
  64. u32 dtuprd0;
  65. u32 dtuprd1;
  66. u32 dtuprd2;
  67. u32 dtuprd3;
  68. u32 dtuawdt;
  69. u32 reserved4[(0xc0 - 0xb4) / 4];
  70. u32 togcnt1u;
  71. u32 tinit;
  72. u32 trsth;
  73. u32 togcnt100n;
  74. u32 trefi;
  75. u32 tmrd;
  76. u32 trfc;
  77. u32 trp;
  78. u32 trtw;
  79. u32 tal;
  80. u32 tcl;
  81. u32 tcwl;
  82. u32 tras;
  83. u32 trc;
  84. u32 trcd;
  85. u32 trrd;
  86. u32 trtp;
  87. u32 twr;
  88. u32 twtr;
  89. u32 texsr;
  90. u32 txp;
  91. u32 txpdll;
  92. u32 tzqcs;
  93. u32 tzqcsi;
  94. u32 tdqs;
  95. u32 tcksre;
  96. u32 tcksrx;
  97. u32 tcke;
  98. u32 tmod;
  99. u32 trstl;
  100. u32 tzqcl;
  101. u32 tmrr;
  102. u32 tckesr;
  103. u32 tdpd;
  104. u32 tref_mem_ddr3;
  105. u32 reserved5[(0x180 - 0x14c) / 4];
  106. u32 ecccfg;
  107. u32 ecctst;
  108. u32 eccclr;
  109. u32 ecclog;
  110. u32 reserved6[(0x200 - 0x190) / 4];
  111. u32 dtuwactl;
  112. u32 dturactl;
  113. u32 dtucfg;
  114. u32 dtuectl;
  115. u32 dtuwd0;
  116. u32 dtuwd1;
  117. u32 dtuwd2;
  118. u32 dtuwd3;
  119. u32 dtuwdm;
  120. u32 dturd0;
  121. u32 dturd1;
  122. u32 dturd2;
  123. u32 dturd3;
  124. u32 dtulfsrwd;
  125. u32 dtulfsrrd;
  126. u32 dtueaf;
  127. /* dfi control registers */
  128. u32 dfitctrldelay;
  129. u32 dfiodtcfg;
  130. u32 dfiodtcfg1;
  131. u32 dfiodtrankmap;
  132. /* dfi write data registers */
  133. u32 dfitphywrdata;
  134. u32 dfitphywrlat;
  135. u32 reserved7[(0x260 - 0x258) / 4];
  136. u32 dfitrddataen;
  137. u32 dfitphyrdlat;
  138. u32 reserved8[(0x270 - 0x268) / 4];
  139. u32 dfitphyupdtype0;
  140. u32 dfitphyupdtype1;
  141. u32 dfitphyupdtype2;
  142. u32 dfitphyupdtype3;
  143. u32 dfitctrlupdmin;
  144. u32 dfitctrlupdmax;
  145. u32 dfitctrlupddly;
  146. u32 reserved9;
  147. u32 dfiupdcfg;
  148. u32 dfitrefmski;
  149. u32 dfitctrlupdi;
  150. u32 reserved10[(0x2ac - 0x29c) / 4];
  151. u32 dfitrcfg0;
  152. u32 dfitrstat0;
  153. u32 dfitrwrlvlen;
  154. u32 dfitrrdlvlen;
  155. u32 dfitrrdlvlgateen;
  156. u32 dfiststat0;
  157. u32 dfistcfg0;
  158. u32 dfistcfg1;
  159. u32 reserved11;
  160. u32 dfitdramclken;
  161. u32 dfitdramclkdis;
  162. u32 dfistcfg2;
  163. u32 dfistparclr;
  164. u32 dfistparlog;
  165. u32 reserved12[(0x2f0 - 0x2e4) / 4];
  166. u32 dfilpcfg0;
  167. u32 reserved13[(0x300 - 0x2f4) / 4];
  168. u32 dfitrwrlvlresp0;
  169. u32 dfitrwrlvlresp1;
  170. u32 dfitrwrlvlresp2;
  171. u32 dfitrrdlvlresp0;
  172. u32 dfitrrdlvlresp1;
  173. u32 dfitrrdlvlresp2;
  174. u32 dfitrwrlvldelay0;
  175. u32 dfitrwrlvldelay1;
  176. u32 dfitrwrlvldelay2;
  177. u32 dfitrrdlvldelay0;
  178. u32 dfitrrdlvldelay1;
  179. u32 dfitrrdlvldelay2;
  180. u32 dfitrrdlvlgatedelay0;
  181. u32 dfitrrdlvlgatedelay1;
  182. u32 dfitrrdlvlgatedelay2;
  183. u32 dfitrcmd;
  184. u32 reserved14[(0x3f8 - 0x340) / 4];
  185. u32 ipvr;
  186. u32 iptr;
  187. };
  188. check_member(rk322x_ddr_pctl, iptr, 0x03fc);
  189. struct rk322x_ddr_phy {
  190. u32 ddrphy_reg[0x100];
  191. };
  192. struct rk322x_pctl_timing {
  193. u32 togcnt1u;
  194. u32 tinit;
  195. u32 trsth;
  196. u32 togcnt100n;
  197. u32 trefi;
  198. u32 tmrd;
  199. u32 trfc;
  200. u32 trp;
  201. u32 trtw;
  202. u32 tal;
  203. u32 tcl;
  204. u32 tcwl;
  205. u32 tras;
  206. u32 trc;
  207. u32 trcd;
  208. u32 trrd;
  209. u32 trtp;
  210. u32 twr;
  211. u32 twtr;
  212. u32 texsr;
  213. u32 txp;
  214. u32 txpdll;
  215. u32 tzqcs;
  216. u32 tzqcsi;
  217. u32 tdqs;
  218. u32 tcksre;
  219. u32 tcksrx;
  220. u32 tcke;
  221. u32 tmod;
  222. u32 trstl;
  223. u32 tzqcl;
  224. u32 tmrr;
  225. u32 tckesr;
  226. u32 tdpd;
  227. u32 trefi_mem_ddr3;
  228. };
  229. struct rk322x_phy_timing {
  230. u32 mr[4];
  231. u32 mr11;
  232. u32 bl;
  233. u32 cl_al;
  234. };
  235. struct rk322x_msch_timings {
  236. u32 ddrtiming;
  237. u32 ddrmode;
  238. u32 readlatency;
  239. u32 activate;
  240. u32 devtodev;
  241. };
  242. struct rk322x_service_sys {
  243. u32 id_coreid;
  244. u32 id_revisionid;
  245. u32 ddrconf;
  246. u32 ddrtiming;
  247. u32 ddrmode;
  248. u32 readlatency;
  249. u32 activate;
  250. u32 devtodev;
  251. };
  252. struct rk322x_base_params {
  253. struct rk322x_msch_timings noc_timing;
  254. u32 ddrconfig;
  255. u32 ddr_freq;
  256. u32 dramtype;
  257. /*
  258. * unused for rk322x
  259. */
  260. u32 stride;
  261. u32 odt;
  262. };
  263. /* PCT_DFISTCFG0 */
  264. #define DFI_INIT_START BIT(0)
  265. #define DFI_DATA_BYTE_DISABLE_EN BIT(2)
  266. /* PCT_DFISTCFG1 */
  267. #define DFI_DRAM_CLK_SR_EN BIT(0)
  268. #define DFI_DRAM_CLK_DPD_EN BIT(1)
  269. /* PCT_DFISTCFG2 */
  270. #define DFI_PARITY_INTR_EN BIT(0)
  271. #define DFI_PARITY_EN BIT(1)
  272. /* PCT_DFILPCFG0 */
  273. #define TLP_RESP_TIME_SHIFT 16
  274. #define LP_SR_EN BIT(8)
  275. #define LP_PD_EN BIT(0)
  276. /* PCT_DFITCTRLDELAY */
  277. #define TCTRL_DELAY_TIME_SHIFT 0
  278. /* PCT_DFITPHYWRDATA */
  279. #define TPHY_WRDATA_TIME_SHIFT 0
  280. /* PCT_DFITPHYRDLAT */
  281. #define TPHY_RDLAT_TIME_SHIFT 0
  282. /* PCT_DFITDRAMCLKDIS */
  283. #define TDRAM_CLK_DIS_TIME_SHIFT 0
  284. /* PCT_DFITDRAMCLKEN */
  285. #define TDRAM_CLK_EN_TIME_SHIFT 0
  286. /* PCTL_DFIODTCFG */
  287. #define RANK0_ODT_WRITE_SEL BIT(3)
  288. #define RANK1_ODT_WRITE_SEL BIT(11)
  289. /* PCTL_DFIODTCFG1 */
  290. #define ODT_LEN_BL8_W_SHIFT 16
  291. /* PUBL_ACDLLCR */
  292. #define ACDLLCR_DLLDIS BIT(31)
  293. #define ACDLLCR_DLLSRST BIT(30)
  294. /* PUBL_DXDLLCR */
  295. #define DXDLLCR_DLLDIS BIT(31)
  296. #define DXDLLCR_DLLSRST BIT(30)
  297. /* PUBL_DLLGCR */
  298. #define DLLGCR_SBIAS BIT(30)
  299. /* PUBL_DXGCR */
  300. #define DQSRTT BIT(9)
  301. #define DQRTT BIT(10)
  302. /* PIR */
  303. #define PIR_INIT BIT(0)
  304. #define PIR_DLLSRST BIT(1)
  305. #define PIR_DLLLOCK BIT(2)
  306. #define PIR_ZCAL BIT(3)
  307. #define PIR_ITMSRST BIT(4)
  308. #define PIR_DRAMRST BIT(5)
  309. #define PIR_DRAMINIT BIT(6)
  310. #define PIR_QSTRN BIT(7)
  311. #define PIR_RVTRN BIT(8)
  312. #define PIR_ICPC BIT(16)
  313. #define PIR_DLLBYP BIT(17)
  314. #define PIR_CTLDINIT BIT(18)
  315. #define PIR_CLRSR BIT(28)
  316. #define PIR_LOCKBYP BIT(29)
  317. #define PIR_ZCALBYP BIT(30)
  318. #define PIR_INITBYP BIT(31)
  319. /* PGCR */
  320. #define PGCR_DFTLMT_SHIFT 3
  321. #define PGCR_DFTCMP_SHIFT 2
  322. #define PGCR_DQSCFG_SHIFT 1
  323. #define PGCR_ITMDMD_SHIFT 0
  324. /* PGSR */
  325. #define PGSR_IDONE BIT(0)
  326. #define PGSR_DLDONE BIT(1)
  327. #define PGSR_ZCDONE BIT(2)
  328. #define PGSR_DIDONE BIT(3)
  329. #define PGSR_DTDONE BIT(4)
  330. #define PGSR_DTERR BIT(5)
  331. #define PGSR_DTIERR BIT(6)
  332. #define PGSR_DFTERR BIT(7)
  333. #define PGSR_RVERR BIT(8)
  334. #define PGSR_RVEIRR BIT(9)
  335. /* PTR0 */
  336. #define PRT_ITMSRST_SHIFT 18
  337. #define PRT_DLLLOCK_SHIFT 6
  338. #define PRT_DLLSRST_SHIFT 0
  339. /* PTR1 */
  340. #define PRT_DINIT0_SHIFT 0
  341. #define PRT_DINIT1_SHIFT 19
  342. /* PTR2 */
  343. #define PRT_DINIT2_SHIFT 0
  344. #define PRT_DINIT3_SHIFT 17
  345. /* DCR */
  346. #define DDRMD_LPDDR 0
  347. #define DDRMD_DDR 1
  348. #define DDRMD_DDR2 2
  349. #define DDRMD_DDR3 3
  350. #define DDRMD_LPDDR2_LPDDR3 4
  351. #define DDRMD_MASK 7
  352. #define DDRMD_SHIFT 0
  353. #define PDQ_MASK 7
  354. #define PDQ_SHIFT 4
  355. /* DXCCR */
  356. #define DQSNRES_MASK 0xf
  357. #define DQSNRES_SHIFT 8
  358. #define DQSRES_MASK 0xf
  359. #define DQSRES_SHIFT 4
  360. /* DTPR */
  361. #define TDQSCKMAX_SHIFT 27
  362. #define TDQSCKMAX_MASK 7
  363. #define TDQSCK_SHIFT 24
  364. #define TDQSCK_MASK 7
  365. /* DSGCR */
  366. #define DQSGX_SHIFT 5
  367. #define DQSGX_MASK 7
  368. #define DQSGE_SHIFT 8
  369. #define DQSGE_MASK 7
  370. /* SCTL */
  371. #define INIT_STATE 0
  372. #define CFG_STATE 1
  373. #define GO_STATE 2
  374. #define SLEEP_STATE 3
  375. #define WAKEUP_STATE 4
  376. /* STAT */
  377. #define LP_TRIG_SHIFT 4
  378. #define LP_TRIG_MASK 7
  379. #define PCTL_STAT_MASK 7
  380. #define INIT_MEM 0
  381. #define CONFIG 1
  382. #define CONFIG_REQ 2
  383. #define ACCESS 3
  384. #define ACCESS_REQ 4
  385. #define LOW_POWER 5
  386. #define LOW_POWER_ENTRY_REQ 6
  387. #define LOW_POWER_EXIT_REQ 7
  388. /* ZQCR*/
  389. #define PD_OUTPUT_SHIFT 0
  390. #define PU_OUTPUT_SHIFT 5
  391. #define PD_ONDIE_SHIFT 10
  392. #define PU_ONDIE_SHIFT 15
  393. #define ZDEN_SHIFT 28
  394. /* DDLGCR */
  395. #define SBIAS_BYPASS BIT(23)
  396. /* MCFG */
  397. #define MDDR_LPDDR2_CLK_STOP_IDLE_SHIFT 24
  398. #define PD_IDLE_SHIFT 8
  399. #define MDDR_EN (2 << 22)
  400. #define LPDDR2_EN (3 << 22)
  401. #define LPDDR3_EN (1 << 22)
  402. #define DDR2_EN (0 << 5)
  403. #define DDR3_EN (1 << 5)
  404. #define LPDDR2_S2 (0 << 6)
  405. #define LPDDR2_S4 (1 << 6)
  406. #define MDDR_LPDDR2_BL_2 (0 << 20)
  407. #define MDDR_LPDDR2_BL_4 (1 << 20)
  408. #define MDDR_LPDDR2_BL_8 (2 << 20)
  409. #define MDDR_LPDDR2_BL_16 (3 << 20)
  410. #define DDR2_DDR3_BL_4 0
  411. #define DDR2_DDR3_BL_8 1
  412. #define TFAW_SHIFT 18
  413. #define PD_EXIT_SLOW (0 << 17)
  414. #define PD_EXIT_FAST (1 << 17)
  415. #define PD_TYPE_SHIFT 16
  416. #define BURSTLENGTH_SHIFT 20
  417. /* POWCTL */
  418. #define POWER_UP_START BIT(0)
  419. /* POWSTAT */
  420. #define POWER_UP_DONE BIT(0)
  421. /* MCMD */
  422. enum {
  423. DESELECT_CMD = 0,
  424. PREA_CMD,
  425. REF_CMD,
  426. MRS_CMD,
  427. ZQCS_CMD,
  428. ZQCL_CMD,
  429. RSTL_CMD,
  430. MRR_CMD = 8,
  431. DPDE_CMD,
  432. };
  433. #define BANK_ADDR_MASK 7
  434. #define BANK_ADDR_SHIFT 17
  435. #define CMD_ADDR_MASK 0x1fff
  436. #define CMD_ADDR_SHIFT 4
  437. #define LPDDR23_MA_SHIFT 4
  438. #define LPDDR23_MA_MASK 0xff
  439. #define LPDDR23_OP_SHIFT 12
  440. #define LPDDR23_OP_MASK 0xff
  441. #define START_CMD (1u << 31)
  442. /* DDRPHY REG */
  443. enum {
  444. /* DDRPHY_REG0 */
  445. SOFT_RESET_MASK = 3,
  446. SOFT_DERESET_ANALOG = 1 << 2,
  447. SOFT_DERESET_DIGITAL = 1 << 3,
  448. SOFT_RESET_SHIFT = 2,
  449. /* DDRPHY REG1 */
  450. PHY_DDR3 = 0,
  451. PHY_DDR2 = 1,
  452. PHY_LPDDR3 = 2,
  453. PHY_LPDDR2 = 3,
  454. PHT_BL_8 = 1 << 2,
  455. PHY_BL_4 = 0 << 2,
  456. /* DDRPHY_REG2 */
  457. MEMORY_SELECT_DDR3 = 0 << 0,
  458. MEMORY_SELECT_LPDDR3 = 2 << 0,
  459. MEMORY_SELECT_LPDDR2 = 3 << 0,
  460. DQS_SQU_CAL_SEL_CS0_CS1 = 0 << 4,
  461. DQS_SQU_CAL_SEL_CS1 = 1 << 4,
  462. DQS_SQU_CAL_SEL_CS0 = 2 << 4,
  463. DQS_SQU_CAL_NORMAL_MODE = 0 << 1,
  464. DQS_SQU_CAL_BYPASS_MODE = 1 << 1,
  465. DQS_SQU_CAL_START = 1 << 0,
  466. DQS_SQU_NO_CAL = 0 << 0,
  467. };
  468. /* CK pull up/down driver strength control */
  469. enum {
  470. PHY_RON_RTT_DISABLE = 0,
  471. PHY_RON_RTT_451OHM = 1,
  472. PHY_RON_RTT_225OHM,
  473. PHY_RON_RTT_150OHM,
  474. PHY_RON_RTT_112OHM,
  475. PHY_RON_RTT_90OHM,
  476. PHY_RON_RTT_75OHM,
  477. PHY_RON_RTT_64OHM = 7,
  478. PHY_RON_RTT_56OHM = 16,
  479. PHY_RON_RTT_50OHM,
  480. PHY_RON_RTT_45OHM,
  481. PHY_RON_RTT_41OHM,
  482. PHY_RON_RTT_37OHM,
  483. PHY_RON_RTT_34OHM,
  484. PHY_RON_RTT_33OHM,
  485. PHY_RON_RTT_30OHM = 23,
  486. PHY_RON_RTT_28OHM = 24,
  487. PHY_RON_RTT_26OHM,
  488. PHY_RON_RTT_25OHM,
  489. PHY_RON_RTT_23OHM,
  490. PHY_RON_RTT_22OHM,
  491. PHY_RON_RTT_21OHM,
  492. PHY_RON_RTT_20OHM,
  493. PHY_RON_RTT_19OHM = 31,
  494. };
  495. /* DQS squelch DLL delay */
  496. enum {
  497. DQS_DLL_NO_DELAY = 0,
  498. DQS_DLL_22P5_DELAY,
  499. DQS_DLL_45_DELAY,
  500. DQS_DLL_67P5_DELAY,
  501. DQS_DLL_90_DELAY,
  502. DQS_DLL_112P5_DELAY,
  503. DQS_DLL_135_DELAY,
  504. DQS_DLL_157P5_DELAY,
  505. };
  506. /* GRF_SOC_CON0 */
  507. #define GRF_DDR_16BIT_EN (((0x1 << 0) << 16) | (0x1 << 0))
  508. #define GRF_DDR_32BIT_EN (((0x1 << 0) << 16) | (0x0 << 0))
  509. #define GRF_MSCH_NOC_16BIT_EN (((0x1 << 7) << 16) | (0x1 << 7))
  510. #define GRF_MSCH_NOC_32BIT_EN (((0x1 << 7) << 16) | (0x0 << 7))
  511. #define GRF_DDRPHY_BUFFEREN_CORE_EN (((0x1 << 8) << 16) | (0x0 << 8))
  512. #define GRF_DDRPHY_BUFFEREN_CORE_DIS (((0x1 << 8) << 16) | (0x1 << 8))
  513. #define GRF_DDR3_EN (((0x1 << 6) << 16) | (0x1 << 6))
  514. #define GRF_LPDDR2_3_EN (((0x1 << 6) << 16) | (0x0 << 6))
  515. #define PHY_DRV_ODT_SET(n) (((n) << 4) | (n))
  516. #define DDR3_DLL_RESET (1 << 8)
  517. #endif /* _ASM_ARCH_SDRAM_RK322X_H */