sdram_rk3036.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. /*
  2. * (C) Copyright 2015 Rockchip Electronics Co., Ltd
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef _ASM_ARCH_SDRAM_RK3036_H
  7. #define _ASM_ARCH_SDRAM_RK3036_H
  8. #include <common.h>
  9. struct rk3036_ddr_pctl {
  10. u32 scfg;
  11. u32 sctl;
  12. u32 stat;
  13. u32 intrstat;
  14. u32 reserved0[12];
  15. u32 mcmd;
  16. u32 powctl;
  17. u32 powstat;
  18. u32 cmdtstat;
  19. u32 cmdtstaten;
  20. u32 reserved1[3];
  21. u32 mrrcfg0;
  22. u32 mrrstat0;
  23. u32 mrrstat1;
  24. u32 reserved2[4];
  25. u32 mcfg1;
  26. u32 mcfg;
  27. u32 ppcfg;
  28. u32 mstat;
  29. u32 lpddr2zqcfg;
  30. u32 reserved3;
  31. u32 dtupdes;
  32. u32 dtuna;
  33. u32 dtune;
  34. u32 dtuprd0;
  35. u32 dtuprd1;
  36. u32 dtuprd2;
  37. u32 dtuprd3;
  38. u32 dtuawdt;
  39. u32 reserved4[3];
  40. u32 togcnt1u;
  41. u32 tinit;
  42. u32 trsth;
  43. u32 togcnt100n;
  44. u32 trefi;
  45. u32 tmrd;
  46. u32 trfc;
  47. u32 trp;
  48. u32 trtw;
  49. u32 tal;
  50. u32 tcl;
  51. u32 tcwl;
  52. u32 tras;
  53. u32 trc;
  54. u32 trcd;
  55. u32 trrd;
  56. u32 trtp;
  57. u32 twr;
  58. u32 twtr;
  59. u32 texsr;
  60. u32 txp;
  61. u32 txpdll;
  62. u32 tzqcs;
  63. u32 tzqcsi;
  64. u32 tdqs;
  65. u32 tcksre;
  66. u32 tcksrx;
  67. u32 tcke;
  68. u32 tmod;
  69. u32 trstl;
  70. u32 tzqcl;
  71. u32 tmrr;
  72. u32 tckesr;
  73. u32 reserved5[47];
  74. u32 dtuwactl;
  75. u32 dturactl;
  76. u32 dtucfg;
  77. u32 dtuectl;
  78. u32 dtuwd0;
  79. u32 dtuwd1;
  80. u32 dtuwd2;
  81. u32 dtuwd3;
  82. u32 dtuwdm;
  83. u32 dturd0;
  84. u32 dturd1;
  85. u32 dturd2;
  86. u32 dturd3;
  87. u32 dtulfsrwd;
  88. u32 dtulfsrrd;
  89. u32 dtueaf;
  90. u32 dfitctrldelay;
  91. u32 dfiodtcfg;
  92. u32 dfiodtcfg1;
  93. u32 dfiodtrankmap;
  94. u32 dfitphywrdata;
  95. u32 dfitphywrlat;
  96. u32 reserved7[2];
  97. u32 dfitrddataen;
  98. u32 dfitphyrdlat;
  99. u32 reserved8[2];
  100. u32 dfitphyupdtype0;
  101. u32 dfitphyupdtype1;
  102. u32 dfitphyupdtype2;
  103. u32 dfitphyupdtype3;
  104. u32 dfitctrlupdmin;
  105. u32 dfitctrlupdmax;
  106. u32 dfitctrlupddly;
  107. u32 reserved9;
  108. u32 dfiupdcfg;
  109. u32 dfitrefmski;
  110. u32 dfitctrlupdi;
  111. u32 reserved10[4];
  112. u32 dfitrcfg0;
  113. u32 dfitrstat0;
  114. u32 dfitrwrlvlen;
  115. u32 dfitrrdlvlen;
  116. u32 dfitrrdlvlgateen;
  117. u32 dfiststat0;
  118. u32 dfistcfg0;
  119. u32 dfistcfg1;
  120. u32 reserved11;
  121. u32 dfitdramclken;
  122. u32 dfitdramclkdis;
  123. u32 dfistcfg2;
  124. u32 dfistparclr;
  125. u32 dfistparlog;
  126. u32 reserved12[3];
  127. u32 dfilpcfg0;
  128. u32 reserved13[3];
  129. u32 dfitrwrlvlresp0;
  130. u32 dfitrwrlvlresp1;
  131. u32 dfitrwrlvlresp2;
  132. u32 dfitrrdlvlresp0;
  133. u32 dfitrrdlvlresp1;
  134. u32 dfitrrdlvlresp2;
  135. u32 dfitrwrlvldelay0;
  136. u32 dfitrwrlvldelay1;
  137. u32 dfitrwrlvldelay2;
  138. u32 dfitrrdlvldelay0;
  139. u32 dfitrrdlvldelay1;
  140. u32 dfitrrdlvldelay2;
  141. u32 dfitrrdlvlgatedelay0;
  142. u32 dfitrrdlvlgatedelay1;
  143. u32 dfitrrdlvlgatedelay2;
  144. u32 dfitrcmd;
  145. u32 reserved14[46];
  146. u32 ipvr;
  147. u32 iptr;
  148. };
  149. check_member(rk3036_ddr_pctl, iptr, 0x03fc);
  150. struct rk3036_ddr_phy {
  151. u32 ddrphy_reg1;
  152. u32 ddrphy_reg3;
  153. u32 ddrphy_reg2;
  154. u32 reserve[11];
  155. u32 ddrphy_reg4a;
  156. u32 ddrphy_reg4b;
  157. u32 reserve1[5];
  158. u32 ddrphy_reg16;
  159. u32 reserve2;
  160. u32 ddrphy_reg18;
  161. u32 ddrphy_reg19;
  162. u32 reserve3;
  163. u32 ddrphy_reg21;
  164. u32 reserve4;
  165. u32 ddrphy_reg22;
  166. u32 reserve5[3];
  167. u32 ddrphy_reg25;
  168. u32 ddrphy_reg26;
  169. u32 ddrphy_reg27;
  170. u32 ddrphy_reg28;
  171. u32 reserve6[17];
  172. u32 ddrphy_reg6;
  173. u32 ddrphy_reg7;
  174. u32 reserve7;
  175. u32 ddrphy_reg8;
  176. u32 ddrphy_reg0e4;
  177. u32 reserve8[11];
  178. u32 ddrphy_reg9;
  179. u32 ddrphy_reg10;
  180. u32 reserve9;
  181. u32 ddrphy_reg11;
  182. u32 ddrphy_reg124;
  183. u32 reserve10[38];
  184. u32 ddrphy_reg29;
  185. u32 reserve11[40];
  186. u32 ddrphy_reg264;
  187. u32 reserve12[18];
  188. u32 ddrphy_reg2a;
  189. u32 reserve13[4];
  190. u32 ddrphy_reg30;
  191. u32 ddrphy_reg31;
  192. u32 ddrphy_reg32;
  193. u32 ddrphy_reg33;
  194. u32 ddrphy_reg34;
  195. u32 ddrphy_reg35;
  196. u32 ddrphy_reg36;
  197. u32 ddrphy_reg37;
  198. u32 ddrphy_reg38;
  199. u32 ddrphy_reg39;
  200. u32 ddrphy_reg40;
  201. u32 ddrphy_reg41;
  202. u32 ddrphy_reg42;
  203. u32 ddrphy_reg43;
  204. u32 ddrphy_reg44;
  205. u32 ddrphy_reg45;
  206. u32 ddrphy_reg46;
  207. u32 ddrphy_reg47;
  208. u32 ddrphy_reg48;
  209. u32 ddrphy_reg49;
  210. u32 ddrphy_reg50;
  211. u32 ddrphy_reg51;
  212. u32 ddrphy_reg52;
  213. u32 ddrphy_reg53;
  214. u32 reserve14;
  215. u32 ddrphy_reg54;
  216. u32 ddrphy_reg55;
  217. u32 ddrphy_reg56;
  218. u32 ddrphy_reg57;
  219. u32 ddrphy_reg58;
  220. u32 ddrphy_reg59;
  221. u32 ddrphy_reg5a;
  222. u32 ddrphy_reg5b;
  223. u32 ddrphy_reg5c;
  224. u32 ddrphy_reg5d;
  225. u32 ddrphy_reg5e;
  226. u32 reserve15[28];
  227. u32 ddrphy_reg5f;
  228. u32 reserve16[6];
  229. u32 ddrphy_reg60;
  230. u32 ddrphy_reg61;
  231. u32 ddrphy_reg62;
  232. };
  233. check_member(rk3036_ddr_phy, ddrphy_reg62, 0x03e8);
  234. struct rk3036_pctl_timing {
  235. u32 togcnt1u;
  236. u32 tinit;
  237. u32 trsth;
  238. u32 togcnt100n;
  239. u32 trefi;
  240. u32 tmrd;
  241. u32 trfc;
  242. u32 trp;
  243. u32 trtw;
  244. u32 tal;
  245. u32 tcl;
  246. u32 tcwl;
  247. u32 tras;
  248. u32 trc;
  249. u32 trcd;
  250. u32 trrd;
  251. u32 trtp;
  252. u32 twr;
  253. u32 twtr;
  254. u32 texsr;
  255. u32 txp;
  256. u32 txpdll;
  257. u32 tzqcs;
  258. u32 tzqcsi;
  259. u32 tdqs;
  260. u32 tcksre;
  261. u32 tcksrx;
  262. u32 tcke;
  263. u32 tmod;
  264. u32 trstl;
  265. u32 tzqcl;
  266. u32 tmrr;
  267. u32 tckesr;
  268. u32 tdpd;
  269. };
  270. struct rk3036_phy_timing {
  271. u32 mr[4];
  272. u32 bl;
  273. u32 cl_al;
  274. };
  275. typedef union {
  276. u32 noc_timing;
  277. struct {
  278. u32 acttoact:6;
  279. u32 rdtomiss:6;
  280. u32 wrtomiss:6;
  281. u32 burstlen:3;
  282. u32 rdtowr:5;
  283. u32 wrtord:5;
  284. u32 bwratio:1;
  285. };
  286. } rk3036_noc_timing;
  287. struct rk3036_ddr_timing {
  288. u32 freq;
  289. struct rk3036_pctl_timing pctl_timing;
  290. struct rk3036_phy_timing phy_timing;
  291. rk3036_noc_timing noc_timing;
  292. };
  293. struct rk3036_service_sys {
  294. u32 id_coreid;
  295. u32 id_revisionid;
  296. u32 ddrconf;
  297. u32 ddrtiming;
  298. u32 ddrmode;
  299. u32 readlatency;
  300. };
  301. struct rk3036_ddr_config {
  302. /*
  303. * 000: lpddr
  304. * 001: ddr
  305. * 010: ddr2
  306. * 011: ddr3
  307. * 100: lpddr2-s2
  308. * 101: lpddr2-s4
  309. * 110: lpddr3
  310. */
  311. u32 ddr_type;
  312. u32 rank;
  313. u32 cs0_row;
  314. u32 cs1_row;
  315. /* 2: 4bank, 3: 8bank */
  316. u32 bank;
  317. u32 col;
  318. /* bw(0: 8bit, 1: 16bit, 2: 32bit) */
  319. u32 bw;
  320. };
  321. /* rk3036 sdram initial */
  322. void sdram_init(void);
  323. /* get ddr die config, implement in specific board */
  324. void get_ddr_config(struct rk3036_ddr_config *config);
  325. /* get ddr size on board */
  326. size_t sdram_size(void);
  327. #endif