ddr_rk3368.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /*
  2. * (C) Copyright 2017 Theobroma Systems Design und Consulting GmbH
  3. *
  4. * SPDX-License-Identifier: GPL-2.0
  5. */
  6. #ifndef __ASM_ARCH_DDR_RK3368_H__
  7. #define __ASM_ARCH_DDR_RK3368_H__
  8. /*
  9. * The RK3368 DDR PCTL differs from the incarnation in the RK3288 only
  10. * in a few details. Most notably, it has an additional field to track
  11. * tREFI in controller cycles (i.e. trefi_mem_ddr3).
  12. */
  13. struct rk3368_ddr_pctl {
  14. u32 scfg;
  15. u32 sctl;
  16. u32 stat;
  17. u32 intrstat;
  18. u32 reserved0[12];
  19. u32 mcmd;
  20. u32 powctl;
  21. u32 powstat;
  22. u32 cmdtstat;
  23. u32 cmdtstaten;
  24. u32 reserved1[3];
  25. u32 mrrcfg0;
  26. u32 mrrstat0;
  27. u32 mrrstat1;
  28. u32 reserved2[4];
  29. u32 mcfg1;
  30. u32 mcfg;
  31. u32 ppcfg;
  32. u32 mstat;
  33. u32 lpddr2zqcfg;
  34. u32 reserved3;
  35. u32 dtupdes;
  36. u32 dtuna;
  37. u32 dtune;
  38. u32 dtuprd0;
  39. u32 dtuprd1;
  40. u32 dtuprd2;
  41. u32 dtuprd3;
  42. u32 dtuawdt;
  43. u32 reserved4[3];
  44. u32 togcnt1u;
  45. u32 tinit;
  46. u32 trsth;
  47. u32 togcnt100n;
  48. u32 trefi;
  49. u32 tmrd;
  50. u32 trfc;
  51. u32 trp;
  52. u32 trtw;
  53. u32 tal;
  54. u32 tcl;
  55. u32 tcwl;
  56. u32 tras;
  57. u32 trc;
  58. u32 trcd;
  59. u32 trrd;
  60. u32 trtp;
  61. u32 twr;
  62. u32 twtr;
  63. u32 texsr;
  64. u32 txp;
  65. u32 txpdll;
  66. u32 tzqcs;
  67. u32 tzqcsi;
  68. u32 tdqs;
  69. u32 tcksre;
  70. u32 tcksrx;
  71. u32 tcke;
  72. u32 tmod;
  73. u32 trstl;
  74. u32 tzqcl;
  75. u32 tmrr;
  76. u32 tckesr;
  77. u32 tdpd;
  78. u32 trefi_mem_ddr3;
  79. u32 reserved5[45];
  80. u32 dtuwactl;
  81. u32 dturactl;
  82. u32 dtucfg;
  83. u32 dtuectl;
  84. u32 dtuwd0;
  85. u32 dtuwd1;
  86. u32 dtuwd2;
  87. u32 dtuwd3;
  88. u32 dtuwdm;
  89. u32 dturd0;
  90. u32 dturd1;
  91. u32 dturd2;
  92. u32 dturd3;
  93. u32 dtulfsrwd;
  94. u32 dtulfsrrd;
  95. u32 dtueaf;
  96. u32 dfitctrldelay;
  97. u32 dfiodtcfg;
  98. u32 dfiodtcfg1;
  99. u32 dfiodtrankmap;
  100. u32 dfitphywrdata;
  101. u32 dfitphywrlat;
  102. u32 reserved7[2];
  103. u32 dfitrddataen;
  104. u32 dfitphyrdlat;
  105. u32 reserved8[2];
  106. u32 dfitphyupdtype0;
  107. u32 dfitphyupdtype1;
  108. u32 dfitphyupdtype2;
  109. u32 dfitphyupdtype3;
  110. u32 dfitctrlupdmin;
  111. u32 dfitctrlupdmax;
  112. u32 dfitctrlupddly;
  113. u32 reserved9;
  114. u32 dfiupdcfg;
  115. u32 dfitrefmski;
  116. u32 dfitctrlupdi;
  117. u32 reserved10[4];
  118. u32 dfitrcfg0;
  119. u32 dfitrstat0;
  120. u32 dfitrwrlvlen;
  121. u32 dfitrrdlvlen;
  122. u32 dfitrrdlvlgateen;
  123. u32 dfiststat0;
  124. u32 dfistcfg0;
  125. u32 dfistcfg1;
  126. u32 reserved11;
  127. u32 dfitdramclken;
  128. u32 dfitdramclkdis;
  129. u32 dfistcfg2;
  130. u32 dfistparclr;
  131. u32 dfistparlog;
  132. u32 reserved12[3];
  133. u32 dfilpcfg0;
  134. u32 reserved13[3];
  135. u32 dfitrwrlvlresp0;
  136. u32 dfitrwrlvlresp1;
  137. u32 dfitrwrlvlresp2;
  138. u32 dfitrrdlvlresp0;
  139. u32 dfitrrdlvlresp1;
  140. u32 dfitrrdlvlresp2;
  141. u32 dfitrwrlvldelay0;
  142. u32 dfitrwrlvldelay1;
  143. u32 dfitrwrlvldelay2;
  144. u32 dfitrrdlvldelay0;
  145. u32 dfitrrdlvldelay1;
  146. u32 dfitrrdlvldelay2;
  147. u32 dfitrrdlvlgatedelay0;
  148. u32 dfitrrdlvlgatedelay1;
  149. u32 dfitrrdlvlgatedelay2;
  150. u32 dfitrcmd;
  151. u32 reserved14[46];
  152. u32 ipvr;
  153. u32 iptr;
  154. };
  155. check_member(rk3368_ddr_pctl, iptr, 0x03fc);
  156. struct rk3368_ddrphy {
  157. u32 reg[0x100];
  158. };
  159. check_member(rk3368_ddrphy, reg[0xff], 0x03fc);
  160. struct rk3368_msch {
  161. u32 coreid;
  162. u32 revisionid;
  163. u32 ddrconf;
  164. u32 ddrtiming;
  165. u32 ddrmode;
  166. u32 readlatency;
  167. u32 reserved1[8];
  168. u32 activate;
  169. u32 devtodev;
  170. };
  171. check_member(rk3368_msch, devtodev, 0x003c);
  172. /* GRF_SOC_CON0 */
  173. enum {
  174. NOC_RSP_ERR_STALL = BIT(9),
  175. MOBILE_DDR_SEL = BIT(4),
  176. DDR0_16BIT_EN = BIT(3),
  177. MSCH0_MAINDDR3_DDR3 = BIT(2),
  178. MSCH0_MAINPARTIALPOP = BIT(1),
  179. UPCTL_C_ACTIVE = BIT(0),
  180. };
  181. #endif