fixed_sdram.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. * (C) Copyright 2007-2009 DENX Software Engineering
  3. *
  4. * See file CREDITS for list of people who contributed to this
  5. * project.
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation; either version 2 of
  10. * the License, or (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  20. * MA 02111-1307 USA
  21. *
  22. */
  23. #include <common.h>
  24. #include <asm/io.h>
  25. #include <asm/mpc512x.h>
  26. /*
  27. * MDDRC Config Runtime Settings in order of the 4 MDDRC cfg registers
  28. */
  29. u32 default_mddrc_config[4] = {
  30. CONFIG_SYS_MDDRC_TIME_CFG0, /* time_config0 */
  31. CONFIG_SYS_MDDRC_TIME_CFG1, /* time_config1 */
  32. CONFIG_SYS_MDDRC_TIME_CFG2, /* time_config2 */
  33. CONFIG_SYS_MDDRC_SYS_CFG, /* sys_config */
  34. };
  35. u32 default_init_seq[] = {
  36. CONFIG_SYS_DDRCMD_NOP,
  37. CONFIG_SYS_DDRCMD_NOP,
  38. CONFIG_SYS_DDRCMD_NOP,
  39. CONFIG_SYS_DDRCMD_NOP,
  40. CONFIG_SYS_DDRCMD_NOP,
  41. CONFIG_SYS_DDRCMD_NOP,
  42. CONFIG_SYS_DDRCMD_NOP,
  43. CONFIG_SYS_DDRCMD_NOP,
  44. CONFIG_SYS_DDRCMD_NOP,
  45. CONFIG_SYS_DDRCMD_NOP,
  46. CONFIG_SYS_DDRCMD_PCHG_ALL,
  47. CONFIG_SYS_DDRCMD_NOP,
  48. CONFIG_SYS_DDRCMD_RFSH,
  49. CONFIG_SYS_DDRCMD_NOP,
  50. CONFIG_SYS_DDRCMD_RFSH,
  51. CONFIG_SYS_DDRCMD_NOP,
  52. CONFIG_SYS_MICRON_INIT_DEV_OP,
  53. CONFIG_SYS_DDRCMD_NOP,
  54. CONFIG_SYS_DDRCMD_EM2,
  55. CONFIG_SYS_DDRCMD_NOP,
  56. CONFIG_SYS_DDRCMD_PCHG_ALL,
  57. CONFIG_SYS_DDRCMD_EM2,
  58. CONFIG_SYS_DDRCMD_EM3,
  59. CONFIG_SYS_DDRCMD_EN_DLL,
  60. CONFIG_SYS_MICRON_INIT_DEV_OP,
  61. CONFIG_SYS_DDRCMD_PCHG_ALL,
  62. CONFIG_SYS_DDRCMD_RFSH,
  63. CONFIG_SYS_MICRON_INIT_DEV_OP,
  64. CONFIG_SYS_DDRCMD_OCD_DEFAULT,
  65. CONFIG_SYS_DDRCMD_PCHG_ALL,
  66. CONFIG_SYS_DDRCMD_NOP
  67. };
  68. /*
  69. * fixed sdram init:
  70. * The board doesn't use memory modules that have serial presence
  71. * detect or similar mechanism for discovery of the DRAM settings
  72. */
  73. long int fixed_sdram(u32 *mddrc_config, u32 *dram_init_seq, int seq_sz)
  74. {
  75. volatile immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
  76. u32 msize = CONFIG_SYS_DDR_SIZE * 1024 * 1024;
  77. u32 msize_log2 = __ilog2(msize);
  78. u32 i;
  79. /* take default settings and init sequence if necessary */
  80. if (mddrc_config == NULL)
  81. mddrc_config = default_mddrc_config;
  82. if (dram_init_seq == NULL) {
  83. dram_init_seq = default_init_seq;
  84. seq_sz = sizeof(default_init_seq)/sizeof(u32);
  85. }
  86. /* Initialize IO Control */
  87. out_be32(&im->io_ctrl.io_control_mem, IOCTRL_MUX_DDR);
  88. /* Initialize DDR Local Window */
  89. out_be32(&im->sysconf.ddrlaw.bar, CONFIG_SYS_DDR_BASE & 0xFFFFF000);
  90. out_be32(&im->sysconf.ddrlaw.ar, msize_log2 - 1);
  91. sync_law(&im->sysconf.ddrlaw.ar);
  92. /* DDR Enable */
  93. out_be32(&im->mddrc.ddr_sys_config, MDDRC_SYS_CFG_EN);
  94. /* Initialize DDR Priority Manager */
  95. out_be32(&im->mddrc.prioman_config1, CONFIG_SYS_MDDRCGRP_PM_CFG1);
  96. out_be32(&im->mddrc.prioman_config2, CONFIG_SYS_MDDRCGRP_PM_CFG2);
  97. out_be32(&im->mddrc.hiprio_config, CONFIG_SYS_MDDRCGRP_HIPRIO_CFG);
  98. out_be32(&im->mddrc.lut_table0_main_upper, CONFIG_SYS_MDDRCGRP_LUT0_MU);
  99. out_be32(&im->mddrc.lut_table0_main_lower, CONFIG_SYS_MDDRCGRP_LUT0_ML);
  100. out_be32(&im->mddrc.lut_table1_main_upper, CONFIG_SYS_MDDRCGRP_LUT1_MU);
  101. out_be32(&im->mddrc.lut_table1_main_lower, CONFIG_SYS_MDDRCGRP_LUT1_ML);
  102. out_be32(&im->mddrc.lut_table2_main_upper, CONFIG_SYS_MDDRCGRP_LUT2_MU);
  103. out_be32(&im->mddrc.lut_table2_main_lower, CONFIG_SYS_MDDRCGRP_LUT2_ML);
  104. out_be32(&im->mddrc.lut_table3_main_upper, CONFIG_SYS_MDDRCGRP_LUT3_MU);
  105. out_be32(&im->mddrc.lut_table3_main_lower, CONFIG_SYS_MDDRCGRP_LUT3_ML);
  106. out_be32(&im->mddrc.lut_table4_main_upper, CONFIG_SYS_MDDRCGRP_LUT4_MU);
  107. out_be32(&im->mddrc.lut_table4_main_lower, CONFIG_SYS_MDDRCGRP_LUT4_ML);
  108. out_be32(&im->mddrc.lut_table0_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT0_AU);
  109. out_be32(&im->mddrc.lut_table0_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT0_AL);
  110. out_be32(&im->mddrc.lut_table1_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT1_AU);
  111. out_be32(&im->mddrc.lut_table1_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT1_AL);
  112. out_be32(&im->mddrc.lut_table2_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT2_AU);
  113. out_be32(&im->mddrc.lut_table2_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT2_AL);
  114. out_be32(&im->mddrc.lut_table3_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT3_AU);
  115. out_be32(&im->mddrc.lut_table3_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT3_AL);
  116. out_be32(&im->mddrc.lut_table4_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT4_AU);
  117. out_be32(&im->mddrc.lut_table4_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT4_AL);
  118. /*
  119. * Initialize MDDRC
  120. * put MDDRC in CMD mode and
  121. * set the max time between refreshes to 0 during init process
  122. */
  123. out_be32(&im->mddrc.ddr_sys_config, mddrc_config[3] | MDDRC_SYS_CFG_CMD_MASK);
  124. out_be32(&im->mddrc.ddr_time_config0, mddrc_config[0] & MDDRC_REFRESH_ZERO_MASK);
  125. out_be32(&im->mddrc.ddr_time_config1, mddrc_config[1]);
  126. out_be32(&im->mddrc.ddr_time_config2, mddrc_config[2]);
  127. /* Initialize DDR with either default or supplied init sequence */
  128. for (i = 0; i < seq_sz; i++)
  129. out_be32(&im->mddrc.ddr_command, dram_init_seq[i]);
  130. /* Start MDDRC */
  131. out_be32(&im->mddrc.ddr_time_config0, mddrc_config[0]);
  132. out_be32(&im->mddrc.ddr_sys_config, mddrc_config[3]);
  133. return msize;
  134. }