T4240RDB.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728
  1. /*
  2. * Copyright 2014 Freescale Semiconductor, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. /*
  7. * T4240 RDB board configuration file
  8. */
  9. #ifndef __CONFIG_H
  10. #define __CONFIG_H
  11. #define CONFIG_FSL_SATA_V2
  12. #define CONFIG_PCIE4
  13. #define CONFIG_ICS307_REFCLK_HZ 25000000 /* ICS307 ref clk freq */
  14. #ifdef CONFIG_RAMBOOT_PBL
  15. #define CONFIG_SYS_FSL_PBL_PBI $(SRCTREE)/board/freescale/t4rdb/t4_pbi.cfg
  16. #ifndef CONFIG_SDCARD
  17. #define CONFIG_RAMBOOT_TEXT_BASE CONFIG_SYS_TEXT_BASE
  18. #define CONFIG_RESET_VECTOR_ADDRESS 0xfffffffc
  19. #else
  20. #define CONFIG_SPL_FLUSH_IMAGE
  21. #define CONFIG_SPL_TARGET "u-boot-with-spl.bin"
  22. #define CONFIG_SPL_TEXT_BASE 0xFFFD8000
  23. #define CONFIG_SPL_PAD_TO 0x40000
  24. #define CONFIG_SPL_MAX_SIZE 0x28000
  25. #define RESET_VECTOR_OFFSET 0x27FFC
  26. #define BOOT_PAGE_OFFSET 0x27000
  27. #ifdef CONFIG_SDCARD
  28. #define CONFIG_RESET_VECTOR_ADDRESS 0x200FFC
  29. #define CONFIG_SYS_MMC_U_BOOT_SIZE (768 << 10)
  30. #define CONFIG_SYS_MMC_U_BOOT_DST 0x00200000
  31. #define CONFIG_SYS_MMC_U_BOOT_START 0x00200000
  32. #define CONFIG_SYS_MMC_U_BOOT_OFFS (260 << 10)
  33. #ifndef CONFIG_SPL_BUILD
  34. #define CONFIG_SYS_MPC85XX_NO_RESETVEC
  35. #endif
  36. #define CONFIG_SYS_LDSCRIPT "arch/powerpc/cpu/mpc85xx/u-boot.lds"
  37. #define CONFIG_SYS_FSL_PBL_RCW $(SRCTREE)/board/freescale/t4rdb/t4_sd_rcw.cfg
  38. #define CONFIG_SPL_MMC_BOOT
  39. #endif
  40. #ifdef CONFIG_SPL_BUILD
  41. #define CONFIG_SPL_SKIP_RELOCATE
  42. #define CONFIG_SPL_COMMON_INIT_DDR
  43. #define CONFIG_SYS_CCSR_DO_NOT_RELOCATE
  44. #endif
  45. #endif
  46. #endif /* CONFIG_RAMBOOT_PBL */
  47. #define CONFIG_DDR_ECC
  48. /* High Level Configuration Options */
  49. #define CONFIG_SYS_BOOK3E_HV /* Category E.HV supported */
  50. #define CONFIG_MP /* support multiple processors */
  51. #ifndef CONFIG_RESET_VECTOR_ADDRESS
  52. #define CONFIG_RESET_VECTOR_ADDRESS 0xeffffffc
  53. #endif
  54. #define CONFIG_SYS_FSL_CPC /* Corenet Platform Cache */
  55. #define CONFIG_SYS_NUM_CPC CONFIG_SYS_NUM_DDR_CTLRS
  56. #define CONFIG_PCIE1 /* PCIE controller 1 */
  57. #define CONFIG_PCIE2 /* PCIE controller 2 */
  58. #define CONFIG_PCIE3 /* PCIE controller 3 */
  59. #define CONFIG_FSL_PCI_INIT /* Use common FSL init code */
  60. #define CONFIG_SYS_PCI_64BIT /* enable 64-bit PCI resources */
  61. #define CONFIG_ENV_OVERWRITE
  62. /*
  63. * These can be toggled for performance analysis, otherwise use default.
  64. */
  65. #define CONFIG_SYS_CACHE_STASHING
  66. #define CONFIG_BTB /* toggle branch predition */
  67. #ifdef CONFIG_DDR_ECC
  68. #define CONFIG_ECC_INIT_VIA_DDRCONTROLLER
  69. #define CONFIG_MEM_INIT_VALUE 0xdeadbeef
  70. #endif
  71. #define CONFIG_ENABLE_36BIT_PHYS
  72. #define CONFIG_ADDR_MAP
  73. #define CONFIG_SYS_NUM_ADDR_MAP 64 /* number of TLB1 entries */
  74. #define CONFIG_SYS_MEMTEST_START 0x00200000 /* memtest works on */
  75. #define CONFIG_SYS_MEMTEST_END 0x00400000
  76. /*
  77. * Config the L3 Cache as L3 SRAM
  78. */
  79. #define CONFIG_SYS_INIT_L3_ADDR 0xFFFC0000
  80. #define CONFIG_SYS_L3_SIZE (512 << 10)
  81. #define CONFIG_SPL_GD_ADDR (CONFIG_SYS_INIT_L3_ADDR + 32 * 1024)
  82. #ifdef CONFIG_RAMBOOT_PBL
  83. #define CONFIG_ENV_ADDR (CONFIG_SPL_GD_ADDR + 4 * 1024)
  84. #endif
  85. #define CONFIG_SPL_RELOC_MALLOC_ADDR (CONFIG_SPL_GD_ADDR + 12 * 1024)
  86. #define CONFIG_SPL_RELOC_MALLOC_SIZE (50 << 10)
  87. #define CONFIG_SPL_RELOC_STACK (CONFIG_SPL_GD_ADDR + 64 * 1024)
  88. #define CONFIG_SPL_RELOC_STACK_SIZE (22 << 10)
  89. #define CONFIG_SYS_DCSRBAR 0xf0000000
  90. #define CONFIG_SYS_DCSRBAR_PHYS 0xf00000000ull
  91. /*
  92. * DDR Setup
  93. */
  94. #define CONFIG_VERY_BIG_RAM
  95. #define CONFIG_SYS_DDR_SDRAM_BASE 0x00000000
  96. #define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_SDRAM_BASE
  97. #define CONFIG_DIMM_SLOTS_PER_CTLR 1
  98. #define CONFIG_CHIP_SELECTS_PER_CTRL 4
  99. #define CONFIG_FSL_DDR_FIRST_SLOT_QUAD_CAPABLE
  100. #define CONFIG_DDR_SPD
  101. /*
  102. * IFC Definitions
  103. */
  104. #define CONFIG_SYS_FLASH_BASE 0xe0000000
  105. #define CONFIG_SYS_FLASH_BASE_PHYS (0xf00000000ull | CONFIG_SYS_FLASH_BASE)
  106. #ifdef CONFIG_SPL_BUILD
  107. #define CONFIG_SYS_MONITOR_BASE CONFIG_SPL_TEXT_BASE
  108. #else
  109. #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE
  110. #endif
  111. #define CONFIG_BOARD_EARLY_INIT_R /* call board_early_init_r function */
  112. #define CONFIG_MISC_INIT_R
  113. #define CONFIG_HWCONFIG
  114. /* define to use L1 as initial stack */
  115. #define CONFIG_L1_INIT_RAM
  116. #define CONFIG_SYS_INIT_RAM_LOCK
  117. #define CONFIG_SYS_INIT_RAM_ADDR 0xfdd00000 /* Initial L1 address */
  118. #define CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH 0xf
  119. #define CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW 0xfe03c000
  120. /* The assembler doesn't like typecast */
  121. #define CONFIG_SYS_INIT_RAM_ADDR_PHYS \
  122. ((CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH * 1ull << 32) | \
  123. CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW)
  124. #define CONFIG_SYS_INIT_RAM_SIZE 0x00004000
  125. #define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - \
  126. GENERATED_GBL_DATA_SIZE)
  127. #define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
  128. #define CONFIG_SYS_MONITOR_LEN (768 * 1024)
  129. #define CONFIG_SYS_MALLOC_LEN (4 * 1024 * 1024)
  130. /* Serial Port - controlled on board with jumper J8
  131. * open - index 2
  132. * shorted - index 1
  133. */
  134. #define CONFIG_SYS_NS16550_SERIAL
  135. #define CONFIG_SYS_NS16550_REG_SIZE 1
  136. #define CONFIG_SYS_NS16550_CLK (get_bus_freq(0)/2)
  137. #define CONFIG_SYS_BAUDRATE_TABLE \
  138. {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200}
  139. #define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_CCSRBAR+0x11C500)
  140. #define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_CCSRBAR+0x11C600)
  141. #define CONFIG_SYS_NS16550_COM3 (CONFIG_SYS_CCSRBAR+0x11D500)
  142. #define CONFIG_SYS_NS16550_COM4 (CONFIG_SYS_CCSRBAR+0x11D600)
  143. /* I2C */
  144. #define CONFIG_SYS_I2C
  145. #define CONFIG_SYS_I2C_FSL
  146. #define CONFIG_SYS_FSL_I2C_SLAVE 0x7F
  147. #define CONFIG_SYS_FSL_I2C_OFFSET 0x118000
  148. #define CONFIG_SYS_FSL_I2C2_SLAVE 0x7F
  149. #define CONFIG_SYS_FSL_I2C2_OFFSET 0x118100
  150. /*
  151. * General PCI
  152. * Memory space is mapped 1-1, but I/O space must start from 0.
  153. */
  154. /* controller 1, direct to uli, tgtid 3, Base address 20000 */
  155. #define CONFIG_SYS_PCIE1_MEM_VIRT 0x80000000
  156. #define CONFIG_SYS_PCIE1_MEM_BUS 0xe0000000
  157. #define CONFIG_SYS_PCIE1_MEM_PHYS 0xc00000000ull
  158. #define CONFIG_SYS_PCIE1_MEM_SIZE 0x20000000 /* 512M */
  159. #define CONFIG_SYS_PCIE1_IO_VIRT 0xf8000000
  160. #define CONFIG_SYS_PCIE1_IO_BUS 0x00000000
  161. #define CONFIG_SYS_PCIE1_IO_PHYS 0xff8000000ull
  162. #define CONFIG_SYS_PCIE1_IO_SIZE 0x00010000 /* 64k */
  163. /* controller 2, Slot 2, tgtid 2, Base address 201000 */
  164. #define CONFIG_SYS_PCIE2_MEM_VIRT 0xa0000000
  165. #define CONFIG_SYS_PCIE2_MEM_BUS 0xe0000000
  166. #define CONFIG_SYS_PCIE2_MEM_PHYS 0xc20000000ull
  167. #define CONFIG_SYS_PCIE2_MEM_SIZE 0x20000000 /* 512M */
  168. #define CONFIG_SYS_PCIE2_IO_VIRT 0xf8010000
  169. #define CONFIG_SYS_PCIE2_IO_BUS 0x00000000
  170. #define CONFIG_SYS_PCIE2_IO_PHYS 0xff8010000ull
  171. #define CONFIG_SYS_PCIE2_IO_SIZE 0x00010000 /* 64k */
  172. /* controller 3, Slot 1, tgtid 1, Base address 202000 */
  173. #define CONFIG_SYS_PCIE3_MEM_VIRT 0xc0000000
  174. #define CONFIG_SYS_PCIE3_MEM_BUS 0xe0000000
  175. #define CONFIG_SYS_PCIE3_MEM_PHYS 0xc40000000ull
  176. #define CONFIG_SYS_PCIE3_MEM_SIZE 0x20000000 /* 512M */
  177. #define CONFIG_SYS_PCIE3_IO_VIRT 0xf8020000
  178. #define CONFIG_SYS_PCIE3_IO_BUS 0x00000000
  179. #define CONFIG_SYS_PCIE3_IO_PHYS 0xff8020000ull
  180. #define CONFIG_SYS_PCIE3_IO_SIZE 0x00010000 /* 64k */
  181. /* controller 4, Base address 203000 */
  182. #define CONFIG_SYS_PCIE4_MEM_BUS 0xe0000000
  183. #define CONFIG_SYS_PCIE4_MEM_PHYS 0xc60000000ull
  184. #define CONFIG_SYS_PCIE4_MEM_SIZE 0x20000000 /* 512M */
  185. #define CONFIG_SYS_PCIE4_IO_BUS 0x00000000
  186. #define CONFIG_SYS_PCIE4_IO_PHYS 0xff8030000ull
  187. #define CONFIG_SYS_PCIE4_IO_SIZE 0x00010000 /* 64k */
  188. #ifdef CONFIG_PCI
  189. #define CONFIG_PCI_INDIRECT_BRIDGE
  190. #define CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */
  191. #endif /* CONFIG_PCI */
  192. /* SATA */
  193. #ifdef CONFIG_FSL_SATA_V2
  194. #define CONFIG_SYS_SATA_MAX_DEVICE 2
  195. #define CONFIG_SATA1
  196. #define CONFIG_SYS_SATA1 CONFIG_SYS_MPC85xx_SATA1_ADDR
  197. #define CONFIG_SYS_SATA1_FLAGS FLAGS_DMA
  198. #define CONFIG_SATA2
  199. #define CONFIG_SYS_SATA2 CONFIG_SYS_MPC85xx_SATA2_ADDR
  200. #define CONFIG_SYS_SATA2_FLAGS FLAGS_DMA
  201. #define CONFIG_LBA48
  202. #endif
  203. #ifdef CONFIG_FMAN_ENET
  204. #define CONFIG_MII /* MII PHY management */
  205. #define CONFIG_ETHPRIME "FM1@DTSEC1"
  206. #endif
  207. /*
  208. * Environment
  209. */
  210. #define CONFIG_LOADS_ECHO /* echo on for serial download */
  211. #define CONFIG_SYS_LOADS_BAUD_CHANGE /* allow baudrate change */
  212. /*
  213. * Command line configuration.
  214. */
  215. /*
  216. * Miscellaneous configurable options
  217. */
  218. #define CONFIG_SYS_LOAD_ADDR 0x2000000 /* default load address */
  219. /*
  220. * For booting Linux, the board info and command line data
  221. * have to be in the first 64 MB of memory, since this is
  222. * the maximum mapped by the Linux kernel during initialization.
  223. */
  224. #define CONFIG_SYS_BOOTMAPSZ (64 << 20) /* Initial map for Linux*/
  225. #define CONFIG_SYS_BOOTM_LEN (64 << 20) /* Increase max gunzip size */
  226. #ifdef CONFIG_CMD_KGDB
  227. #define CONFIG_KGDB_BAUDRATE 230400 /* speed to run kgdb serial port */
  228. #endif
  229. /*
  230. * Environment Configuration
  231. */
  232. #define CONFIG_ROOTPATH "/opt/nfsroot"
  233. #define CONFIG_BOOTFILE "uImage"
  234. #define CONFIG_UBOOTPATH "u-boot.bin" /* U-Boot image on TFTP server*/
  235. /* default location for tftp and bootm */
  236. #define CONFIG_LOADADDR 1000000
  237. #define CONFIG_HVBOOT \
  238. "setenv bootargs config-addr=0x60000000; " \
  239. "bootm 0x01000000 - 0x00f00000"
  240. #ifndef CONFIG_MTD_NOR_FLASH
  241. #else
  242. #define CONFIG_FLASH_CFI_DRIVER
  243. #define CONFIG_SYS_FLASH_CFI
  244. #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE
  245. #endif
  246. #if defined(CONFIG_SPIFLASH)
  247. #define CONFIG_SYS_EXTRA_ENV_RELOC
  248. #define CONFIG_ENV_SPI_BUS 0
  249. #define CONFIG_ENV_SPI_CS 0
  250. #define CONFIG_ENV_SPI_MAX_HZ 10000000
  251. #define CONFIG_ENV_SPI_MODE 0
  252. #define CONFIG_ENV_SIZE 0x2000 /* 8KB */
  253. #define CONFIG_ENV_OFFSET 0x100000 /* 1MB */
  254. #define CONFIG_ENV_SECT_SIZE 0x10000
  255. #elif defined(CONFIG_SDCARD)
  256. #define CONFIG_SYS_EXTRA_ENV_RELOC
  257. #define CONFIG_SYS_MMC_ENV_DEV 0
  258. #define CONFIG_ENV_SIZE 0x2000
  259. #define CONFIG_ENV_OFFSET (512 * 0x800)
  260. #elif defined(CONFIG_NAND)
  261. #define CONFIG_SYS_EXTRA_ENV_RELOC
  262. #define CONFIG_ENV_SIZE CONFIG_SYS_NAND_BLOCK_SIZE
  263. #define CONFIG_ENV_OFFSET (7 * CONFIG_SYS_NAND_BLOCK_SIZE)
  264. #elif defined(CONFIG_ENV_IS_NOWHERE)
  265. #define CONFIG_ENV_SIZE 0x2000
  266. #else
  267. #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE)
  268. #define CONFIG_ENV_SIZE 0x2000
  269. #define CONFIG_ENV_SECT_SIZE 0x20000 /* 128K (one sector) */
  270. #endif
  271. #define CONFIG_SYS_CLK_FREQ 66666666
  272. #define CONFIG_DDR_CLK_FREQ 133333333
  273. #ifndef __ASSEMBLY__
  274. unsigned long get_board_sys_clk(void);
  275. unsigned long get_board_ddr_clk(void);
  276. #endif
  277. /*
  278. * DDR Setup
  279. */
  280. #define CONFIG_SYS_SPD_BUS_NUM 0
  281. #define SPD_EEPROM_ADDRESS1 0x52
  282. #define SPD_EEPROM_ADDRESS2 0x54
  283. #define SPD_EEPROM_ADDRESS3 0x56
  284. #define SPD_EEPROM_ADDRESS SPD_EEPROM_ADDRESS1 /* for p3041/p5010 */
  285. #define CONFIG_SYS_SDRAM_SIZE 4096 /* for fixed parameter use */
  286. /*
  287. * IFC Definitions
  288. */
  289. #define CONFIG_SYS_NOR0_CSPR_EXT (0xf)
  290. #define CONFIG_SYS_NOR0_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS \
  291. + 0x8000000) | \
  292. CSPR_PORT_SIZE_16 | \
  293. CSPR_MSEL_NOR | \
  294. CSPR_V)
  295. #define CONFIG_SYS_NOR1_CSPR_EXT (0xf)
  296. #define CONFIG_SYS_NOR1_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | \
  297. CSPR_PORT_SIZE_16 | \
  298. CSPR_MSEL_NOR | \
  299. CSPR_V)
  300. #define CONFIG_SYS_NOR_AMASK IFC_AMASK(128*1024*1024)
  301. /* NOR Flash Timing Params */
  302. #define CONFIG_SYS_NOR_CSOR CSOR_NAND_TRHZ_80
  303. #define CONFIG_SYS_NOR_FTIM0 (FTIM0_NOR_TACSE(0x4) | \
  304. FTIM0_NOR_TEADC(0x5) | \
  305. FTIM0_NOR_TEAHC(0x5))
  306. #define CONFIG_SYS_NOR_FTIM1 (FTIM1_NOR_TACO(0x35) | \
  307. FTIM1_NOR_TRAD_NOR(0x1A) |\
  308. FTIM1_NOR_TSEQRAD_NOR(0x13))
  309. #define CONFIG_SYS_NOR_FTIM2 (FTIM2_NOR_TCS(0x4) | \
  310. FTIM2_NOR_TCH(0x4) | \
  311. FTIM2_NOR_TWPH(0x0E) | \
  312. FTIM2_NOR_TWP(0x1c))
  313. #define CONFIG_SYS_NOR_FTIM3 0x0
  314. #define CONFIG_SYS_FLASH_QUIET_TEST
  315. #define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */
  316. #define CONFIG_SYS_MAX_FLASH_BANKS 2 /* number of banks */
  317. #define CONFIG_SYS_MAX_FLASH_SECT 1024 /* sectors per device */
  318. #define CONFIG_SYS_FLASH_ERASE_TOUT 60000 /* Flash Erase Timeout (ms) */
  319. #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout (ms) */
  320. #define CONFIG_SYS_FLASH_EMPTY_INFO
  321. #define CONFIG_SYS_FLASH_BANKS_LIST {CONFIG_SYS_FLASH_BASE_PHYS \
  322. + 0x8000000, CONFIG_SYS_FLASH_BASE_PHYS}
  323. /* NAND Flash on IFC */
  324. #define CONFIG_NAND_FSL_IFC
  325. #define CONFIG_SYS_NAND_MAX_ECCPOS 256
  326. #define CONFIG_SYS_NAND_MAX_OOBFREE 2
  327. #define CONFIG_SYS_NAND_BASE 0xff800000
  328. #define CONFIG_SYS_NAND_BASE_PHYS (0xf00000000ull | CONFIG_SYS_NAND_BASE)
  329. #define CONFIG_SYS_NAND_CSPR_EXT (0xf)
  330. #define CONFIG_SYS_NAND_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \
  331. | CSPR_PORT_SIZE_8 /* Port Size = 8 bit */ \
  332. | CSPR_MSEL_NAND /* MSEL = NAND */ \
  333. | CSPR_V)
  334. #define CONFIG_SYS_NAND_AMASK IFC_AMASK(64*1024)
  335. #define CONFIG_SYS_NAND_CSOR (CSOR_NAND_ECC_ENC_EN /* ECC on encode */ \
  336. | CSOR_NAND_ECC_DEC_EN /* ECC on decode */ \
  337. | CSOR_NAND_ECC_MODE_4 /* 4-bit ECC */ \
  338. | CSOR_NAND_RAL_3 /* RAL = 2Byes */ \
  339. | CSOR_NAND_PGS_4K /* Page Size = 4K */ \
  340. | CSOR_NAND_SPRZ_224 /* Spare size = 224 */ \
  341. | CSOR_NAND_PB(128)) /*Page Per Block = 128*/
  342. #define CONFIG_SYS_NAND_ONFI_DETECTION
  343. /* ONFI NAND Flash mode0 Timing Params */
  344. #define CONFIG_SYS_NAND_FTIM0 (FTIM0_NAND_TCCST(0x07) | \
  345. FTIM0_NAND_TWP(0x18) | \
  346. FTIM0_NAND_TWCHT(0x07) | \
  347. FTIM0_NAND_TWH(0x0a))
  348. #define CONFIG_SYS_NAND_FTIM1 (FTIM1_NAND_TADLE(0x32) | \
  349. FTIM1_NAND_TWBE(0x39) | \
  350. FTIM1_NAND_TRR(0x0e) | \
  351. FTIM1_NAND_TRP(0x18))
  352. #define CONFIG_SYS_NAND_FTIM2 (FTIM2_NAND_TRAD(0x0f) | \
  353. FTIM2_NAND_TREH(0x0a) | \
  354. FTIM2_NAND_TWHRE(0x1e))
  355. #define CONFIG_SYS_NAND_FTIM3 0x0
  356. #define CONFIG_SYS_NAND_DDR_LAW 11
  357. #define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE }
  358. #define CONFIG_SYS_MAX_NAND_DEVICE 1
  359. #define CONFIG_SYS_NAND_BLOCK_SIZE (512 * 1024)
  360. #if defined(CONFIG_NAND)
  361. #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NAND_CSPR_EXT
  362. #define CONFIG_SYS_CSPR0 CONFIG_SYS_NAND_CSPR
  363. #define CONFIG_SYS_AMASK0 CONFIG_SYS_NAND_AMASK
  364. #define CONFIG_SYS_CSOR0 CONFIG_SYS_NAND_CSOR
  365. #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NAND_FTIM0
  366. #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NAND_FTIM1
  367. #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NAND_FTIM2
  368. #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NAND_FTIM3
  369. #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NOR0_CSPR_EXT
  370. #define CONFIG_SYS_CSPR2 CONFIG_SYS_NOR0_CSPR
  371. #define CONFIG_SYS_AMASK2 CONFIG_SYS_NOR_AMASK
  372. #define CONFIG_SYS_CSOR2 CONFIG_SYS_NOR_CSOR
  373. #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NOR_FTIM0
  374. #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NOR_FTIM1
  375. #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NOR_FTIM2
  376. #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NOR_FTIM3
  377. #else
  378. #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT
  379. #define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR
  380. #define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK
  381. #define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR
  382. #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0
  383. #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1
  384. #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2
  385. #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3
  386. #define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_NAND_CSPR_EXT
  387. #define CONFIG_SYS_CSPR1 CONFIG_SYS_NAND_CSPR
  388. #define CONFIG_SYS_AMASK1 CONFIG_SYS_NAND_AMASK
  389. #define CONFIG_SYS_CSOR1 CONFIG_SYS_NAND_CSOR
  390. #define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_NAND_FTIM0
  391. #define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_NAND_FTIM1
  392. #define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_NAND_FTIM2
  393. #define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_NAND_FTIM3
  394. #endif
  395. #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NOR1_CSPR_EXT
  396. #define CONFIG_SYS_CSPR2 CONFIG_SYS_NOR1_CSPR
  397. #define CONFIG_SYS_AMASK2 CONFIG_SYS_NOR_AMASK
  398. #define CONFIG_SYS_CSOR2 CONFIG_SYS_NOR_CSOR
  399. #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NOR_FTIM0
  400. #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NOR_FTIM1
  401. #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NOR_FTIM2
  402. #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NOR_FTIM3
  403. /* CPLD on IFC */
  404. #define CONFIG_SYS_CPLD_BASE 0xffdf0000
  405. #define CONFIG_SYS_CPLD_BASE_PHYS (0xf00000000ull | CONFIG_SYS_CPLD_BASE)
  406. #define CONFIG_SYS_CSPR3_EXT (0xf)
  407. #define CONFIG_SYS_CSPR3 (CSPR_PHYS_ADDR(CONFIG_SYS_CPLD_BASE_PHYS) \
  408. | CSPR_PORT_SIZE_8 \
  409. | CSPR_MSEL_GPCM \
  410. | CSPR_V)
  411. #define CONFIG_SYS_AMASK3 IFC_AMASK(4*1024)
  412. #define CONFIG_SYS_CSOR3 0x0
  413. /* CPLD Timing parameters for IFC CS3 */
  414. #define CONFIG_SYS_CS3_FTIM0 (FTIM0_GPCM_TACSE(0x0e) | \
  415. FTIM0_GPCM_TEADC(0x0e) | \
  416. FTIM0_GPCM_TEAHC(0x0e))
  417. #define CONFIG_SYS_CS3_FTIM1 (FTIM1_GPCM_TACO(0x0e) | \
  418. FTIM1_GPCM_TRAD(0x1f))
  419. #define CONFIG_SYS_CS3_FTIM2 (FTIM2_GPCM_TCS(0x0e) | \
  420. FTIM2_GPCM_TCH(0x8) | \
  421. FTIM2_GPCM_TWP(0x1f))
  422. #define CONFIG_SYS_CS3_FTIM3 0x0
  423. #if defined(CONFIG_RAMBOOT_PBL)
  424. #define CONFIG_SYS_RAMBOOT
  425. #endif
  426. /* I2C */
  427. #define CONFIG_SYS_FSL_I2C_SPEED 100000 /* I2C speed */
  428. #define CONFIG_SYS_FSL_I2C2_SPEED 100000 /* I2C2 speed */
  429. #define I2C_MUX_PCA_ADDR_PRI 0x77 /* I2C bus multiplexer,primary */
  430. #define I2C_MUX_PCA_ADDR_SEC 0x76 /* I2C bus multiplexer,secondary */
  431. #define I2C_MUX_CH_DEFAULT 0x8
  432. #define I2C_MUX_CH_VOL_MONITOR 0xa
  433. #define I2C_MUX_CH_VSC3316_FS 0xc
  434. #define I2C_MUX_CH_VSC3316_BS 0xd
  435. /* Voltage monitor on channel 2*/
  436. #define I2C_VOL_MONITOR_ADDR 0x40
  437. #define I2C_VOL_MONITOR_BUS_V_OFFSET 0x2
  438. #define I2C_VOL_MONITOR_BUS_V_OVF 0x1
  439. #define I2C_VOL_MONITOR_BUS_V_SHIFT 3
  440. #define CONFIG_VID_FLS_ENV "t4240rdb_vdd_mv"
  441. #ifndef CONFIG_SPL_BUILD
  442. #define CONFIG_VID
  443. #endif
  444. #define CONFIG_VOL_MONITOR_IR36021_SET
  445. #define CONFIG_VOL_MONITOR_IR36021_READ
  446. /* The lowest and highest voltage allowed for T4240RDB */
  447. #define VDD_MV_MIN 819
  448. #define VDD_MV_MAX 1212
  449. /*
  450. * eSPI - Enhanced SPI
  451. */
  452. #define CONFIG_SF_DEFAULT_SPEED 10000000
  453. #define CONFIG_SF_DEFAULT_MODE 0
  454. /* Qman/Bman */
  455. #ifndef CONFIG_NOBQFMAN
  456. #define CONFIG_SYS_BMAN_NUM_PORTALS 50
  457. #define CONFIG_SYS_BMAN_MEM_BASE 0xf4000000
  458. #define CONFIG_SYS_BMAN_MEM_PHYS 0xff4000000ull
  459. #define CONFIG_SYS_BMAN_MEM_SIZE 0x02000000
  460. #define CONFIG_SYS_BMAN_SP_CENA_SIZE 0x4000
  461. #define CONFIG_SYS_BMAN_SP_CINH_SIZE 0x1000
  462. #define CONFIG_SYS_BMAN_CENA_BASE CONFIG_SYS_BMAN_MEM_BASE
  463. #define CONFIG_SYS_BMAN_CENA_SIZE (CONFIG_SYS_BMAN_MEM_SIZE >> 1)
  464. #define CONFIG_SYS_BMAN_CINH_BASE (CONFIG_SYS_BMAN_MEM_BASE + \
  465. CONFIG_SYS_BMAN_CENA_SIZE)
  466. #define CONFIG_SYS_BMAN_CINH_SIZE (CONFIG_SYS_BMAN_MEM_SIZE >> 1)
  467. #define CONFIG_SYS_BMAN_SWP_ISDR_REG 0xE08
  468. #define CONFIG_SYS_QMAN_NUM_PORTALS 50
  469. #define CONFIG_SYS_QMAN_MEM_BASE 0xf6000000
  470. #define CONFIG_SYS_QMAN_MEM_PHYS 0xff6000000ull
  471. #define CONFIG_SYS_QMAN_MEM_SIZE 0x02000000
  472. #define CONFIG_SYS_QMAN_SP_CENA_SIZE 0x4000
  473. #define CONFIG_SYS_QMAN_SP_CINH_SIZE 0x1000
  474. #define CONFIG_SYS_QMAN_CENA_BASE CONFIG_SYS_QMAN_MEM_BASE
  475. #define CONFIG_SYS_QMAN_CENA_SIZE (CONFIG_SYS_QMAN_MEM_SIZE >> 1)
  476. #define CONFIG_SYS_QMAN_CINH_BASE (CONFIG_SYS_QMAN_MEM_BASE + \
  477. CONFIG_SYS_QMAN_CENA_SIZE)
  478. #define CONFIG_SYS_QMAN_CINH_SIZE (CONFIG_SYS_QMAN_MEM_SIZE >> 1)
  479. #define CONFIG_SYS_QMAN_SWP_ISDR_REG 0xE08
  480. #define CONFIG_SYS_DPAA_FMAN
  481. #define CONFIG_SYS_DPAA_PME
  482. #define CONFIG_SYS_PMAN
  483. #define CONFIG_SYS_DPAA_DCE
  484. #define CONFIG_SYS_DPAA_RMAN
  485. #define CONFIG_SYS_INTERLAKEN
  486. /* Default address of microcode for the Linux Fman driver */
  487. #if defined(CONFIG_SPIFLASH)
  488. /*
  489. * env is stored at 0x100000, sector size is 0x10000, ucode is stored after
  490. * env, so we got 0x110000.
  491. */
  492. #define CONFIG_SYS_QE_FW_IN_SPIFLASH
  493. #define CONFIG_SYS_FMAN_FW_ADDR 0x110000
  494. #elif defined(CONFIG_SDCARD)
  495. /*
  496. * PBL SD boot image should stored at 0x1000(8 blocks), the size of the image is
  497. * about 1MB (2048 blocks), Env is stored after the image, and the env size is
  498. * 0x2000 (16 blocks), 8 + 2048 + 16 = 2072, enlarge it to 2080.
  499. */
  500. #define CONFIG_SYS_QE_FMAN_FW_IN_MMC
  501. #define CONFIG_SYS_FMAN_FW_ADDR (512 * 0x820)
  502. #elif defined(CONFIG_NAND)
  503. #define CONFIG_SYS_QE_FMAN_FW_IN_NAND
  504. #define CONFIG_SYS_FMAN_FW_ADDR (8 * CONFIG_SYS_NAND_BLOCK_SIZE)
  505. #else
  506. #define CONFIG_SYS_QE_FMAN_FW_IN_NOR
  507. #define CONFIG_SYS_FMAN_FW_ADDR 0xEFF00000
  508. #endif
  509. #define CONFIG_SYS_QE_FMAN_FW_LENGTH 0x10000
  510. #define CONFIG_SYS_FDT_PAD (0x3000 + CONFIG_SYS_QE_FMAN_FW_LENGTH)
  511. #endif /* CONFIG_NOBQFMAN */
  512. #ifdef CONFIG_SYS_DPAA_FMAN
  513. #define CONFIG_FMAN_ENET
  514. #define CONFIG_PHYLIB_10G
  515. #define CONFIG_PHY_VITESSE
  516. #define CONFIG_PHY_CORTINA
  517. #define CONFIG_SYS_CORTINA_FW_IN_NOR
  518. #define CONFIG_CORTINA_FW_ADDR 0xefe00000
  519. #define CONFIG_CORTINA_FW_LENGTH 0x40000
  520. #define CONFIG_PHY_TERANETICS
  521. #define SGMII_PHY_ADDR1 0x0
  522. #define SGMII_PHY_ADDR2 0x1
  523. #define SGMII_PHY_ADDR3 0x2
  524. #define SGMII_PHY_ADDR4 0x3
  525. #define SGMII_PHY_ADDR5 0x4
  526. #define SGMII_PHY_ADDR6 0x5
  527. #define SGMII_PHY_ADDR7 0x6
  528. #define SGMII_PHY_ADDR8 0x7
  529. #define FM1_10GEC1_PHY_ADDR 0x10
  530. #define FM1_10GEC2_PHY_ADDR 0x11
  531. #define FM2_10GEC1_PHY_ADDR 0x12
  532. #define FM2_10GEC2_PHY_ADDR 0x13
  533. #define CORTINA_PHY_ADDR1 FM1_10GEC1_PHY_ADDR
  534. #define CORTINA_PHY_ADDR2 FM1_10GEC2_PHY_ADDR
  535. #define CORTINA_PHY_ADDR3 FM2_10GEC1_PHY_ADDR
  536. #define CORTINA_PHY_ADDR4 FM2_10GEC2_PHY_ADDR
  537. #endif
  538. /* SATA */
  539. #ifdef CONFIG_FSL_SATA_V2
  540. #define CONFIG_SYS_SATA_MAX_DEVICE 2
  541. #define CONFIG_SATA1
  542. #define CONFIG_SYS_SATA1 CONFIG_SYS_MPC85xx_SATA1_ADDR
  543. #define CONFIG_SYS_SATA1_FLAGS FLAGS_DMA
  544. #define CONFIG_SATA2
  545. #define CONFIG_SYS_SATA2 CONFIG_SYS_MPC85xx_SATA2_ADDR
  546. #define CONFIG_SYS_SATA2_FLAGS FLAGS_DMA
  547. #define CONFIG_LBA48
  548. #endif
  549. #ifdef CONFIG_FMAN_ENET
  550. #define CONFIG_MII /* MII PHY management */
  551. #define CONFIG_ETHPRIME "FM1@DTSEC1"
  552. #endif
  553. /*
  554. * USB
  555. */
  556. #define CONFIG_USB_EHCI_FSL
  557. #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
  558. #define CONFIG_HAS_FSL_DR_USB
  559. #ifdef CONFIG_MMC
  560. #define CONFIG_FSL_ESDHC
  561. #define CONFIG_SYS_FSL_ESDHC_ADDR CONFIG_SYS_MPC85xx_ESDHC_ADDR
  562. #define CONFIG_SYS_FSL_ESDHC_BROKEN_TIMEOUT
  563. #define CONFIG_SYS_FSL_MMC_HAS_CAPBLT_VS33
  564. #endif
  565. #define __USB_PHY_TYPE utmi
  566. /*
  567. * T4240 has 3 DDR controllers. Default to 3-way interleaving. It can be
  568. * 3way_1KB, 3way_4KB, 3way_8KB. T4160 has 2 DDR controllers. Default to 2-way
  569. * interleaving. It can be cacheline, page, bank, superbank.
  570. * See doc/README.fsl-ddr for details.
  571. */
  572. #ifdef CONFIG_ARCH_T4240
  573. #define CTRL_INTLV_PREFERED 3way_4KB
  574. #else
  575. #define CTRL_INTLV_PREFERED cacheline
  576. #endif
  577. #define CONFIG_EXTRA_ENV_SETTINGS \
  578. "hwconfig=fsl_ddr:" \
  579. "ctlr_intlv=" __stringify(CTRL_INTLV_PREFERED) "," \
  580. "bank_intlv=auto;" \
  581. "usb1:dr_mode=host,phy_type=" __stringify(__USB_PHY_TYPE) "\0"\
  582. "netdev=eth0\0" \
  583. "uboot=" __stringify(CONFIG_UBOOTPATH) "\0" \
  584. "ubootaddr=" __stringify(CONFIG_SYS_TEXT_BASE) "\0" \
  585. "tftpflash=tftpboot $loadaddr $uboot && " \
  586. "protect off $ubootaddr +$filesize && " \
  587. "erase $ubootaddr +$filesize && " \
  588. "cp.b $loadaddr $ubootaddr $filesize && " \
  589. "protect on $ubootaddr +$filesize && " \
  590. "cmp.b $loadaddr $ubootaddr $filesize\0" \
  591. "consoledev=ttyS0\0" \
  592. "ramdiskaddr=2000000\0" \
  593. "ramdiskfile=t4240rdb/ramdisk.uboot\0" \
  594. "fdtaddr=1e00000\0" \
  595. "fdtfile=t4240rdb/t4240rdb.dtb\0" \
  596. "bdev=sda3\0"
  597. #define CONFIG_HVBOOT \
  598. "setenv bootargs config-addr=0x60000000; " \
  599. "bootm 0x01000000 - 0x00f00000"
  600. #define CONFIG_LINUX \
  601. "setenv bootargs root=/dev/ram rw " \
  602. "console=$consoledev,$baudrate $othbootargs;" \
  603. "setenv ramdiskaddr 0x02000000;" \
  604. "setenv fdtaddr 0x00c00000;" \
  605. "setenv loadaddr 0x1000000;" \
  606. "bootm $loadaddr $ramdiskaddr $fdtaddr"
  607. #define CONFIG_HDBOOT \
  608. "setenv bootargs root=/dev/$bdev rw " \
  609. "console=$consoledev,$baudrate $othbootargs;" \
  610. "tftp $loadaddr $bootfile;" \
  611. "tftp $fdtaddr $fdtfile;" \
  612. "bootm $loadaddr - $fdtaddr"
  613. #define CONFIG_NFSBOOTCOMMAND \
  614. "setenv bootargs root=/dev/nfs rw " \
  615. "nfsroot=$serverip:$rootpath " \
  616. "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:$netdev:off " \
  617. "console=$consoledev,$baudrate $othbootargs;" \
  618. "tftp $loadaddr $bootfile;" \
  619. "tftp $fdtaddr $fdtfile;" \
  620. "bootm $loadaddr - $fdtaddr"
  621. #define CONFIG_RAMBOOTCOMMAND \
  622. "setenv bootargs root=/dev/ram rw " \
  623. "console=$consoledev,$baudrate $othbootargs;" \
  624. "tftp $ramdiskaddr $ramdiskfile;" \
  625. "tftp $loadaddr $bootfile;" \
  626. "tftp $fdtaddr $fdtfile;" \
  627. "bootm $loadaddr $ramdiskaddr $fdtaddr"
  628. #define CONFIG_BOOTCOMMAND CONFIG_LINUX
  629. #include <asm/fsl_secure_boot.h>
  630. #endif /* __CONFIG_H */