galaxy5200.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. /*
  2. * (C) Copyright 2003
  3. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  4. *
  5. * (C) Copyright 2004
  6. * Mark Jonas, Freescale Semiconductor, mark.jonas@motorola.com.
  7. *
  8. * (C) Copyright 2006
  9. * Eric Schumann, Phytec Messtechnik GmbH
  10. *
  11. * (C) Copyright 2009
  12. * Eric Millbrandt, DEKA Research and Development Corporation
  13. *
  14. * SPDX-License-Identifier: GPL-2.0+
  15. */
  16. #include <common.h>
  17. #include <mpc5xxx.h>
  18. #include <pci.h>
  19. #include <asm/io.h>
  20. #ifndef CONFIG_SYS_RAMBOOT
  21. static void sdram_start(int hi_addr)
  22. {
  23. volatile struct mpc5xxx_cdm *cdm =
  24. (struct mpc5xxx_cdm *)MPC5XXX_CDM;
  25. volatile struct mpc5xxx_sdram *sdram =
  26. (struct mpc5xxx_sdram *)MPC5XXX_SDRAM;
  27. long hi_addr_bit = hi_addr ? 0x01000000 : 0;
  28. /* unlock mode register */
  29. out_be32 (&sdram->ctrl,
  30. (SDRAM_CONTROL | 0x80000000 | hi_addr_bit));
  31. /* precharge all banks */
  32. out_be32 (&sdram->ctrl,
  33. (SDRAM_CONTROL | 0x80000002 | hi_addr_bit));
  34. #ifdef SDRAM_DDR
  35. /* set mode register: extended mode */
  36. out_be32 (&sdram->mode, (SDRAM_EMODE));
  37. /* set mode register: reset DLL */
  38. out_be32 (&sdram->mode, (SDRAM_MODE | 0x04000000));
  39. #endif
  40. /* precharge all banks */
  41. out_be32 (&sdram->ctrl,
  42. (SDRAM_CONTROL | 0x80000002 | hi_addr_bit));
  43. /* auto refresh */
  44. out_be32 (&sdram->ctrl,
  45. (SDRAM_CONTROL | 0x80000004 | hi_addr_bit));
  46. /* set mode register */
  47. out_be32 (&sdram->mode, (SDRAM_MODE));
  48. /* normal operation */
  49. out_be32 (&sdram->ctrl,
  50. (SDRAM_CONTROL | hi_addr_bit));
  51. /* set CDM clock enable register, set MPC5200B SDRAM bus */
  52. /* to reduced driver strength */
  53. out_be32 (&cdm->clock_enable, (0x00CFFFFF));
  54. }
  55. #endif
  56. /*
  57. * ATTENTION: Although partially referenced initdram does NOT make
  58. * real use of CONFIG_SYS_SDRAM_BASE. The code does not
  59. * work if CONFIG_SYS_SDRAM_BASE
  60. * is something else than 0x00000000.
  61. */
  62. phys_size_t initdram(int board_type)
  63. {
  64. volatile struct mpc5xxx_mmap_ctl *mm =
  65. (struct mpc5xxx_mmap_ctl *)CONFIG_SYS_MBAR;
  66. volatile struct mpc5xxx_sdram *sdram =
  67. (struct mpc5xxx_sdram *)MPC5XXX_SDRAM;
  68. ulong dramsize = 0;
  69. ulong dramsize2 = 0;
  70. #ifndef CONFIG_SYS_RAMBOOT
  71. ulong test1, test2;
  72. /* setup SDRAM chip selects */
  73. /* 256MB at 0x0 */
  74. out_be32 (&mm->sdram0, 0x0000001b);
  75. /* disabled */
  76. out_be32 (&mm->sdram1, 0x10000000);
  77. /* setup config registers */
  78. out_be32 (&sdram->config1, SDRAM_CONFIG1);
  79. out_be32 (&sdram->config2, SDRAM_CONFIG2);
  80. /* find RAM size using SDRAM CS0 only */
  81. sdram_start(0);
  82. test1 = get_ram_size((long *) CONFIG_SYS_SDRAM_BASE, 0x10000000);
  83. sdram_start(1);
  84. test2 = get_ram_size((long *) CONFIG_SYS_SDRAM_BASE, 0x10000000);
  85. if (test1 > test2) {
  86. sdram_start(0);
  87. dramsize = test1;
  88. } else
  89. dramsize = test2;
  90. /* memory smaller than 1MB is impossible */
  91. if (dramsize < (1 << 20))
  92. dramsize = 0;
  93. /* set SDRAM CS0 size according to the amount of RAM found */
  94. if (dramsize > 0) {
  95. out_be32 (&mm->sdram0,
  96. (0x13 + __builtin_ffs(dramsize >> 20) - 1));
  97. } else {
  98. /* disabled */
  99. out_be32 (&mm->sdram0, 0);
  100. }
  101. #else /* CONFIG_SYS_RAMBOOT */
  102. /* retrieve size of memory connected to SDRAM CS0 */
  103. dramsize = in_be32(&mm->sdram0) & 0xFF;
  104. if (dramsize >= 0x13)
  105. dramsize = (1 << (dramsize - 0x13)) << 20;
  106. else
  107. dramsize = 0;
  108. /* retrieve size of memory connected to SDRAM CS1 */
  109. dramsize2 = in_be32(&mm->sdram1) & 0xFF;
  110. if (dramsize2 >= 0x13)
  111. dramsize2 = (1 << (dramsize2 - 0x13)) << 20;
  112. else
  113. dramsize2 = 0;
  114. #endif /* CONFIG_SYS_RAMBOOT */
  115. return dramsize + dramsize2;
  116. }
  117. int checkboard(void)
  118. {
  119. puts("Board: galaxy5200\n");
  120. return 0;
  121. }
  122. #if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP)
  123. int ft_board_setup(void *blob, bd_t *bd)
  124. {
  125. ft_cpu_setup(blob, bd);
  126. return 0;
  127. }
  128. #endif /* defined(CONFIG_OF_LIBFDT) && defined(CONFIG_OF_BOARD_SETUP) */
  129. #if defined(CONFIG_CMD_IDE) && defined(CONFIG_IDE_RESET)
  130. void init_ide_reset (void)
  131. {
  132. volatile struct mpc5xxx_gpt *gpt = (struct mpc5xxx_gpt *)MPC5XXX_GPT;
  133. debug ("init_ide_reset\n");
  134. /* Configure TIMER_5 as GPIO output for ATA reset */
  135. /* Deassert reset */
  136. gpt[5].emsr = MPC5XXX_GPT_GPIO_OUT1 | MPC5XXX_GPT_TMS_GPIO;
  137. }
  138. void ide_set_reset (int idereset)
  139. {
  140. volatile struct mpc5xxx_gpt *gpt = (struct mpc5xxx_gpt *)MPC5XXX_GPT;
  141. debug ("ide_reset(%d)\n", idereset);
  142. /* Configure TIMER_5 as GPIO output for ATA reset */
  143. if (idereset) {
  144. gpt[5].emsr = MPC5XXX_GPT_GPIO_OUT0 | MPC5XXX_GPT_TMS_GPIO;
  145. /* Make a delay. MPC5200 spec says 25 usec min */
  146. udelay(50);
  147. } else {
  148. gpt[5].emsr = MPC5XXX_GPT_GPIO_OUT1 | MPC5XXX_GPT_TMS_GPIO;
  149. udelay(50);
  150. }
  151. }
  152. #endif /* defined(CONFIG_CMD_IDE) && defined(CONFIG_IDE_RESET) */