mem.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. /*
  2. * (C) Copyright 2008
  3. * Texas Instruments, <www.ti.com>
  4. *
  5. * Author :
  6. * Manikandan Pillai <mani.pillai@ti.com>
  7. *
  8. * Initial Code from:
  9. * Richard Woodruff <r-woodruff2@ti.com>
  10. * Syed Mohammed Khasim <khasim@ti.com>
  11. *
  12. * This program is free software; you can redistribute it and/or
  13. * modify it under the terms of the GNU General Public License as
  14. * published by the Free Software Foundation; either version 2 of
  15. * the License, or (at your option) any later version.
  16. *
  17. * This program is distributed in the hope that it will be useful,
  18. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  20. * GNU General Public License for more details.
  21. *
  22. * You should have received a copy of the GNU General Public License
  23. * along with this program; if not, write to the Free Software
  24. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  25. * MA 02111-1307 USA
  26. */
  27. #include <common.h>
  28. #include <asm/io.h>
  29. #include <asm/arch/mem.h>
  30. #include <asm/arch/sys_proto.h>
  31. #include <command.h>
  32. struct gpmc *gpmc_cfg;
  33. #if defined(CONFIG_CMD_NAND)
  34. static const u32 gpmc_m_nand[GPMC_MAX_REG] = {
  35. M_NAND_GPMC_CONFIG1,
  36. M_NAND_GPMC_CONFIG2,
  37. M_NAND_GPMC_CONFIG3,
  38. M_NAND_GPMC_CONFIG4,
  39. M_NAND_GPMC_CONFIG5,
  40. M_NAND_GPMC_CONFIG6, 0
  41. };
  42. #endif /* CONFIG_CMD_NAND */
  43. #if defined(CONFIG_CMD_ONENAND)
  44. static const u32 gpmc_onenand[GPMC_MAX_REG] = {
  45. ONENAND_GPMC_CONFIG1,
  46. ONENAND_GPMC_CONFIG2,
  47. ONENAND_GPMC_CONFIG3,
  48. ONENAND_GPMC_CONFIG4,
  49. ONENAND_GPMC_CONFIG5,
  50. ONENAND_GPMC_CONFIG6, 0
  51. };
  52. #endif /* CONFIG_CMD_ONENAND */
  53. /********************************************************
  54. * mem_ok() - test used to see if timings are correct
  55. * for a part. Helps in guessing which part
  56. * we are currently using.
  57. *******************************************************/
  58. u32 mem_ok(u32 cs)
  59. {
  60. u32 val1, val2, addr;
  61. u32 pattern = 0x12345678;
  62. addr = OMAP34XX_SDRC_CS0 + get_sdr_cs_offset(cs);
  63. writel(0x0, addr + 0x400); /* clear pos A */
  64. writel(pattern, addr); /* pattern to pos B */
  65. writel(0x0, addr + 4); /* remove pattern off the bus */
  66. val1 = readl(addr + 0x400); /* get pos A value */
  67. val2 = readl(addr); /* get val2 */
  68. writel(0x0, addr + 0x400); /* clear pos A */
  69. if ((val1 != 0) || (val2 != pattern)) /* see if pos A val changed */
  70. return 0;
  71. else
  72. return 1;
  73. }
  74. void enable_gpmc_cs_config(const u32 *gpmc_config, struct gpmc_cs *cs, u32 base,
  75. u32 size)
  76. {
  77. writel(0, &cs->config7);
  78. sdelay(1000);
  79. /* Delay for settling */
  80. writel(gpmc_config[0], &cs->config1);
  81. writel(gpmc_config[1], &cs->config2);
  82. writel(gpmc_config[2], &cs->config3);
  83. writel(gpmc_config[3], &cs->config4);
  84. writel(gpmc_config[4], &cs->config5);
  85. writel(gpmc_config[5], &cs->config6);
  86. /*
  87. * Enable the config. size is the CS size and goes in
  88. * bits 11:8. We set bit 6 to enable this CS and the base
  89. * address goes into bits 5:0.
  90. */
  91. writel((size << 8) | (GPMC_CS_ENABLE << 6) |
  92. ((base >> 24) & GPMC_BASEADDR_MASK),
  93. &cs->config7);
  94. sdelay(2000);
  95. }
  96. /*****************************************************
  97. * gpmc_init(): init gpmc bus
  98. * Init GPMC for x16, MuxMode (SDRAM in x32).
  99. * This code can only be executed from SRAM or SDRAM.
  100. *****************************************************/
  101. void gpmc_init(void)
  102. {
  103. /* putting a blanket check on GPMC based on ZeBu for now */
  104. gpmc_cfg = (struct gpmc *)GPMC_BASE;
  105. #if defined(CONFIG_CMD_NAND) || defined(CONFIG_CMD_ONENAND)
  106. const u32 *gpmc_config = NULL;
  107. u32 base = 0;
  108. u32 size = 0;
  109. #endif
  110. u32 config = 0;
  111. /* global settings */
  112. writel(0, &gpmc_cfg->irqenable); /* isr's sources masked */
  113. writel(0, &gpmc_cfg->timeout_control);/* timeout disable */
  114. config = readl(&gpmc_cfg->config);
  115. config &= (~0xf00);
  116. writel(config, &gpmc_cfg->config);
  117. /*
  118. * Disable the GPMC0 config set by ROM code
  119. * It conflicts with our MPDB (both at 0x08000000)
  120. */
  121. writel(0, &gpmc_cfg->cs[0].config7);
  122. sdelay(1000);
  123. #if defined(CONFIG_CMD_NAND) /* CS 0 */
  124. gpmc_config = gpmc_m_nand;
  125. base = PISMO1_NAND_BASE;
  126. size = PISMO1_NAND_SIZE;
  127. enable_gpmc_cs_config(gpmc_config, &gpmc_cfg->cs[0], base, size);
  128. #endif
  129. #if defined(CONFIG_CMD_ONENAND)
  130. gpmc_config = gpmc_onenand;
  131. base = PISMO1_ONEN_BASE;
  132. size = PISMO1_ONEN_SIZE;
  133. enable_gpmc_cs_config(gpmc_config, &gpmc_cfg->cs[0], base, size);
  134. #endif
  135. }