bamboo.h 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. /*
  2. * (C) Copyright 2005-2007
  3. * Stefan Roese, DENX Software Engineering, sr@denx.de.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. /************************************************************************
  8. * bamboo.h - configuration for BAMBOO board
  9. ***********************************************************************/
  10. #ifndef __CONFIG_H
  11. #define __CONFIG_H
  12. /*-----------------------------------------------------------------------
  13. * High Level Configuration Options
  14. *----------------------------------------------------------------------*/
  15. #define CONFIG_BAMBOO 1 /* Board is BAMBOO */
  16. #define CONFIG_440EP 1 /* Specific PPC440EP support */
  17. #define CONFIG_440 1 /* ... PPC440 family */
  18. #define CONFIG_SYS_CLK_FREQ 33333333 /* external freq to pll */
  19. #ifndef CONFIG_SYS_TEXT_BASE
  20. #define CONFIG_SYS_TEXT_BASE 0xFFFA0000
  21. #endif
  22. /*
  23. * Include common defines/options for all AMCC eval boards
  24. */
  25. #define CONFIG_HOSTNAME bamboo
  26. #include "amcc-common.h"
  27. /* Reclaim some space. */
  28. #undef CONFIG_SYS_LONGHELP
  29. #define CONFIG_BOARD_EARLY_INIT_F 1 /* Call board_early_init_f */
  30. /*
  31. * Please note that, if NAND support is enabled, the 2nd ethernet port
  32. * can't be used because of pin multiplexing. So, if you want to use the
  33. * 2nd ethernet port you have to "undef" the following define.
  34. */
  35. #define CONFIG_BAMBOO_NAND 1 /* enable nand flash support */
  36. /*-----------------------------------------------------------------------
  37. * Base addresses -- Note these are effective addresses where the
  38. * actual resources get mapped (not physical addresses)
  39. *----------------------------------------------------------------------*/
  40. #define CONFIG_SYS_FLASH_BASE 0xfff00000 /* start of FLASH */
  41. #define CONFIG_SYS_PCI_MEMBASE 0xa0000000 /* mapped pci memory*/
  42. #define CONFIG_SYS_PCI_MEMBASE1 CONFIG_SYS_PCI_MEMBASE + 0x10000000
  43. #define CONFIG_SYS_PCI_MEMBASE2 CONFIG_SYS_PCI_MEMBASE1 + 0x10000000
  44. #define CONFIG_SYS_PCI_MEMBASE3 CONFIG_SYS_PCI_MEMBASE2 + 0x10000000
  45. /*Don't change either of these*/
  46. #define CONFIG_SYS_PCI_BASE 0xe0000000 /* internal PCI regs*/
  47. /*Don't change either of these*/
  48. #define CONFIG_SYS_USB_DEVICE 0x50000000
  49. #define CONFIG_SYS_NVRAM_BASE_ADDR 0x80000000
  50. #define CONFIG_SYS_BOOT_BASE_ADDR 0xf0000000
  51. #define CONFIG_SYS_NAND_ADDR 0x90000000
  52. #define CONFIG_SYS_NAND2_ADDR 0x94000000
  53. /*-----------------------------------------------------------------------
  54. * Initial RAM & stack pointer (placed in SDRAM)
  55. *----------------------------------------------------------------------*/
  56. #define CONFIG_SYS_INIT_RAM_DCACHE 1 /* d-cache as init ram */
  57. #define CONFIG_SYS_INIT_RAM_ADDR 0x70000000 /* DCache */
  58. #define CONFIG_SYS_INIT_RAM_SIZE (4 << 10)
  59. #define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
  60. #define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
  61. /*-----------------------------------------------------------------------
  62. * Serial Port
  63. *----------------------------------------------------------------------*/
  64. #define CONFIG_CONS_INDEX 1 /* Use UART0 */
  65. #define CONFIG_SYS_EXT_SERIAL_CLOCK 11059200 /* use external 11.059MHz clk */
  66. /*-----------------------------------------------------------------------
  67. * NVRAM/RTC
  68. *
  69. * NOTE: The RTC registers are located at 0x7FFF0 - 0x7FFFF
  70. * The DS1558 code assumes this condition
  71. *
  72. *----------------------------------------------------------------------*/
  73. #define CONFIG_SYS_NVRAM_SIZE (0x2000 - 0x10) /* NVRAM size(8k)- RTC regs */
  74. #define CONFIG_RTC_DS1556 1 /* DS1556 RTC */
  75. /*-----------------------------------------------------------------------
  76. * Environment
  77. *----------------------------------------------------------------------*/
  78. #define CONFIG_ENV_IS_IN_FLASH 1 /* use FLASH for environment vars */
  79. /*-----------------------------------------------------------------------
  80. * FLASH related
  81. *----------------------------------------------------------------------*/
  82. #define CONFIG_SYS_MAX_FLASH_BANKS 3 /* number of banks */
  83. #define CONFIG_SYS_MAX_FLASH_SECT 256 /* sectors per device */
  84. #undef CONFIG_SYS_FLASH_CHECKSUM
  85. #define CONFIG_SYS_FLASH_ERASE_TOUT 120000 /* Timeout for Flash Erase (in ms) */
  86. #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Timeout for Flash Write (in ms) */
  87. #define CONFIG_SYS_FLASH_ADDR0 0x555
  88. #define CONFIG_SYS_FLASH_ADDR1 0x2aa
  89. #define CONFIG_SYS_FLASH_WORD_SIZE unsigned char
  90. #define CONFIG_SYS_FLASH_2ND_16BIT_DEV 1 /* bamboo has 8 and 16bit device */
  91. #define CONFIG_SYS_FLASH_2ND_ADDR 0x87800000 /* bamboo has 8 and 16bit device */
  92. #ifdef CONFIG_ENV_IS_IN_FLASH
  93. #define CONFIG_ENV_SECT_SIZE 0x10000 /* size of one complete sector */
  94. #define CONFIG_ENV_ADDR ((-CONFIG_SYS_MONITOR_LEN)-CONFIG_ENV_SECT_SIZE)
  95. #define CONFIG_ENV_SIZE 0x2000 /* Total Size of Environment Sector */
  96. /* Address and size of Redundant Environment Sector */
  97. #define CONFIG_ENV_ADDR_REDUND (CONFIG_ENV_ADDR-CONFIG_ENV_SECT_SIZE)
  98. #define CONFIG_ENV_SIZE_REDUND (CONFIG_ENV_SIZE)
  99. #endif /* CONFIG_ENV_IS_IN_FLASH */
  100. /*-----------------------------------------------------------------------
  101. * NAND FLASH
  102. *----------------------------------------------------------------------*/
  103. #define CONFIG_SYS_MAX_NAND_DEVICE 2
  104. #define CONFIG_SYS_NAND_BASE (CONFIG_SYS_NAND_ADDR + CONFIG_SYS_NAND_CS)
  105. #define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE, CONFIG_SYS_NAND_ADDR + 2 }
  106. #define CONFIG_SYS_NAND_SELECT_DEVICE 1 /* nand driver supports mutipl. chips */
  107. #define CONFIG_SYS_NAND_CS 1
  108. /*-----------------------------------------------------------------------
  109. * DDR SDRAM
  110. *----------------------------------------------------------------------------- */
  111. #define CONFIG_SPD_EEPROM /* Use SPD EEPROM for setup */
  112. #undef CONFIG_DDR_ECC /* don't use ECC */
  113. #define CONFIG_SYS_SIMULATE_SPD_EEPROM 0xff /* simulate spd eeprom on this address */
  114. #define SPD_EEPROM_ADDRESS {CONFIG_SYS_SIMULATE_SPD_EEPROM, 0x50, 0x51}
  115. #define CONFIG_SYS_MBYTES_SDRAM (64) /* 64MB fixed size for early-sdram-init */
  116. #define CONFIG_PROG_SDRAM_TLB
  117. /*-----------------------------------------------------------------------
  118. * I2C
  119. *----------------------------------------------------------------------*/
  120. #define CONFIG_SYS_I2C_PPC4XX_SPEED_0 400000
  121. #define CONFIG_SYS_I2C_EEPROM_ADDR (0xa8>>1)
  122. #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1
  123. #define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 3
  124. #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 10
  125. #ifdef CONFIG_ENV_IS_IN_EEPROM
  126. #define CONFIG_ENV_SIZE 0x200 /* Size of Environment vars */
  127. #define CONFIG_ENV_OFFSET 0x0
  128. #endif /* CONFIG_ENV_IS_IN_EEPROM */
  129. /*
  130. * Default environment variables
  131. */
  132. #define CONFIG_EXTRA_ENV_SETTINGS \
  133. CONFIG_AMCC_DEF_ENV \
  134. CONFIG_AMCC_DEF_ENV_POWERPC \
  135. CONFIG_AMCC_DEF_ENV_PPC_OLD \
  136. CONFIG_AMCC_DEF_ENV_NOR_UPD \
  137. "kernel_addr=fff00000\0" \
  138. "ramdisk_addr=fff10000\0" \
  139. ""
  140. #define CONFIG_HAS_ETH0
  141. #define CONFIG_PHY_ADDR 0 /* PHY address, See schematics */
  142. #define CONFIG_PHY1_ADDR 1
  143. #ifndef CONFIG_BAMBOO_NAND
  144. #define CONFIG_HAS_ETH1 1 /* add support for "eth1addr" */
  145. #endif /* CONFIG_BAMBOO_NAND */
  146. #ifdef CONFIG_440EP
  147. /* USB */
  148. #define CONFIG_USB_OHCI
  149. /*Comment this out to enable USB 1.1 device*/
  150. #define USB_2_0_DEVICE
  151. #endif /*CONFIG_440EP*/
  152. /*
  153. * Commands additional to the ones defined in amcc-common.h
  154. */
  155. #define CONFIG_CMD_DATE
  156. #define CONFIG_CMD_PCI
  157. #define CONFIG_CMD_SDRAM
  158. #ifdef CONFIG_BAMBOO_NAND
  159. #define CONFIG_CMD_NAND
  160. #endif
  161. #define CONFIG_SUPPORT_VFAT
  162. /* Partitions */
  163. #define CONFIG_MAC_PARTITION
  164. #define CONFIG_DOS_PARTITION
  165. #define CONFIG_ISO_PARTITION
  166. /*-----------------------------------------------------------------------
  167. * PCI stuff
  168. *-----------------------------------------------------------------------
  169. */
  170. /* General PCI */
  171. #define CONFIG_PCI_INDIRECT_BRIDGE /* indirect PCI bridge support */
  172. #define CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */
  173. #define CONFIG_SYS_PCI_TARGBASE 0x80000000 /* PCIaddr mapped to CONFIG_SYS_PCI_MEMBASE*/
  174. /* Board-specific PCI */
  175. #define CONFIG_SYS_PCI_TARGET_INIT
  176. #define CONFIG_SYS_PCI_MASTER_INIT
  177. #define CONFIG_SYS_PCI_SUBSYS_VENDORID 0x10e8 /* AMCC */
  178. #define CONFIG_SYS_PCI_SUBSYS_ID 0xcafe /* Whatever */
  179. #endif /* __CONFIG_H */