mecp5200.c 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  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. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. /*
  11. * pf5200.c - main board support/init for the esd pf5200.
  12. */
  13. #include <common.h>
  14. #include <mpc5xxx.h>
  15. #include <pci.h>
  16. #include <command.h>
  17. #include <netdev.h>
  18. #include "mt46v16m16-75.h"
  19. void init_power_switch(void);
  20. static void sdram_start(int hi_addr)
  21. {
  22. long hi_addr_bit = hi_addr ? 0x01000000 : 0;
  23. /* unlock mode register */
  24. *(vu_long *) MPC5XXX_SDRAM_CTRL =
  25. SDRAM_CONTROL | 0x80000000 | hi_addr_bit;
  26. __asm__ volatile ("sync");
  27. /* precharge all banks */
  28. *(vu_long *) MPC5XXX_SDRAM_CTRL =
  29. SDRAM_CONTROL | 0x80000002 | hi_addr_bit;
  30. __asm__ volatile ("sync");
  31. /* set mode register: extended mode */
  32. *(vu_long *) MPC5XXX_SDRAM_MODE = SDRAM_EMODE;
  33. __asm__ volatile ("sync");
  34. /* set mode register: reset DLL */
  35. *(vu_long *) MPC5XXX_SDRAM_MODE = SDRAM_MODE | 0x04000000;
  36. __asm__ volatile ("sync");
  37. /* precharge all banks */
  38. *(vu_long *) MPC5XXX_SDRAM_CTRL =
  39. SDRAM_CONTROL | 0x80000002 | hi_addr_bit;
  40. __asm__ volatile ("sync");
  41. /* auto refresh */
  42. *(vu_long *) MPC5XXX_SDRAM_CTRL =
  43. SDRAM_CONTROL | 0x80000004 | hi_addr_bit;
  44. __asm__ volatile ("sync");
  45. /* set mode register */
  46. *(vu_long *) MPC5XXX_SDRAM_MODE = SDRAM_MODE;
  47. __asm__ volatile ("sync");
  48. /* normal operation */
  49. *(vu_long *) MPC5XXX_SDRAM_CTRL = SDRAM_CONTROL | hi_addr_bit;
  50. __asm__ volatile ("sync");
  51. }
  52. /*
  53. * ATTENTION: Although partially referenced initdram does NOT make real use
  54. * use of CONFIG_SYS_SDRAM_BASE. The code does not work if CONFIG_SYS_SDRAM_BASE
  55. * is something else than 0x00000000.
  56. */
  57. phys_size_t initdram(int board_type)
  58. {
  59. ulong dramsize = 0;
  60. ulong test1, test2;
  61. /* setup SDRAM chip selects */
  62. *(vu_long *) MPC5XXX_SDRAM_CS0CFG = 0x0000001e; /* 2G at 0x0 */
  63. *(vu_long *) MPC5XXX_SDRAM_CS1CFG = 0x80000000; /* disabled */
  64. __asm__ volatile ("sync");
  65. /* setup config registers */
  66. *(vu_long *) MPC5XXX_SDRAM_CONFIG1 = SDRAM_CONFIG1;
  67. *(vu_long *) MPC5XXX_SDRAM_CONFIG2 = SDRAM_CONFIG2;
  68. __asm__ volatile ("sync");
  69. /* set tap delay */
  70. *(vu_long *) MPC5XXX_CDM_PORCFG = SDRAM_TAPDELAY;
  71. __asm__ volatile ("sync");
  72. /* find RAM size using SDRAM CS0 only */
  73. sdram_start(0);
  74. test1 = get_ram_size(CONFIG_SYS_SDRAM_BASE, 0x80000000);
  75. sdram_start(1);
  76. test2 = get_ram_size(CONFIG_SYS_SDRAM_BASE, 0x80000000);
  77. if (test1 > test2) {
  78. sdram_start(0);
  79. dramsize = test1;
  80. } else {
  81. dramsize = test2;
  82. }
  83. /* memory smaller than 1MB is impossible */
  84. if (dramsize < (1 << 20))
  85. dramsize = 0;
  86. /* set SDRAM CS0 size according to the amount of RAM found */
  87. if (dramsize > 0) {
  88. *(vu_long *) MPC5XXX_SDRAM_CS0CFG =
  89. 0x13 + __builtin_ffs(dramsize >> 20) - 1;
  90. /* let SDRAM CS1 start right after CS0 */
  91. *(vu_long *) MPC5XXX_SDRAM_CS1CFG = dramsize + 0x0000001e; /* 2G */
  92. } else {
  93. #if 0
  94. *(vu_long *) MPC5XXX_SDRAM_CS0CFG = 0; /* disabled */
  95. /* let SDRAM CS1 start right after CS0 */
  96. *(vu_long *) MPC5XXX_SDRAM_CS1CFG = dramsize + 0x0000001e; /* 2G */
  97. #else
  98. *(vu_long *) MPC5XXX_SDRAM_CS0CFG =
  99. 0x13 + __builtin_ffs(0x08000000 >> 20) - 1;
  100. /* let SDRAM CS1 start right after CS0 */
  101. *(vu_long *) MPC5XXX_SDRAM_CS1CFG = 0x08000000 + 0x0000001e; /* 2G */
  102. #endif
  103. }
  104. #if 0
  105. /* find RAM size using SDRAM CS1 only */
  106. sdram_start(0);
  107. get_ram_size((ulong *) (CONFIG_SYS_SDRAM_BASE + dramsize), 0x80000000);
  108. sdram_start(1);
  109. get_ram_size((ulong *) (CONFIG_SYS_SDRAM_BASE + dramsize), 0x80000000);
  110. sdram_start(0);
  111. #endif
  112. /* set SDRAM CS1 size according to the amount of RAM found */
  113. *(vu_long *) MPC5XXX_SDRAM_CS1CFG = dramsize; /* disabled */
  114. init_power_switch();
  115. return (dramsize);
  116. }
  117. int checkboard(void)
  118. {
  119. puts("Board: esd CPX CPU5200 (mecp5200)\n");
  120. return 0;
  121. }
  122. void flash_preinit(void)
  123. {
  124. /*
  125. * Now, when we are in RAM, enable flash write
  126. * access for detection process.
  127. * Note that CS_BOOT cannot be cleared when
  128. * executing in flash.
  129. */
  130. *(vu_long *) MPC5XXX_BOOTCS_CFG &= ~0x1; /* clear RO */
  131. }
  132. void flash_afterinit(ulong size)
  133. {
  134. if (size == CONFIG_SYS_FLASH_SIZE) {
  135. /* adjust mapping */
  136. *(vu_long *) MPC5XXX_BOOTCS_START =
  137. *(vu_long *) MPC5XXX_CS0_START =
  138. START_REG(CONFIG_SYS_BOOTCS_START | size);
  139. *(vu_long *) MPC5XXX_BOOTCS_STOP =
  140. *(vu_long *) MPC5XXX_CS0_STOP =
  141. STOP_REG(CONFIG_SYS_BOOTCS_START | size, size);
  142. }
  143. }
  144. #ifdef CONFIG_PCI
  145. static struct pci_controller hose;
  146. extern void pci_mpc5xxx_init(struct pci_controller *);
  147. void pci_init_board(void)
  148. {
  149. pci_mpc5xxx_init(&hose);
  150. }
  151. #endif
  152. #if defined(CONFIG_CMD_IDE) && defined(CONFIG_IDE_RESET)
  153. #define GPIO_PSC1_4 0x01000000UL
  154. void init_ide_reset(void)
  155. {
  156. debug("init_ide_reset\n");
  157. /* Configure PSC1_4 as GPIO output for ATA reset */
  158. *(vu_long *) MPC5XXX_WU_GPIO_ENABLE |= GPIO_PSC1_4;
  159. *(vu_long *) MPC5XXX_WU_GPIO_DIR |= GPIO_PSC1_4;
  160. }
  161. void ide_set_reset(int idereset)
  162. {
  163. debug("ide_reset(%d)\n", idereset);
  164. if (idereset)
  165. *(vu_long *) MPC5XXX_WU_GPIO_DATA_O &= ~GPIO_PSC1_4;
  166. else
  167. *(vu_long *) MPC5XXX_WU_GPIO_DATA_O |= GPIO_PSC1_4;
  168. }
  169. #endif
  170. #define MPC5XXX_SIMPLEIO_GPIO_ENABLE (MPC5XXX_GPIO + 0x0004)
  171. #define MPC5XXX_SIMPLEIO_GPIO_DIR (MPC5XXX_GPIO + 0x000C)
  172. #define MPC5XXX_SIMPLEIO_GPIO_DATA_OUTPUT (MPC5XXX_GPIO + 0x0010)
  173. #define MPC5XXX_SIMPLEIO_GPIO_DATA_INPUT (MPC5XXX_GPIO + 0x0014)
  174. #define MPC5XXX_INTERRUPT_GPIO_ENABLE (MPC5XXX_GPIO + 0x0020)
  175. #define MPC5XXX_INTERRUPT_GPIO_DIR (MPC5XXX_GPIO + 0x0028)
  176. #define MPC5XXX_INTERRUPT_GPIO_DATA_OUTPUT (MPC5XXX_GPIO + 0x002C)
  177. #define MPC5XXX_INTERRUPT_GPIO_STATUS (MPC5XXX_GPIO + 0x003C)
  178. #define GPIO_WU6 0x40000000UL
  179. #define GPIO_USB0 0x00010000UL
  180. #define GPIO_USB9 0x08000000UL
  181. #define GPIO_USB9S 0x00080000UL
  182. void init_power_switch(void)
  183. {
  184. debug("init_power_switch\n");
  185. /* Configure GPIO_WU6 as GPIO output for ATA reset */
  186. *(vu_long *) MPC5XXX_WU_GPIO_DATA_O |= GPIO_WU6;
  187. *(vu_long *) MPC5XXX_WU_GPIO_ENABLE |= GPIO_WU6;
  188. *(vu_long *) MPC5XXX_WU_GPIO_DIR |= GPIO_WU6;
  189. __asm__ volatile ("sync");
  190. *(vu_long *) MPC5XXX_SIMPLEIO_GPIO_DATA_OUTPUT &= ~GPIO_USB0;
  191. *(vu_long *) MPC5XXX_SIMPLEIO_GPIO_ENABLE |= GPIO_USB0;
  192. *(vu_long *) MPC5XXX_SIMPLEIO_GPIO_DIR |= GPIO_USB0;
  193. __asm__ volatile ("sync");
  194. *(vu_long *) MPC5XXX_INTERRUPT_GPIO_DATA_OUTPUT &= ~GPIO_USB9;
  195. *(vu_long *) MPC5XXX_INTERRUPT_GPIO_ENABLE &= ~GPIO_USB9;
  196. __asm__ volatile ("sync");
  197. if ((*(vu_long *) MPC5XXX_INTERRUPT_GPIO_STATUS & GPIO_USB9S) == 0) {
  198. *(vu_long *) MPC5XXX_SIMPLEIO_GPIO_DATA_OUTPUT |= GPIO_USB0;
  199. __asm__ volatile ("sync");
  200. }
  201. }
  202. int board_eth_init(bd_t *bis)
  203. {
  204. return pci_eth_init(bis);
  205. }