ddr3_cfg.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. /*
  2. * Keystone2: DDR3 configuration
  3. *
  4. * (C) Copyright 2012-2014
  5. * Texas Instruments Incorporated, <www.ti.com>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #include <common.h>
  10. #include <i2c.h>
  11. #include <asm/arch/ddr3.h>
  12. #include <asm/arch/hardware.h>
  13. DECLARE_GLOBAL_DATA_PTR;
  14. /* DDR3 PHY configuration data with 1600M rate, 8GB size */
  15. struct ddr3_phy_config ddr3phy_1600_8g = {
  16. .pllcr = 0x0001C000ul,
  17. .pgcr1_mask = (IODDRM_MASK | ZCKSEL_MASK),
  18. .pgcr1_val = ((1 << 2) | (1 << 7) | (1 << 23)),
  19. .ptr0 = 0x42C21590ul,
  20. .ptr1 = 0xD05612C0ul,
  21. .ptr2 = 0, /* not set in gel */
  22. .ptr3 = 0x0D861A80ul,
  23. .ptr4 = 0x0C827100ul,
  24. .dcr_mask = (PDQ_MASK | MPRDQ_MASK | BYTEMASK_MASK),
  25. .dcr_val = ((1 << 10)),
  26. .dtpr0 = 0xA19DBB66ul,
  27. .dtpr1 = 0x32868300ul,
  28. .dtpr2 = 0x50035200ul,
  29. .mr0 = 0x00001C70ul,
  30. .mr1 = 0x00000006ul,
  31. .mr2 = 0x00000018ul,
  32. .dtcr = 0x730035C7ul,
  33. .pgcr2 = 0x00F07A12ul,
  34. .zq0cr1 = 0x0000005Dul,
  35. .zq1cr1 = 0x0000005Bul,
  36. .zq2cr1 = 0x0000005Bul,
  37. .pir_v1 = 0x00000033ul,
  38. .pir_v2 = 0x0000FF81ul,
  39. };
  40. /* DDR3 EMIF configuration data with 1600M rate, 8GB size */
  41. struct ddr3_emif_config ddr3_1600_8g = {
  42. .sdcfg = 0x6200CE6Aul,
  43. .sdtim1 = 0x16709C55ul,
  44. .sdtim2 = 0x00001D4Aul,
  45. .sdtim3 = 0x435DFF54ul,
  46. .sdtim4 = 0x553F0CFFul,
  47. .zqcfg = 0xF0073200ul,
  48. .sdrfc = 0x00001869ul,
  49. };
  50. #ifdef CONFIG_K2HK_EVM
  51. /* DDR3 PHY configuration data with 1333M rate, and 2GB size */
  52. struct ddr3_phy_config ddr3phy_1333_2g = {
  53. .pllcr = 0x0005C000ul,
  54. .pgcr1_mask = (IODDRM_MASK | ZCKSEL_MASK),
  55. .pgcr1_val = ((1 << 2) | (1 << 7) | (1 << 23)),
  56. .ptr0 = 0x42C21590ul,
  57. .ptr1 = 0xD05612C0ul,
  58. .ptr2 = 0, /* not set in gel */
  59. .ptr3 = 0x0B4515C2ul,
  60. .ptr4 = 0x0A6E08B4ul,
  61. .dcr_mask = (PDQ_MASK | MPRDQ_MASK | BYTEMASK_MASK),
  62. .dcr_val = ((1 << 10)),
  63. .dtpr0 = 0x8558AA55ul,
  64. .dtpr1 = 0x32857280ul,
  65. .dtpr2 = 0x5002C200ul,
  66. .mr0 = 0x00001A60ul,
  67. .mr1 = 0x00000006ul,
  68. .mr2 = 0x00000010ul,
  69. .dtcr = 0x710035C7ul,
  70. .pgcr2 = 0x00F065B8ul,
  71. .zq0cr1 = 0x0000005Dul,
  72. .zq1cr1 = 0x0000005Bul,
  73. .zq2cr1 = 0x0000005Bul,
  74. .pir_v1 = 0x00000033ul,
  75. .pir_v2 = 0x0000FF81ul,
  76. };
  77. /* DDR3 EMIF configuration data with 1333M rate, and 2GB size */
  78. struct ddr3_emif_config ddr3_1333_2g = {
  79. .sdcfg = 0x62008C62ul,
  80. .sdtim1 = 0x125C8044ul,
  81. .sdtim2 = 0x00001D29ul,
  82. .sdtim3 = 0x32CDFF43ul,
  83. .sdtim4 = 0x543F0ADFul,
  84. .zqcfg = 0x70073200ul,
  85. .sdrfc = 0x00001457ul,
  86. };
  87. #endif
  88. #ifdef CONFIG_K2E_EVM
  89. /* DDR3 PHY configuration data with 1600M rate, and 4GB size */
  90. struct ddr3_phy_config ddr3phy_1600_4g = {
  91. .pllcr = 0x0001C000ul,
  92. .pgcr1_mask = (IODDRM_MASK | ZCKSEL_MASK),
  93. .pgcr1_val = ((1 << 2) | (1 << 7) | (1 << 23)),
  94. .ptr0 = 0x42C21590ul,
  95. .ptr1 = 0xD05612C0ul,
  96. .ptr2 = 0, /* not set in gel */
  97. .ptr3 = 0x08861A80ul,
  98. .ptr4 = 0x0C827100ul,
  99. .dcr_mask = (PDQ_MASK | MPRDQ_MASK | BYTEMASK_MASK),
  100. .dcr_val = ((1 << 10)),
  101. .dtpr0 = 0x9D9CBB66ul,
  102. .dtpr1 = 0x12840300ul,
  103. .dtpr2 = 0x5002D200ul,
  104. .mr0 = 0x00001C70ul,
  105. .mr1 = 0x00000006ul,
  106. .mr2 = 0x00000018ul,
  107. .dtcr = 0x710035C7ul,
  108. .pgcr2 = 0x00F07A12ul,
  109. .zq0cr1 = 0x0001005Dul,
  110. .zq1cr1 = 0x0001005Bul,
  111. .zq2cr1 = 0x0001005Bul,
  112. .pir_v1 = 0x00000033ul,
  113. .pir_v2 = 0x0000FF81ul,
  114. };
  115. /* DDR3 EMIF configuration data with 1600M rate, and 4GB size */
  116. struct ddr3_emif_config ddr3_1600_4g = {
  117. .sdcfg = 0x6200CE62ul,
  118. .sdtim1 = 0x166C9855ul,
  119. .sdtim2 = 0x00001D4Aul,
  120. .sdtim3 = 0x421DFF53ul,
  121. .sdtim4 = 0x543F07FFul,
  122. .zqcfg = 0x70073200ul,
  123. .sdrfc = 0x00001869ul,
  124. };
  125. #endif
  126. struct ddr3_phy_config ddr3phy_1600_2g = {
  127. .pllcr = 0x0001C000ul,
  128. .pgcr1_mask = (IODDRM_MASK | ZCKSEL_MASK),
  129. .pgcr1_val = ((1 << 2) | (1 << 7) | (1 << 23)),
  130. .ptr0 = 0x42C21590ul,
  131. .ptr1 = 0xD05612C0ul,
  132. .ptr2 = 0, /* not set in gel */
  133. .ptr3 = 0x0D861A80ul,
  134. .ptr4 = 0x0C827100ul,
  135. .dcr_mask = (PDQ_MASK | MPRDQ_MASK | BYTEMASK_MASK),
  136. .dcr_val = ((1 << 10)),
  137. .dtpr0 = 0x9D5CBB66ul,
  138. .dtpr1 = 0x12868300ul,
  139. .dtpr2 = 0x5002D200ul,
  140. .mr0 = 0x00001C70ul,
  141. .mr1 = 0x00000006ul,
  142. .mr2 = 0x00000018ul,
  143. .dtcr = 0x710035C7ul,
  144. .pgcr2 = 0x00F07A12ul,
  145. .zq0cr1 = 0x0001005Dul,
  146. .zq1cr1 = 0x0001005Bul,
  147. .zq2cr1 = 0x0001005Bul,
  148. .pir_v1 = 0x00000033ul,
  149. .pir_v2 = 0x0000FF81ul,
  150. };
  151. struct ddr3_emif_config ddr3_1600_2g = {
  152. .sdcfg = 0x6200CE62ul,
  153. .sdtim1 = 0x166C9855ul,
  154. .sdtim2 = 0x00001D4Aul,
  155. .sdtim3 = 0x435DFF53ul,
  156. .sdtim4 = 0x543F0CFFul,
  157. .zqcfg = 0x70073200ul,
  158. .sdrfc = 0x00001869ul,
  159. };
  160. int ddr3_get_dimm_params(char *dimm_name)
  161. {
  162. int ret;
  163. int old_bus;
  164. u8 spd_params[256];
  165. i2c_init(CONFIG_SYS_DAVINCI_I2C_SPEED, CONFIG_SYS_DAVINCI_I2C_SLAVE);
  166. old_bus = i2c_get_bus_num();
  167. i2c_set_bus_num(1);
  168. ret = i2c_read(0x53, 0, 1, spd_params, 256);
  169. i2c_set_bus_num(old_bus);
  170. dimm_name[0] = '\0';
  171. if (ret) {
  172. puts("Cannot read DIMM params\n");
  173. return 1;
  174. }
  175. /*
  176. * We need to convert spd data to dimm parameters
  177. * and to DDR3 EMIF and PHY regirsters values.
  178. * For now we just return DIMM type string value.
  179. * Caller may use this value to choose appropriate
  180. * a pre-set DDR3 configuration
  181. */
  182. strncpy(dimm_name, (char *)&spd_params[0x80], 18);
  183. dimm_name[18] = '\0';
  184. return 0;
  185. }