mx7-ddr.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. /*
  2. * DDR controller registers of the i.MX7 architecture
  3. *
  4. * (C) Copyright 2017 CompuLab, Ltd. http://www.compulab.com
  5. *
  6. * Author: Uri Mashiach <uri.mashiach@compulab.co.il>
  7. *
  8. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. #ifndef __ASM_ARCH_MX7_DDR_H__
  11. #define __ASM_ARCH_MX7_DDR_H__
  12. /* DDRC Registers (DDRC_IPS_BASE_ADDR) */
  13. struct ddrc {
  14. u32 mstr; /* 0x0000 */
  15. u32 reserved1[0x18];
  16. u32 rfshtmg; /* 0x0064 */
  17. u32 reserved2[0x1a];
  18. u32 init0; /* 0x00d0 */
  19. u32 init1; /* 0x00d4 */
  20. u32 reserved3;
  21. u32 init3; /* 0x00dc */
  22. u32 init4; /* 0x00e0 */
  23. u32 init5; /* 0x00e4 */
  24. u32 reserved4[0x03];
  25. u32 rankctl; /* 0x00f4 */
  26. u32 reserved5[0x02];
  27. u32 dramtmg0; /* 0x0100 */
  28. u32 dramtmg1; /* 0x0104 */
  29. u32 dramtmg2; /* 0x0108 */
  30. u32 dramtmg3; /* 0x010c */
  31. u32 dramtmg4; /* 0x0110 */
  32. u32 dramtmg5; /* 0x0114 */
  33. u32 reserved6[0x02];
  34. u32 dramtmg8; /* 0x0120 */
  35. u32 reserved7[0x17];
  36. u32 zqctl0; /* 0x0180 */
  37. u32 reserved8[0x03];
  38. u32 dfitmg0; /* 0x0190 */
  39. u32 dfitmg1; /* 0x0194 */
  40. u32 reserved9[0x02];
  41. u32 dfiupd0; /* 0x01a0 */
  42. u32 dfiupd1; /* 0x01a4 */
  43. u32 dfiupd2; /* 0x01a8 */
  44. u32 reserved10[0x15];
  45. u32 addrmap0; /* 0x0200 */
  46. u32 addrmap1; /* 0x0204 */
  47. u32 addrmap2; /* 0x0208 */
  48. u32 addrmap3; /* 0x020c */
  49. u32 addrmap4; /* 0x0210 */
  50. u32 addrmap5; /* 0x0214 */
  51. u32 addrmap6; /* 0x0218 */
  52. u32 reserved12[0x09];
  53. u32 odtcfg; /* 0x0240 */
  54. u32 odtmap; /* 0x0244 */
  55. };
  56. /* DDRC_MSTR fields */
  57. #define MSTR_DATA_BUS_WIDTH_MASK 0x3 << 12
  58. #define MSTR_DATA_BUS_WIDTH_SHIFT 12
  59. #define MSTR_DATA_ACTIVE_RANKS_MASK 0xf << 24
  60. #define MSTR_DATA_ACTIVE_RANKS_SHIFT 24
  61. /* DDRC_ADDRMAP1 fields */
  62. #define ADDRMAP1_BANK_B0_MASK 0x1f << 0
  63. #define ADDRMAP1_BANK_B0_SHIFT 0
  64. #define ADDRMAP1_BANK_B1_MASK 0x1f << 8
  65. #define ADDRMAP1_BANK_B1_SHIFT 8
  66. #define ADDRMAP1_BANK_B2_MASK 0x1f << 16
  67. #define ADDRMAP1_BANK_B2_SHIFT 16
  68. /* DDRC_ADDRMAP2 fields */
  69. #define ADDRMAP2_COL_B2_MASK 0xF << 0
  70. #define ADDRMAP2_COL_B2_SHIFT 0
  71. #define ADDRMAP2_COL_B3_MASK 0xF << 8
  72. #define ADDRMAP2_COL_B3_SHIFT 8
  73. #define ADDRMAP2_COL_B4_MASK 0xF << 16
  74. #define ADDRMAP2_COL_B4_SHIFT 16
  75. #define ADDRMAP2_COL_B5_MASK 0xF << 24
  76. #define ADDRMAP2_COL_B5_SHIFT 24
  77. /* DDRC_ADDRMAP3 fields */
  78. #define ADDRMAP3_COL_B6_MASK 0xF << 0
  79. #define ADDRMAP3_COL_B6_SHIFT 0
  80. #define ADDRMAP3_COL_B7_MASK 0xF << 8
  81. #define ADDRMAP3_COL_B7_SHIFT 8
  82. #define ADDRMAP3_COL_B8_MASK 0xF << 16
  83. #define ADDRMAP3_COL_B8_SHIFT 16
  84. #define ADDRMAP3_COL_B9_MASK 0xF << 24
  85. #define ADDRMAP3_COL_B9_SHIFT 24
  86. /* DDRC_ADDRMAP4 fields */
  87. #define ADDRMAP4_COL_B10_MASK 0xF << 0
  88. #define ADDRMAP4_COL_B10_SHIFT 0
  89. #define ADDRMAP4_COL_B11_MASK 0xF << 8
  90. #define ADDRMAP4_COL_B11_SHIFT 8
  91. /* DDRC_ADDRMAP5 fields */
  92. #define ADDRMAP5_ROW_B0_MASK 0xF << 0
  93. #define ADDRMAP5_ROW_B0_SHIFT 0
  94. #define ADDRMAP5_ROW_B1_MASK 0xF << 8
  95. #define ADDRMAP5_ROW_B1_SHIFT 8
  96. #define ADDRMAP5_ROW_B2_10_MASK 0xF << 16
  97. #define ADDRMAP5_ROW_B2_10_SHIFT 16
  98. #define ADDRMAP5_ROW_B11_MASK 0xF << 24
  99. #define ADDRMAP5_ROW_B11_SHIFT 24
  100. /* DDRC_ADDRMAP6 fields */
  101. #define ADDRMAP6_ROW_B12_MASK 0xF << 0
  102. #define ADDRMAP6_ROW_B12_SHIFT 0
  103. #define ADDRMAP6_ROW_B13_MASK 0xF << 8
  104. #define ADDRMAP6_ROW_B13_SHIFT 8
  105. #define ADDRMAP6_ROW_B14_MASK 0xF << 16
  106. #define ADDRMAP6_ROW_B14_SHIFT 16
  107. #define ADDRMAP6_ROW_B15_MASK 0xF << 24
  108. #define ADDRMAP6_ROW_B15_SHIFT 24
  109. /* DDRC_MP Registers */
  110. #define DDRC_MP_BASE_ADDR (DDRC_IPS_BASE_ADDR + 0x03fc)
  111. struct ddrc_mp {
  112. u32 reserved1[0x25];
  113. u32 pctrl_0; /* 0x0094 */
  114. };
  115. /* DDR_PHY registers */
  116. struct ddr_phy {
  117. u32 phy_con0; /* 0x0000 */
  118. u32 phy_con1; /* 0x0004 */
  119. u32 reserved1[0x02];
  120. u32 phy_con4; /* 0x0010 */
  121. u32 reserved2;
  122. u32 offset_lp_con0; /* 0x0018 */
  123. u32 reserved3;
  124. u32 offset_rd_con0; /* 0x0020 */
  125. u32 reserved4[0x03];
  126. u32 offset_wr_con0; /* 0x0030 */
  127. u32 reserved5[0x07];
  128. u32 cmd_sdll_con0; /* 0x0050 */
  129. u32 reserved6[0x12];
  130. u32 drvds_con0; /* 0x009c */
  131. u32 reserved7[0x04];
  132. u32 mdll_con0; /* 0x00b0 */
  133. u32 reserved8[0x03];
  134. u32 zq_con0; /* 0x00c0 */
  135. };
  136. #define DDR_PHY_CMD_SDLL_CON0_CTRL_RESYNC_MASK BIT(24)
  137. #define MX7_CAL_VAL_MAX 5
  138. /* Calibration parameters */
  139. struct mx7_calibration {
  140. int num_val; /* Number of calibration values */
  141. u32 values[MX7_CAL_VAL_MAX]; /* calibration values */
  142. };
  143. void mx7_dram_cfg(struct ddrc *ddrc_regs_val, struct ddrc_mp *ddrc_mp_val,
  144. struct ddr_phy *ddr_phy_regs_val,
  145. struct mx7_calibration *calib_param);
  146. #endif /*__ASM_ARCH_MX7_DDR_H__ */