1c59e1b4dSTimur Tabi /* 23d7506faSramneek mehresh * Copyright 2010-2012 Freescale Semiconductor, Inc. 3c59e1b4dSTimur Tabi * Authors: Srikanth Srinivasan <srikanth.srinivasan@freescale.com> 4c59e1b4dSTimur Tabi * Timur Tabi <timur@freescale.com> 5c59e1b4dSTimur Tabi * 61a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 7c59e1b4dSTimur Tabi */ 8c59e1b4dSTimur Tabi 9c59e1b4dSTimur Tabi #ifndef __CONFIG_H 10c59e1b4dSTimur Tabi #define __CONFIG_H 11c59e1b4dSTimur Tabi 12c59e1b4dSTimur Tabi #include "../board/freescale/common/ics307_clk.h" 13c59e1b4dSTimur Tabi 14840a5182STang Yuantian #define CONFIG_DISPLAY_BOARDINFO 15840a5182STang Yuantian 169899ac19SJiang Yutang #ifdef CONFIG_36BIT 179899ac19SJiang Yutang #define CONFIG_PHYS_64BIT 189899ac19SJiang Yutang #endif 199899ac19SJiang Yutang 20af253608SMatthew McClintock #ifdef CONFIG_SDCARD 217c8eea59SYing Zhang #define CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT 227c8eea59SYing Zhang #define CONFIG_SPL_ENV_SUPPORT 237c8eea59SYing Zhang #define CONFIG_SPL_SERIAL_SUPPORT 247c8eea59SYing Zhang #define CONFIG_SPL_MMC_SUPPORT 257c8eea59SYing Zhang #define CONFIG_SPL_MMC_MINIMAL 267c8eea59SYing Zhang #define CONFIG_SPL_FLUSH_IMAGE 277c8eea59SYing Zhang #define CONFIG_SPL_TARGET "u-boot-with-spl.bin" 287c8eea59SYing Zhang #define CONFIG_SPL_LIBGENERIC_SUPPORT 297c8eea59SYing Zhang #define CONFIG_SPL_LIBCOMMON_SUPPORT 307c8eea59SYing Zhang #define CONFIG_SPL_I2C_SUPPORT 317c8eea59SYing Zhang #define CONFIG_FSL_LAW /* Use common FSL init code */ 327c8eea59SYing Zhang #define CONFIG_SYS_TEXT_BASE 0x11001000 337c8eea59SYing Zhang #define CONFIG_SPL_TEXT_BASE 0xf8f81000 34ee4d6511SYing Zhang #define CONFIG_SPL_PAD_TO 0x20000 35ee4d6511SYing Zhang #define CONFIG_SPL_MAX_SIZE (128 * 1024) 36e222b1f3SPrabhakar Kushwaha #define CONFIG_SYS_MMC_U_BOOT_SIZE (768 << 10) 377c8eea59SYing Zhang #define CONFIG_SYS_MMC_U_BOOT_DST (0x11000000) 387c8eea59SYing Zhang #define CONFIG_SYS_MMC_U_BOOT_START (0x11000000) 39ee4d6511SYing Zhang #define CONFIG_SYS_MMC_U_BOOT_OFFS (128 << 10) 407c8eea59SYing Zhang #define CONFIG_SYS_MPC85XX_NO_RESETVEC 417c8eea59SYing Zhang #define CONFIG_SYS_LDSCRIPT "arch/powerpc/cpu/mpc85xx/u-boot.lds" 427c8eea59SYing Zhang #define CONFIG_SPL_MMC_BOOT 437c8eea59SYing Zhang #ifdef CONFIG_SPL_BUILD 447c8eea59SYing Zhang #define CONFIG_SPL_COMMON_INIT_DDR 457c8eea59SYing Zhang #endif 46af253608SMatthew McClintock #endif 47af253608SMatthew McClintock 48af253608SMatthew McClintock #ifdef CONFIG_SPIFLASH 49382ce7e9SYing Zhang #define CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT 50382ce7e9SYing Zhang #define CONFIG_SPL_ENV_SUPPORT 51382ce7e9SYing Zhang #define CONFIG_SPL_SERIAL_SUPPORT 52382ce7e9SYing Zhang #define CONFIG_SPL_SPI_SUPPORT 53382ce7e9SYing Zhang #define CONFIG_SPL_SPI_FLASH_SUPPORT 54382ce7e9SYing Zhang #define CONFIG_SPL_SPI_FLASH_MINIMAL 55382ce7e9SYing Zhang #define CONFIG_SPL_FLUSH_IMAGE 56382ce7e9SYing Zhang #define CONFIG_SPL_TARGET "u-boot-with-spl.bin" 57382ce7e9SYing Zhang #define CONFIG_SPL_LIBGENERIC_SUPPORT 58382ce7e9SYing Zhang #define CONFIG_SPL_LIBCOMMON_SUPPORT 59382ce7e9SYing Zhang #define CONFIG_SPL_I2C_SUPPORT 60382ce7e9SYing Zhang #define CONFIG_FSL_LAW /* Use common FSL init code */ 61382ce7e9SYing Zhang #define CONFIG_SYS_TEXT_BASE 0x11001000 62382ce7e9SYing Zhang #define CONFIG_SPL_TEXT_BASE 0xf8f81000 63ee4d6511SYing Zhang #define CONFIG_SPL_PAD_TO 0x20000 64ee4d6511SYing Zhang #define CONFIG_SPL_MAX_SIZE (128 * 1024) 65e222b1f3SPrabhakar Kushwaha #define CONFIG_SYS_SPI_FLASH_U_BOOT_SIZE (768 << 10) 66382ce7e9SYing Zhang #define CONFIG_SYS_SPI_FLASH_U_BOOT_DST (0x11000000) 67382ce7e9SYing Zhang #define CONFIG_SYS_SPI_FLASH_U_BOOT_START (0x11000000) 68ee4d6511SYing Zhang #define CONFIG_SYS_SPI_FLASH_U_BOOT_OFFS (128 << 10) 69382ce7e9SYing Zhang #define CONFIG_SYS_MPC85XX_NO_RESETVEC 70382ce7e9SYing Zhang #define CONFIG_SYS_LDSCRIPT "arch/powerpc/cpu/mpc85xx/u-boot.lds" 71382ce7e9SYing Zhang #define CONFIG_SPL_SPI_BOOT 72382ce7e9SYing Zhang #ifdef CONFIG_SPL_BUILD 73382ce7e9SYing Zhang #define CONFIG_SPL_COMMON_INIT_DDR 74382ce7e9SYing Zhang #endif 75af253608SMatthew McClintock #endif 76af253608SMatthew McClintock 77f45210d6SMatthew McClintock #define CONFIG_NAND_FSL_ELBC 789407c3fcSYork Sun #define CONFIG_SYS_NAND_MAX_ECCPOS 56 799407c3fcSYork Sun #define CONFIG_SYS_NAND_MAX_OOBFREE 5 80f45210d6SMatthew McClintock 81f45210d6SMatthew McClintock #ifdef CONFIG_NAND 825d97fe2aSYing Zhang #ifdef CONFIG_TPL_BUILD 835d97fe2aSYing Zhang #define CONFIG_SPL_NAND_BOOT 845d97fe2aSYing Zhang #define CONFIG_SPL_FLUSH_IMAGE 855d97fe2aSYing Zhang #define CONFIG_SPL_ENV_SUPPORT 865d97fe2aSYing Zhang #define CONFIG_SPL_NAND_INIT 875d97fe2aSYing Zhang #define CONFIG_SPL_SERIAL_SUPPORT 885d97fe2aSYing Zhang #define CONFIG_SPL_LIBGENERIC_SUPPORT 895d97fe2aSYing Zhang #define CONFIG_SPL_LIBCOMMON_SUPPORT 905d97fe2aSYing Zhang #define CONFIG_SPL_I2C_SUPPORT 915d97fe2aSYing Zhang #define CONFIG_SPL_NAND_SUPPORT 925d97fe2aSYing Zhang #define CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT 935d97fe2aSYing Zhang #define CONFIG_SPL_COMMON_INIT_DDR 945d97fe2aSYing Zhang #define CONFIG_SPL_MAX_SIZE (128 << 10) 955d97fe2aSYing Zhang #define CONFIG_SPL_TEXT_BASE 0xf8f81000 965d97fe2aSYing Zhang #define CONFIG_SYS_MPC85XX_NO_RESETVEC 97e222b1f3SPrabhakar Kushwaha #define CONFIG_SYS_NAND_U_BOOT_SIZE (832 << 10) 985d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_DST (0x11000000) 995d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_START (0x11000000) 1005d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_OFFS ((128 + 128) << 10) 1015d97fe2aSYing Zhang #elif defined(CONFIG_SPL_BUILD) 102f45210d6SMatthew McClintock #define CONFIG_SPL_INIT_MINIMAL 103f45210d6SMatthew McClintock #define CONFIG_SPL_SERIAL_SUPPORT 104f45210d6SMatthew McClintock #define CONFIG_SPL_NAND_SUPPORT 105f45210d6SMatthew McClintock #define CONFIG_SPL_FLUSH_IMAGE 1065d97fe2aSYing Zhang #define CONFIG_SPL_TEXT_BASE 0xff800000 1075ed6f447STom Rini #define CONFIG_SPL_MAX_SIZE 4096 1085d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_SIZE (128 << 10) 1095d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_DST 0xf8f80000 1105d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_START 0xf8f80000 1115d97fe2aSYing Zhang #define CONFIG_SYS_NAND_U_BOOT_OFFS (128 << 10) 1125d97fe2aSYing Zhang #endif 1135d97fe2aSYing Zhang #define CONFIG_SPL_PAD_TO 0x20000 1145d97fe2aSYing Zhang #define CONFIG_TPL_PAD_TO 0x20000 1155d97fe2aSYing Zhang #define CONFIG_SPL_TARGET "u-boot-with-spl.bin" 1165d97fe2aSYing Zhang #define CONFIG_SYS_TEXT_BASE 0x11001000 117f45210d6SMatthew McClintock #define CONFIG_SYS_LDSCRIPT "arch/powerpc/cpu/mpc85xx/u-boot-nand.lds" 118f45210d6SMatthew McClintock #endif 119f45210d6SMatthew McClintock 120c59e1b4dSTimur Tabi /* High Level Configuration Options */ 121c59e1b4dSTimur Tabi #define CONFIG_BOOKE /* BOOKE */ 122c59e1b4dSTimur Tabi #define CONFIG_E500 /* BOOKE e500 family */ 123c59e1b4dSTimur Tabi #define CONFIG_P1022 124c59e1b4dSTimur Tabi #define CONFIG_P1022DS 125c59e1b4dSTimur Tabi #define CONFIG_MP /* support multiple processors */ 126c59e1b4dSTimur Tabi 1272ae18241SWolfgang Denk #ifndef CONFIG_SYS_TEXT_BASE 128e222b1f3SPrabhakar Kushwaha #define CONFIG_SYS_TEXT_BASE 0xeff40000 1292ae18241SWolfgang Denk #endif 1302ae18241SWolfgang Denk 1317a577fdaSKumar Gala #ifndef CONFIG_RESET_VECTOR_ADDRESS 1327a577fdaSKumar Gala #define CONFIG_RESET_VECTOR_ADDRESS 0xeffffffc 1337a577fdaSKumar Gala #endif 1347a577fdaSKumar Gala 135c59e1b4dSTimur Tabi #define CONFIG_FSL_ELBC /* Has Enhanced localbus controller */ 136c59e1b4dSTimur Tabi #define CONFIG_PCI /* Enable PCI/PCIE */ 137b38eaec5SRobert P. J. Day #define CONFIG_PCIE1 /* PCIE controller 1 (slot 1) */ 138b38eaec5SRobert P. J. Day #define CONFIG_PCIE2 /* PCIE controller 2 (slot 2) */ 139b38eaec5SRobert P. J. Day #define CONFIG_PCIE3 /* PCIE controller 3 (ULI bridge) */ 140c59e1b4dSTimur Tabi #define CONFIG_FSL_PCI_INIT /* Use common FSL init code */ 141c59e1b4dSTimur Tabi #define CONFIG_FSL_PCIE_RESET /* need PCIe reset errata */ 142c59e1b4dSTimur Tabi #define CONFIG_SYS_PCI_64BIT /* enable 64-bit PCI resources */ 143c59e1b4dSTimur Tabi 144c59e1b4dSTimur Tabi #define CONFIG_ENABLE_36BIT_PHYS 145babb348cSTimur Tabi 146babb348cSTimur Tabi #ifdef CONFIG_PHYS_64BIT 147c59e1b4dSTimur Tabi #define CONFIG_ADDR_MAP 148c59e1b4dSTimur Tabi #define CONFIG_SYS_NUM_ADDR_MAP 16 /* number of TLB1 entries */ 1499899ac19SJiang Yutang #endif 150c59e1b4dSTimur Tabi 151c59e1b4dSTimur Tabi #define CONFIG_FSL_LAW /* Use common FSL init code */ 152c59e1b4dSTimur Tabi 153c59e1b4dSTimur Tabi #define CONFIG_SYS_CLK_FREQ get_board_sys_clk() 154c59e1b4dSTimur Tabi #define CONFIG_DDR_CLK_FREQ get_board_ddr_clk() 155c59e1b4dSTimur Tabi #define CONFIG_ICS307_REFCLK_HZ 33333000 /* ICS307 clock chip ref freq */ 156c59e1b4dSTimur Tabi 157c59e1b4dSTimur Tabi /* 158c59e1b4dSTimur Tabi * These can be toggled for performance analysis, otherwise use default. 159c59e1b4dSTimur Tabi */ 160c59e1b4dSTimur Tabi #define CONFIG_L2_CACHE 161c59e1b4dSTimur Tabi #define CONFIG_BTB 162c59e1b4dSTimur Tabi 163c59e1b4dSTimur Tabi #define CONFIG_SYS_MEMTEST_START 0x00000000 164c59e1b4dSTimur Tabi #define CONFIG_SYS_MEMTEST_END 0x7fffffff 165c59e1b4dSTimur Tabi 166e46fedfeSTimur Tabi #define CONFIG_SYS_CCSRBAR 0xffe00000 167e46fedfeSTimur Tabi #define CONFIG_SYS_CCSRBAR_PHYS_LOW CONFIG_SYS_CCSRBAR 168c59e1b4dSTimur Tabi 169f45210d6SMatthew McClintock /* IN case of NAND bootloader relocate CCSRBAR in RAMboot code not in the 4k 170f45210d6SMatthew McClintock SPL code*/ 171f45210d6SMatthew McClintock #ifdef CONFIG_SPL_BUILD 172f45210d6SMatthew McClintock #define CONFIG_SYS_CCSR_DO_NOT_RELOCATE 173f45210d6SMatthew McClintock #endif 174f45210d6SMatthew McClintock 175c59e1b4dSTimur Tabi /* DDR Setup */ 176c59e1b4dSTimur Tabi #define CONFIG_DDR_SPD 177c59e1b4dSTimur Tabi #define CONFIG_VERY_BIG_RAM 1785614e71bSYork Sun #define CONFIG_SYS_FSL_DDR3 179c59e1b4dSTimur Tabi 180c59e1b4dSTimur Tabi #ifdef CONFIG_DDR_ECC 181c59e1b4dSTimur Tabi #define CONFIG_ECC_INIT_VIA_DDRCONTROLLER 182c59e1b4dSTimur Tabi #define CONFIG_MEM_INIT_VALUE 0xdeadbeef 183c59e1b4dSTimur Tabi #endif 184c59e1b4dSTimur Tabi 185c59e1b4dSTimur Tabi #define CONFIG_SYS_DDR_SDRAM_BASE 0x00000000 186c59e1b4dSTimur Tabi #define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_SDRAM_BASE 187c59e1b4dSTimur Tabi 188c59e1b4dSTimur Tabi #define CONFIG_NUM_DDR_CONTROLLERS 1 189c59e1b4dSTimur Tabi #define CONFIG_DIMM_SLOTS_PER_CTLR 1 190c59e1b4dSTimur Tabi #define CONFIG_CHIP_SELECTS_PER_CTRL (2 * CONFIG_DIMM_SLOTS_PER_CTLR) 191c59e1b4dSTimur Tabi 192c59e1b4dSTimur Tabi /* I2C addresses of SPD EEPROMs */ 193c59e1b4dSTimur Tabi #define CONFIG_SYS_SPD_BUS_NUM 1 194c39f44dcSKumar Gala #define SPD_EEPROM_ADDRESS 0x51 /* CTLR 0 DIMM 0 */ 195c59e1b4dSTimur Tabi 196f45210d6SMatthew McClintock /* These are used when DDR doesn't use SPD. */ 197f45210d6SMatthew McClintock #define CONFIG_SYS_SDRAM_SIZE 2048 198f45210d6SMatthew McClintock #define CONFIG_SYS_SDRAM_SIZE_LAW LAW_SIZE_2G 199f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CS0_BNDS 0x0000003F 200f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CS0_CONFIG 0x80014202 201f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CS1_BNDS 0x0040007F 202f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CS1_CONFIG 0x80014202 203f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_3 0x00010000 204f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_0 0x40110104 205f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_1 0x5c5bd746 206f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_2 0x0fa8d4ca 207f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_MODE_1 0x00441221 208f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_MODE_2 0x00000000 209f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_INTERVAL 0x0a280100 210f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_DATA_INIT 0xdeadbeef 211f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CLK_CTRL 0x02800000 212f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CONTROL 0xc7000008 213f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_CONTROL_2 0x24401041 214f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_4 0x00220001 215f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_TIMING_5 0x02401400 216f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_ZQ_CONTROL 0x89080600 217f45210d6SMatthew McClintock #define CONFIG_SYS_DDR_WRLVL_CONTROL 0x8675f608 218f45210d6SMatthew McClintock 219c59e1b4dSTimur Tabi /* 220c59e1b4dSTimur Tabi * Memory map 221c59e1b4dSTimur Tabi * 222c59e1b4dSTimur Tabi * 0x0000_0000 0x7fff_ffff DDR 2G Cacheable 223c59e1b4dSTimur Tabi * 0x8000_0000 0xdfff_ffff PCI Express Mem 1.5G non-cacheable 224c59e1b4dSTimur Tabi * 0xffc0_0000 0xffc2_ffff PCI IO range 192K non-cacheable 225c59e1b4dSTimur Tabi * 226c59e1b4dSTimur Tabi * Localbus cacheable (TBD) 227c59e1b4dSTimur Tabi * 0xXXXX_XXXX 0xXXXX_XXXX SRAM YZ M Cacheable 228c59e1b4dSTimur Tabi * 229c59e1b4dSTimur Tabi * Localbus non-cacheable 230c59e1b4dSTimur Tabi * 0xe000_0000 0xe80f_ffff Promjet/free 128M non-cacheable 231c59e1b4dSTimur Tabi * 0xe800_0000 0xefff_ffff FLASH 128M non-cacheable 232f45210d6SMatthew McClintock * 0xff80_0000 0xff80_7fff NAND 32K non-cacheable 233c59e1b4dSTimur Tabi * 0xffdf_0000 0xffdf_7fff PIXIS 32K non-cacheable TLB0 234c59e1b4dSTimur Tabi * 0xffd0_0000 0xffd0_3fff L1 for stack 16K Cacheable TLB0 235c59e1b4dSTimur Tabi * 0xffe0_0000 0xffef_ffff CCSR 1M non-cacheable 236c59e1b4dSTimur Tabi */ 237c59e1b4dSTimur Tabi 238c59e1b4dSTimur Tabi /* 239c59e1b4dSTimur Tabi * Local Bus Definitions 240c59e1b4dSTimur Tabi */ 241f45210d6SMatthew McClintock #define CONFIG_SYS_FLASH_BASE 0xe8000000 /* start of FLASH 128M */ 2429899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 243f45210d6SMatthew McClintock #define CONFIG_SYS_FLASH_BASE_PHYS 0xfe8000000ull 2449899ac19SJiang Yutang #else 2459899ac19SJiang Yutang #define CONFIG_SYS_FLASH_BASE_PHYS CONFIG_SYS_FLASH_BASE 2469899ac19SJiang Yutang #endif 247c59e1b4dSTimur Tabi 248c59e1b4dSTimur Tabi #define CONFIG_FLASH_BR_PRELIM \ 249f45210d6SMatthew McClintock (BR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | BR_PS_16 | BR_V) 250c59e1b4dSTimur Tabi #define CONFIG_FLASH_OR_PRELIM (OR_AM_128MB | 0xff7) 251c59e1b4dSTimur Tabi 252f45210d6SMatthew McClintock #ifdef CONFIG_NAND 253f45210d6SMatthew McClintock #define CONFIG_SYS_BR1_PRELIM CONFIG_FLASH_BR_PRELIM /* NOR Base Address */ 254f45210d6SMatthew McClintock #define CONFIG_SYS_OR1_PRELIM CONFIG_FLASH_OR_PRELIM /* NOR Options */ 255f45210d6SMatthew McClintock #else 256c59e1b4dSTimur Tabi #define CONFIG_SYS_BR0_PRELIM CONFIG_FLASH_BR_PRELIM /* NOR Base Address */ 257c59e1b4dSTimur Tabi #define CONFIG_SYS_OR0_PRELIM CONFIG_FLASH_OR_PRELIM /* NOR Options */ 258f45210d6SMatthew McClintock #endif 259c59e1b4dSTimur Tabi 260f45210d6SMatthew McClintock #define CONFIG_SYS_FLASH_BANKS_LIST {CONFIG_SYS_FLASH_BASE_PHYS} 261c59e1b4dSTimur Tabi #define CONFIG_SYS_FLASH_QUIET_TEST 262c59e1b4dSTimur Tabi #define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */ 263c59e1b4dSTimur Tabi 264f45210d6SMatthew McClintock #define CONFIG_SYS_MAX_FLASH_BANKS 1 265c59e1b4dSTimur Tabi #define CONFIG_SYS_MAX_FLASH_SECT 1024 266c59e1b4dSTimur Tabi 267f45210d6SMatthew McClintock #ifndef CONFIG_SYS_MONITOR_BASE 268f45210d6SMatthew McClintock #ifdef CONFIG_SPL_BUILD 269f45210d6SMatthew McClintock #define CONFIG_SYS_MONITOR_BASE CONFIG_SPL_TEXT_BASE 270f45210d6SMatthew McClintock #else 27114d0a02aSWolfgang Denk #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE /* start of monitor */ 272f45210d6SMatthew McClintock #endif 273f45210d6SMatthew McClintock #endif 274c59e1b4dSTimur Tabi 275c59e1b4dSTimur Tabi #define CONFIG_FLASH_CFI_DRIVER 276c59e1b4dSTimur Tabi #define CONFIG_SYS_FLASH_CFI 277c59e1b4dSTimur Tabi #define CONFIG_SYS_FLASH_EMPTY_INFO 278c59e1b4dSTimur Tabi 279f45210d6SMatthew McClintock /* Nand Flash */ 280f45210d6SMatthew McClintock #if defined(CONFIG_NAND_FSL_ELBC) 281f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_BASE 0xff800000 282f45210d6SMatthew McClintock #ifdef CONFIG_PHYS_64BIT 283f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_BASE_PHYS 0xfff800000ull 284f45210d6SMatthew McClintock #else 285f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_BASE_PHYS CONFIG_SYS_NAND_BASE 286f45210d6SMatthew McClintock #endif 287f45210d6SMatthew McClintock 2885d97fe2aSYing Zhang #define CONFIG_SYS_NAND_BASE_LIST {CONFIG_SYS_NAND_BASE} 289f45210d6SMatthew McClintock #define CONFIG_SYS_MAX_NAND_DEVICE 1 290f45210d6SMatthew McClintock #define CONFIG_CMD_NAND 1 291f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_BLOCK_SIZE (256 * 1024) 292f45210d6SMatthew McClintock #define CONFIG_ELBC_NAND_SPL_STATIC_PGSIZE 293f45210d6SMatthew McClintock 294f45210d6SMatthew McClintock /* NAND flash config */ 295f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_BR_PRELIM (BR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \ 296f45210d6SMatthew McClintock | (2<<BR_DECC_SHIFT) /* Use HW ECC */ \ 297f45210d6SMatthew McClintock | BR_PS_8 /* Port Size = 8 bit */ \ 298f45210d6SMatthew McClintock | BR_MS_FCM /* MSEL = FCM */ \ 299f45210d6SMatthew McClintock | BR_V) /* valid */ 300f45210d6SMatthew McClintock #define CONFIG_SYS_NAND_OR_PRELIM (OR_AM_32KB /* length 256K */ \ 301f45210d6SMatthew McClintock | OR_FCM_PGS /* Large Page*/ \ 302f45210d6SMatthew McClintock | OR_FCM_CSCT \ 303f45210d6SMatthew McClintock | OR_FCM_CST \ 304f45210d6SMatthew McClintock | OR_FCM_CHT \ 305f45210d6SMatthew McClintock | OR_FCM_SCY_1 \ 306f45210d6SMatthew McClintock | OR_FCM_TRLX \ 307f45210d6SMatthew McClintock | OR_FCM_EHTR) 308f45210d6SMatthew McClintock #ifdef CONFIG_NAND 309f45210d6SMatthew McClintock #define CONFIG_SYS_BR0_PRELIM CONFIG_SYS_NAND_BR_PRELIM /* NAND Base Address */ 310f45210d6SMatthew McClintock #define CONFIG_SYS_OR0_PRELIM CONFIG_SYS_NAND_OR_PRELIM /* NAND Options */ 311f45210d6SMatthew McClintock #else 312f45210d6SMatthew McClintock #define CONFIG_SYS_BR1_PRELIM CONFIG_SYS_NAND_BR_PRELIM /* NAND Base Address */ 313f45210d6SMatthew McClintock #define CONFIG_SYS_OR1_PRELIM CONFIG_SYS_NAND_OR_PRELIM /* NAND Options */ 314f45210d6SMatthew McClintock #endif 315f45210d6SMatthew McClintock 316f45210d6SMatthew McClintock #endif /* CONFIG_NAND_FSL_ELBC */ 317f45210d6SMatthew McClintock 318c59e1b4dSTimur Tabi #define CONFIG_BOARD_EARLY_INIT_F 319c59e1b4dSTimur Tabi #define CONFIG_BOARD_EARLY_INIT_R 320c59e1b4dSTimur Tabi #define CONFIG_MISC_INIT_R 321a2d12f88STimur Tabi #define CONFIG_HWCONFIG 322c59e1b4dSTimur Tabi 323c59e1b4dSTimur Tabi #define CONFIG_FSL_NGPIXIS 324c59e1b4dSTimur Tabi #define PIXIS_BASE 0xffdf0000 /* PIXIS registers */ 3259899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 326c59e1b4dSTimur Tabi #define PIXIS_BASE_PHYS 0xfffdf0000ull 3279899ac19SJiang Yutang #else 3289899ac19SJiang Yutang #define PIXIS_BASE_PHYS PIXIS_BASE 3299899ac19SJiang Yutang #endif 330c59e1b4dSTimur Tabi 331c59e1b4dSTimur Tabi #define CONFIG_SYS_BR2_PRELIM (BR_PHYS_ADDR(PIXIS_BASE_PHYS) | BR_PS_8 | BR_V) 332c59e1b4dSTimur Tabi #define CONFIG_SYS_OR2_PRELIM (OR_AM_32KB | 0x6ff7) 333c59e1b4dSTimur Tabi 334c59e1b4dSTimur Tabi #define PIXIS_LBMAP_SWITCH 7 3352906845aSYork Sun #define PIXIS_LBMAP_MASK 0xF0 336c59e1b4dSTimur Tabi #define PIXIS_LBMAP_ALTBANK 0x20 337f45210d6SMatthew McClintock #define PIXIS_SPD 0x07 338f45210d6SMatthew McClintock #define PIXIS_SPD_SYSCLK_MASK 0x07 3399b6e9d1cSJiang Yutang #define PIXIS_ELBC_SPI_MASK 0xc0 3409b6e9d1cSJiang Yutang #define PIXIS_SPI 0x80 341c59e1b4dSTimur Tabi 342c59e1b4dSTimur Tabi #define CONFIG_SYS_INIT_RAM_LOCK 343c59e1b4dSTimur Tabi #define CONFIG_SYS_INIT_RAM_ADDR 0xffd00000 /* Initial L1 address */ 344553f0982SWolfgang Denk #define CONFIG_SYS_INIT_RAM_SIZE 0x00004000 /* Size of used area in RAM */ 345c59e1b4dSTimur Tabi 346c59e1b4dSTimur Tabi #define CONFIG_SYS_GBL_DATA_OFFSET \ 34725ddd1fbSWolfgang Denk (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 348c59e1b4dSTimur Tabi #define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET 349c59e1b4dSTimur Tabi 3509307cbabSPrabhakar Kushwaha #define CONFIG_SYS_MONITOR_LEN (768 * 1024) 35107b5edc2SJerry Huang #define CONFIG_SYS_MALLOC_LEN (10 * 1024 * 1024) 352c59e1b4dSTimur Tabi 353c59e1b4dSTimur Tabi /* 3547c8eea59SYing Zhang * Config the L2 Cache as L2 SRAM 3557c8eea59SYing Zhang */ 3567c8eea59SYing Zhang #if defined(CONFIG_SPL_BUILD) 357382ce7e9SYing Zhang #if defined(CONFIG_SDCARD) || defined(CONFIG_SPIFLASH) 3587c8eea59SYing Zhang #define CONFIG_SYS_INIT_L2_ADDR 0xf8f80000 3597c8eea59SYing Zhang #define CONFIG_SYS_INIT_L2_ADDR_PHYS CONFIG_SYS_INIT_L2_ADDR 3607c8eea59SYing Zhang #define CONFIG_SYS_L2_SIZE (256 << 10) 3617c8eea59SYing Zhang #define CONFIG_SYS_INIT_L2_END (CONFIG_SYS_INIT_L2_ADDR + CONFIG_SYS_L2_SIZE) 3627c8eea59SYing Zhang #define CONFIG_SPL_RELOC_TEXT_BASE 0xf8f81000 36327585bd3SYing Zhang #define CONFIG_SPL_RELOC_STACK (CONFIG_SYS_INIT_L2_ADDR + 116 * 1024) 3647c8eea59SYing Zhang #define CONFIG_SPL_RELOC_STACK_SIZE (32 << 10) 36527585bd3SYing Zhang #define CONFIG_SPL_RELOC_MALLOC_ADDR (CONFIG_SYS_INIT_L2_ADDR + 148 * 1024) 36627585bd3SYing Zhang #define CONFIG_SPL_RELOC_MALLOC_SIZE (108 << 10) 3677c8eea59SYing Zhang #define CONFIG_SPL_GD_ADDR (CONFIG_SYS_INIT_L2_ADDR + 112 * 1024) 3685d97fe2aSYing Zhang #elif defined(CONFIG_NAND) 3695d97fe2aSYing Zhang #ifdef CONFIG_TPL_BUILD 3705d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_ADDR 0xf8f80000 3715d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_ADDR_PHYS CONFIG_SYS_INIT_L2_ADDR 3725d97fe2aSYing Zhang #define CONFIG_SYS_L2_SIZE (256 << 10) 3735d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_END (CONFIG_SYS_INIT_L2_ADDR + CONFIG_SYS_L2_SIZE) 3745d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_TEXT_BASE 0xf8f81000 3755d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_STACK (CONFIG_SYS_INIT_L2_ADDR + 192 * 1024) 3765d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_MALLOC_ADDR (CONFIG_SYS_INIT_L2_ADDR + 208 * 1024) 3775d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_MALLOC_SIZE (48 << 10) 3785d97fe2aSYing Zhang #define CONFIG_SPL_GD_ADDR (CONFIG_SYS_INIT_L2_ADDR + 176 * 1024) 3795d97fe2aSYing Zhang #else 3805d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_ADDR 0xf8f80000 3815d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_ADDR_PHYS CONFIG_SYS_INIT_L2_ADDR 3825d97fe2aSYing Zhang #define CONFIG_SYS_L2_SIZE (256 << 10) 3835d97fe2aSYing Zhang #define CONFIG_SYS_INIT_L2_END (CONFIG_SYS_INIT_L2_ADDR + CONFIG_SYS_L2_SIZE) 3845d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_TEXT_BASE (CONFIG_SYS_INIT_L2_END - 0x2000) 3855d97fe2aSYing Zhang #define CONFIG_SPL_RELOC_STACK ((CONFIG_SYS_INIT_L2_END - 1) & ~0xF) 3865d97fe2aSYing Zhang #endif 3877c8eea59SYing Zhang #endif 3887c8eea59SYing Zhang #endif 3897c8eea59SYing Zhang 3907c8eea59SYing Zhang /* 391c59e1b4dSTimur Tabi * Serial Port 392c59e1b4dSTimur Tabi */ 393c59e1b4dSTimur Tabi #define CONFIG_CONS_INDEX 1 394c59e1b4dSTimur Tabi #define CONFIG_SYS_NS16550_SERIAL 395c59e1b4dSTimur Tabi #define CONFIG_SYS_NS16550_REG_SIZE 1 396c59e1b4dSTimur Tabi #define CONFIG_SYS_NS16550_CLK get_bus_freq(0) 3977c8eea59SYing Zhang #if defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_INIT_MINIMAL) 398f45210d6SMatthew McClintock #define CONFIG_NS16550_MIN_FUNCTIONS 399f45210d6SMatthew McClintock #endif 400c59e1b4dSTimur Tabi 401c59e1b4dSTimur Tabi #define CONFIG_SYS_BAUDRATE_TABLE \ 402c59e1b4dSTimur Tabi {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200} 403c59e1b4dSTimur Tabi 404c59e1b4dSTimur Tabi #define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_CCSRBAR+0x4500) 405c59e1b4dSTimur Tabi #define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_CCSRBAR+0x4600) 406c59e1b4dSTimur Tabi 407c59e1b4dSTimur Tabi /* Video */ 408ba8e76bdSTimur Tabi 409d5e01e49STimur Tabi #ifdef CONFIG_FSL_DIU_FB 410d5e01e49STimur Tabi #define CONFIG_SYS_DIU_ADDR (CONFIG_SYS_CCSRBAR + 0x10000) 411d5e01e49STimur Tabi #define CONFIG_VIDEO 412d5e01e49STimur Tabi #define CONFIG_CMD_BMP 413c59e1b4dSTimur Tabi #define CONFIG_CFB_CONSOLE 4147d3053fbSTimur Tabi #define CONFIG_VIDEO_SW_CURSOR 415c59e1b4dSTimur Tabi #define CONFIG_VGA_AS_SINGLE_DEVICE 416d5e01e49STimur Tabi #define CONFIG_VIDEO_LOGO 417d5e01e49STimur Tabi #define CONFIG_VIDEO_BMP_LOGO 41855b05237STimur Tabi #define CONFIG_CFI_FLASH_USE_WEAK_ACCESSORS 41955b05237STimur Tabi /* 42055b05237STimur Tabi * With CONFIG_CFI_FLASH_USE_WEAK_ACCESSORS, flash I/O is really slow, so 42155b05237STimur Tabi * disable empty flash sector detection, which is I/O-intensive. 42255b05237STimur Tabi */ 42355b05237STimur Tabi #undef CONFIG_SYS_FLASH_EMPTY_INFO 424c59e1b4dSTimur Tabi #endif 425c59e1b4dSTimur Tabi 426ba8e76bdSTimur Tabi #ifndef CONFIG_FSL_DIU_FB 427218a758fSJiang Yutang #endif 428218a758fSJiang Yutang 429218a758fSJiang Yutang #ifdef CONFIG_ATI 430218a758fSJiang Yutang #define VIDEO_IO_OFFSET CONFIG_SYS_PCIE1_IO_VIRT 431218a758fSJiang Yutang #define CONFIG_VIDEO 432218a758fSJiang Yutang #define CONFIG_BIOSEMU 433218a758fSJiang Yutang #define CONFIG_VIDEO_SW_CURSOR 434218a758fSJiang Yutang #define CONFIG_ATI_RADEON_FB 435218a758fSJiang Yutang #define CONFIG_VIDEO_LOGO 436218a758fSJiang Yutang #define CONFIG_SYS_ISA_IO_BASE_ADDRESS VIDEO_IO_OFFSET 437218a758fSJiang Yutang #define CONFIG_CFB_CONSOLE 438218a758fSJiang Yutang #define CONFIG_VGA_AS_SINGLE_DEVICE 439218a758fSJiang Yutang #endif 440218a758fSJiang Yutang 441c59e1b4dSTimur Tabi /* I2C */ 44200f792e0SHeiko Schocher #define CONFIG_SYS_I2C 44300f792e0SHeiko Schocher #define CONFIG_SYS_I2C_FSL 44400f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_SPEED 400000 44500f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_SLAVE 0x7F 44600f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_OFFSET 0x3000 44700f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C2_SPEED 400000 44800f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C2_SLAVE 0x7F 44900f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C2_OFFSET 0x3100 450c59e1b4dSTimur Tabi #define CONFIG_SYS_I2C_NOPROBES {{0, 0x29}} 451c59e1b4dSTimur Tabi 452c59e1b4dSTimur Tabi /* 453c59e1b4dSTimur Tabi * I2C2 EEPROM 454c59e1b4dSTimur Tabi */ 455c59e1b4dSTimur Tabi #define CONFIG_ID_EEPROM 456c59e1b4dSTimur Tabi #define CONFIG_SYS_I2C_EEPROM_NXID 457c59e1b4dSTimur Tabi #define CONFIG_SYS_I2C_EEPROM_ADDR 0x57 458c59e1b4dSTimur Tabi #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1 459c59e1b4dSTimur Tabi #define CONFIG_SYS_EEPROM_BUS_NUM 1 460c59e1b4dSTimur Tabi 461c59e1b4dSTimur Tabi /* 4629b6e9d1cSJiang Yutang * eSPI - Enhanced SPI 4639b6e9d1cSJiang Yutang */ 4649b6e9d1cSJiang Yutang 4659b6e9d1cSJiang Yutang #define CONFIG_HARD_SPI 4669b6e9d1cSJiang Yutang 4679b6e9d1cSJiang Yutang #define CONFIG_SF_DEFAULT_SPEED 10000000 4689b6e9d1cSJiang Yutang #define CONFIG_SF_DEFAULT_MODE 0 4699b6e9d1cSJiang Yutang 4709b6e9d1cSJiang Yutang /* 471c59e1b4dSTimur Tabi * General PCI 472c59e1b4dSTimur Tabi * Memory space is mapped 1-1, but I/O space must start from 0. 473c59e1b4dSTimur Tabi */ 474c59e1b4dSTimur Tabi 475c59e1b4dSTimur Tabi /* controller 1, Slot 2, tgtid 1, Base address a000 */ 476c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_MEM_VIRT 0xc0000000 4779899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 478c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_MEM_BUS 0xe0000000 479c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_MEM_PHYS 0xc40000000ull 4809899ac19SJiang Yutang #else 4819899ac19SJiang Yutang #define CONFIG_SYS_PCIE1_MEM_BUS 0xc0000000 4829899ac19SJiang Yutang #define CONFIG_SYS_PCIE1_MEM_PHYS 0xc0000000 4839899ac19SJiang Yutang #endif 484c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_MEM_SIZE 0x20000000 /* 512M */ 485c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_IO_VIRT 0xffc20000 486c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_IO_BUS 0x00000000 4879899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 488c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_IO_PHYS 0xfffc20000ull 4899899ac19SJiang Yutang #else 4909899ac19SJiang Yutang #define CONFIG_SYS_PCIE1_IO_PHYS 0xffc20000 4919899ac19SJiang Yutang #endif 492c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE1_IO_SIZE 0x00010000 /* 64k */ 493c59e1b4dSTimur Tabi 494c59e1b4dSTimur Tabi /* controller 2, direct to uli, tgtid 2, Base address 9000 */ 495c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_MEM_VIRT 0xa0000000 4969899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 497c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_MEM_BUS 0xe0000000 498c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_MEM_PHYS 0xc20000000ull 4999899ac19SJiang Yutang #else 5009899ac19SJiang Yutang #define CONFIG_SYS_PCIE2_MEM_BUS 0xa0000000 5019899ac19SJiang Yutang #define CONFIG_SYS_PCIE2_MEM_PHYS 0xa0000000 5029899ac19SJiang Yutang #endif 503c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_MEM_SIZE 0x20000000 /* 512M */ 504c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_IO_VIRT 0xffc10000 505c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_IO_BUS 0x00000000 5069899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 507c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_IO_PHYS 0xfffc10000ull 5089899ac19SJiang Yutang #else 5099899ac19SJiang Yutang #define CONFIG_SYS_PCIE2_IO_PHYS 0xffc10000 5109899ac19SJiang Yutang #endif 511c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE2_IO_SIZE 0x00010000 /* 64k */ 512c59e1b4dSTimur Tabi 513c59e1b4dSTimur Tabi /* controller 3, Slot 1, tgtid 3, Base address b000 */ 514c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_MEM_VIRT 0x80000000 5159899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 516c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_MEM_BUS 0xe0000000 517c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_MEM_PHYS 0xc00000000ull 5189899ac19SJiang Yutang #else 5199899ac19SJiang Yutang #define CONFIG_SYS_PCIE3_MEM_BUS 0x80000000 5209899ac19SJiang Yutang #define CONFIG_SYS_PCIE3_MEM_PHYS 0x80000000 5219899ac19SJiang Yutang #endif 522c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_MEM_SIZE 0x20000000 /* 512M */ 523c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_IO_VIRT 0xffc00000 524c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_IO_BUS 0x00000000 5259899ac19SJiang Yutang #ifdef CONFIG_PHYS_64BIT 526c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_IO_PHYS 0xfffc00000ull 5279899ac19SJiang Yutang #else 5289899ac19SJiang Yutang #define CONFIG_SYS_PCIE3_IO_PHYS 0xffc00000 5299899ac19SJiang Yutang #endif 530c59e1b4dSTimur Tabi #define CONFIG_SYS_PCIE3_IO_SIZE 0x00010000 /* 64k */ 531c59e1b4dSTimur Tabi 532c59e1b4dSTimur Tabi #ifdef CONFIG_PCI 533842033e6SGabor Juhos #define CONFIG_PCI_INDIRECT_BRIDGE 534c59e1b4dSTimur Tabi #define CONFIG_PCI_PNP /* do pci plug-and-play */ 535c59e1b4dSTimur Tabi #define CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */ 536c59e1b4dSTimur Tabi #endif 537c59e1b4dSTimur Tabi 538c59e1b4dSTimur Tabi /* SATA */ 539c59e1b4dSTimur Tabi #define CONFIG_LIBATA 540c59e1b4dSTimur Tabi #define CONFIG_FSL_SATA 5419760b274SZang Roy-R61911 #define CONFIG_FSL_SATA_V2 542c59e1b4dSTimur Tabi 543c59e1b4dSTimur Tabi #define CONFIG_SYS_SATA_MAX_DEVICE 2 544c59e1b4dSTimur Tabi #define CONFIG_SATA1 545c59e1b4dSTimur Tabi #define CONFIG_SYS_SATA1 CONFIG_SYS_MPC85xx_SATA1_ADDR 546c59e1b4dSTimur Tabi #define CONFIG_SYS_SATA1_FLAGS FLAGS_DMA 547c59e1b4dSTimur Tabi #define CONFIG_SATA2 548c59e1b4dSTimur Tabi #define CONFIG_SYS_SATA2 CONFIG_SYS_MPC85xx_SATA2_ADDR 549c59e1b4dSTimur Tabi #define CONFIG_SYS_SATA2_FLAGS FLAGS_DMA 550c59e1b4dSTimur Tabi 551c59e1b4dSTimur Tabi #ifdef CONFIG_FSL_SATA 552c59e1b4dSTimur Tabi #define CONFIG_LBA48 553c59e1b4dSTimur Tabi #define CONFIG_CMD_SATA 554c59e1b4dSTimur Tabi #define CONFIG_DOS_PARTITION 555c59e1b4dSTimur Tabi #endif 556c59e1b4dSTimur Tabi 557c59e1b4dSTimur Tabi #define CONFIG_MMC 558c59e1b4dSTimur Tabi #ifdef CONFIG_MMC 559c59e1b4dSTimur Tabi #define CONFIG_FSL_ESDHC 560c59e1b4dSTimur Tabi #define CONFIG_GENERIC_MMC 561c59e1b4dSTimur Tabi #define CONFIG_SYS_FSL_ESDHC_ADDR CONFIG_SYS_MPC85xx_ESDHC_ADDR 562c59e1b4dSTimur Tabi #endif 563c59e1b4dSTimur Tabi 564c59e1b4dSTimur Tabi #if defined(CONFIG_MMC) || defined(CONFIG_USB_EHCI) 565c59e1b4dSTimur Tabi #define CONFIG_DOS_PARTITION 566c59e1b4dSTimur Tabi #endif 567c59e1b4dSTimur Tabi 568c59e1b4dSTimur Tabi #define CONFIG_TSEC_ENET 569c59e1b4dSTimur Tabi #ifdef CONFIG_TSEC_ENET 570c59e1b4dSTimur Tabi 571c59e1b4dSTimur Tabi #define CONFIG_TSECV2 572c59e1b4dSTimur Tabi 573c59e1b4dSTimur Tabi #define CONFIG_MII /* MII PHY management */ 574c59e1b4dSTimur Tabi #define CONFIG_TSEC1 1 575c59e1b4dSTimur Tabi #define CONFIG_TSEC1_NAME "eTSEC1" 576c59e1b4dSTimur Tabi #define CONFIG_TSEC2 1 577c59e1b4dSTimur Tabi #define CONFIG_TSEC2_NAME "eTSEC2" 578c59e1b4dSTimur Tabi 579c59e1b4dSTimur Tabi #define TSEC1_PHY_ADDR 1 580c59e1b4dSTimur Tabi #define TSEC2_PHY_ADDR 2 581c59e1b4dSTimur Tabi 582c59e1b4dSTimur Tabi #define TSEC1_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 583c59e1b4dSTimur Tabi #define TSEC2_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 584c59e1b4dSTimur Tabi 585c59e1b4dSTimur Tabi #define TSEC1_PHYIDX 0 586c59e1b4dSTimur Tabi #define TSEC2_PHYIDX 0 587c59e1b4dSTimur Tabi 588c59e1b4dSTimur Tabi #define CONFIG_ETHPRIME "eTSEC1" 589c59e1b4dSTimur Tabi 590c59e1b4dSTimur Tabi #define CONFIG_PHY_GIGE /* Include GbE speed/duplex detection */ 591c59e1b4dSTimur Tabi #endif 592c59e1b4dSTimur Tabi 593c59e1b4dSTimur Tabi /* 59494b383e7SYangbo Lu * Dynamic MTD Partition support with mtdparts 59594b383e7SYangbo Lu */ 59694b383e7SYangbo Lu #define CONFIG_MTD_DEVICE 59794b383e7SYangbo Lu #define CONFIG_MTD_PARTITIONS 59894b383e7SYangbo Lu #define CONFIG_CMD_MTDPARTS 59994b383e7SYangbo Lu #define CONFIG_FLASH_CFI_MTD 60094b383e7SYangbo Lu #ifdef CONFIG_PHYS_64BIT 60194b383e7SYangbo Lu #define MTDIDS_DEFAULT "nor0=fe8000000.nor" 60294b383e7SYangbo Lu #define MTDPARTS_DEFAULT "mtdparts=fe8000000.nor:48m(ramdisk)," \ 60394b383e7SYangbo Lu "14m(diagnostic),2m(dink),6m(kernel),58112k(fs)," \ 60494b383e7SYangbo Lu "512k(dtb),768k(u-boot)" 60594b383e7SYangbo Lu #else 60694b383e7SYangbo Lu #define MTDIDS_DEFAULT "nor0=e8000000.nor" 60794b383e7SYangbo Lu #define MTDPARTS_DEFAULT "mtdparts=e8000000.nor:48m(ramdisk)," \ 60894b383e7SYangbo Lu "14m(diagnostic),2m(dink),6m(kernel),58112k(fs)," \ 60994b383e7SYangbo Lu "512k(dtb),768k(u-boot)" 61094b383e7SYangbo Lu #endif 61194b383e7SYangbo Lu 61294b383e7SYangbo Lu /* 613c59e1b4dSTimur Tabi * Environment 614c59e1b4dSTimur Tabi */ 615382ce7e9SYing Zhang #ifdef CONFIG_SPIFLASH 616af253608SMatthew McClintock #define CONFIG_ENV_IS_IN_SPI_FLASH 617af253608SMatthew McClintock #define CONFIG_ENV_SPI_BUS 0 618af253608SMatthew McClintock #define CONFIG_ENV_SPI_CS 0 619af253608SMatthew McClintock #define CONFIG_ENV_SPI_MAX_HZ 10000000 620af253608SMatthew McClintock #define CONFIG_ENV_SPI_MODE 0 621af253608SMatthew McClintock #define CONFIG_ENV_SIZE 0x2000 /* 8KB */ 622af253608SMatthew McClintock #define CONFIG_ENV_OFFSET 0x100000 /* 1MB */ 623af253608SMatthew McClintock #define CONFIG_ENV_SECT_SIZE 0x10000 6247c8eea59SYing Zhang #elif defined(CONFIG_SDCARD) 625af253608SMatthew McClintock #define CONFIG_ENV_IS_IN_MMC 6267c8eea59SYing Zhang #define CONFIG_FSL_FIXED_MMC_LOCATION 627c59e1b4dSTimur Tabi #define CONFIG_ENV_SIZE 0x2000 628af253608SMatthew McClintock #define CONFIG_SYS_MMC_ENV_DEV 0 629f45210d6SMatthew McClintock #elif defined(CONFIG_NAND) 6305d97fe2aSYing Zhang #ifdef CONFIG_TPL_BUILD 6315d97fe2aSYing Zhang #define CONFIG_ENV_SIZE 0x2000 6325d97fe2aSYing Zhang #define CONFIG_ENV_ADDR (CONFIG_SYS_INIT_L2_ADDR + (160 << 10)) 6335d97fe2aSYing Zhang #else 634af253608SMatthew McClintock #define CONFIG_ENV_SIZE CONFIG_SYS_NAND_BLOCK_SIZE 6355d97fe2aSYing Zhang #endif 6365d97fe2aSYing Zhang #define CONFIG_ENV_IS_IN_NAND 6375d97fe2aSYing Zhang #define CONFIG_ENV_OFFSET (1024 * 1024) 638af253608SMatthew McClintock #define CONFIG_ENV_RANGE (3 * CONFIG_ENV_SIZE) 639f45210d6SMatthew McClintock #elif defined(CONFIG_SYS_RAMBOOT) 640af253608SMatthew McClintock #define CONFIG_ENV_IS_NOWHERE /* Store ENV in memory only */ 641af253608SMatthew McClintock #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - 0x1000) 642af253608SMatthew McClintock #define CONFIG_ENV_SIZE 0x2000 643af253608SMatthew McClintock #else 644af253608SMatthew McClintock #define CONFIG_ENV_IS_IN_FLASH 645af253608SMatthew McClintock #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE) 646af253608SMatthew McClintock #define CONFIG_ENV_SIZE 0x2000 647af253608SMatthew McClintock #define CONFIG_ENV_SECT_SIZE 0x20000 /* 128K (one sector) */ 648af253608SMatthew McClintock #endif 649c59e1b4dSTimur Tabi 650c59e1b4dSTimur Tabi #define CONFIG_LOADS_ECHO 651c59e1b4dSTimur Tabi #define CONFIG_SYS_LOADS_BAUD_CHANGE 652c59e1b4dSTimur Tabi 653c59e1b4dSTimur Tabi /* 654c59e1b4dSTimur Tabi * Command line configuration. 655c59e1b4dSTimur Tabi */ 65679ee3448SKumar Gala #define CONFIG_CMD_ERRATA 657c59e1b4dSTimur Tabi #define CONFIG_CMD_IRQ 658b8339e2bSMatthew McClintock #define CONFIG_CMD_REGINFO 659c59e1b4dSTimur Tabi 660c59e1b4dSTimur Tabi #ifdef CONFIG_PCI 661c59e1b4dSTimur Tabi #define CONFIG_CMD_PCI 662c59e1b4dSTimur Tabi #endif 663c59e1b4dSTimur Tabi 664c59e1b4dSTimur Tabi /* 665c59e1b4dSTimur Tabi * USB 666c59e1b4dSTimur Tabi */ 6673d7506faSramneek mehresh #define CONFIG_HAS_FSL_DR_USB 6683d7506faSramneek mehresh #ifdef CONFIG_HAS_FSL_DR_USB 669c59e1b4dSTimur Tabi #define CONFIG_USB_EHCI 670c59e1b4dSTimur Tabi 671c59e1b4dSTimur Tabi #ifdef CONFIG_USB_EHCI 672c59e1b4dSTimur Tabi #define CONFIG_EHCI_HCD_INIT_AFTER_RESET 673c59e1b4dSTimur Tabi #define CONFIG_USB_EHCI_FSL 674c59e1b4dSTimur Tabi #define CONFIG_USB_STORAGE 675c59e1b4dSTimur Tabi #endif 6763d7506faSramneek mehresh #endif 677c59e1b4dSTimur Tabi 678c59e1b4dSTimur Tabi /* 679c59e1b4dSTimur Tabi * Miscellaneous configurable options 680c59e1b4dSTimur Tabi */ 681c59e1b4dSTimur Tabi #define CONFIG_SYS_LONGHELP /* undef to save memory */ 682c59e1b4dSTimur Tabi #define CONFIG_CMDLINE_EDITING /* Command-line editing */ 6835be58f5fSKim Phillips #define CONFIG_AUTO_COMPLETE /* add autocompletion support */ 684c59e1b4dSTimur Tabi #define CONFIG_SYS_LOAD_ADDR 0x2000000 /* default load address */ 685c59e1b4dSTimur Tabi #ifdef CONFIG_CMD_KGDB 686c59e1b4dSTimur Tabi #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ 687c59e1b4dSTimur Tabi #else 688c59e1b4dSTimur Tabi #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */ 689c59e1b4dSTimur Tabi #endif 690c59e1b4dSTimur Tabi /* Print Buffer Size */ 691c59e1b4dSTimur Tabi #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 692c59e1b4dSTimur Tabi #define CONFIG_SYS_MAXARGS 16 693c59e1b4dSTimur Tabi #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 694c59e1b4dSTimur Tabi 695c59e1b4dSTimur Tabi /* 696c59e1b4dSTimur Tabi * For booting Linux, the board info and command line data 697a832ac41SKumar Gala * have to be in the first 64 MB of memory, since this is 698c59e1b4dSTimur Tabi * the maximum mapped by the Linux kernel during initialization. 699c59e1b4dSTimur Tabi */ 700a832ac41SKumar Gala #define CONFIG_SYS_BOOTMAPSZ (64 << 20) /* Initial Memory map for Linux*/ 701a832ac41SKumar Gala #define CONFIG_SYS_BOOTM_LEN (64 << 20) /* Increase max gunzip size */ 702c59e1b4dSTimur Tabi 703c59e1b4dSTimur Tabi #ifdef CONFIG_CMD_KGDB 704c59e1b4dSTimur Tabi #define CONFIG_KGDB_BAUDRATE 230400 /* speed to run kgdb serial port */ 705c59e1b4dSTimur Tabi #endif 706c59e1b4dSTimur Tabi 707c59e1b4dSTimur Tabi /* 708c59e1b4dSTimur Tabi * Environment Configuration 709c59e1b4dSTimur Tabi */ 710c59e1b4dSTimur Tabi 711c59e1b4dSTimur Tabi #define CONFIG_HOSTNAME p1022ds 7128b3637c6SJoe Hershberger #define CONFIG_ROOTPATH "/opt/nfsroot" 713b3f44c21SJoe Hershberger #define CONFIG_BOOTFILE "uImage" 714c59e1b4dSTimur Tabi #define CONFIG_UBOOTPATH u-boot.bin /* U-Boot image on TFTP server */ 715c59e1b4dSTimur Tabi 716c59e1b4dSTimur Tabi #define CONFIG_LOADADDR 1000000 717c59e1b4dSTimur Tabi 718c59e1b4dSTimur Tabi 719c59e1b4dSTimur Tabi #define CONFIG_BAUDRATE 115200 720c59e1b4dSTimur Tabi 721c59e1b4dSTimur Tabi #define CONFIG_EXTRA_ENV_SETTINGS \ 722c59e1b4dSTimur Tabi "netdev=eth0\0" \ 7235368c55dSMarek Vasut "uboot=" __stringify(CONFIG_UBOOTPATH) "\0" \ 7245368c55dSMarek Vasut "ubootaddr=" __stringify(CONFIG_SYS_TEXT_BASE) "\0" \ 72584e34b65STimur Tabi "tftpflash=tftpboot $loadaddr $uboot && " \ 72684e34b65STimur Tabi "protect off $ubootaddr +$filesize && " \ 72784e34b65STimur Tabi "erase $ubootaddr +$filesize && " \ 72884e34b65STimur Tabi "cp.b $loadaddr $ubootaddr $filesize && " \ 72984e34b65STimur Tabi "protect on $ubootaddr +$filesize && " \ 73084e34b65STimur Tabi "cmp.b $loadaddr $ubootaddr $filesize\0" \ 731c59e1b4dSTimur Tabi "consoledev=ttyS0\0" \ 732c59e1b4dSTimur Tabi "ramdiskaddr=2000000\0" \ 73384e34b65STimur Tabi "ramdiskfile=rootfs.ext2.gz.uboot\0" \ 734*b24a4f62SScott Wood "fdtaddr=1e00000\0" \ 735c59e1b4dSTimur Tabi "fdtfile=p1022ds.dtb\0" \ 736c59e1b4dSTimur Tabi "bdev=sda3\0" \ 737ba8e76bdSTimur Tabi "hwconfig=esdhc;audclk:12\0" 738c59e1b4dSTimur Tabi 739c59e1b4dSTimur Tabi #define CONFIG_HDBOOT \ 740c59e1b4dSTimur Tabi "setenv bootargs root=/dev/$bdev rw " \ 74184e34b65STimur Tabi "console=$consoledev,$baudrate $othbootargs $videobootargs;" \ 742c59e1b4dSTimur Tabi "tftp $loadaddr $bootfile;" \ 743c59e1b4dSTimur Tabi "tftp $fdtaddr $fdtfile;" \ 744c59e1b4dSTimur Tabi "bootm $loadaddr - $fdtaddr" 745c59e1b4dSTimur Tabi 746c59e1b4dSTimur Tabi #define CONFIG_NFSBOOTCOMMAND \ 747c59e1b4dSTimur Tabi "setenv bootargs root=/dev/nfs rw " \ 748c59e1b4dSTimur Tabi "nfsroot=$serverip:$rootpath " \ 749c59e1b4dSTimur Tabi "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:$netdev:off " \ 75084e34b65STimur Tabi "console=$consoledev,$baudrate $othbootargs $videobootargs;" \ 751c59e1b4dSTimur Tabi "tftp $loadaddr $bootfile;" \ 752c59e1b4dSTimur Tabi "tftp $fdtaddr $fdtfile;" \ 753c59e1b4dSTimur Tabi "bootm $loadaddr - $fdtaddr" 754c59e1b4dSTimur Tabi 755c59e1b4dSTimur Tabi #define CONFIG_RAMBOOTCOMMAND \ 756c59e1b4dSTimur Tabi "setenv bootargs root=/dev/ram rw " \ 75784e34b65STimur Tabi "console=$consoledev,$baudrate $othbootargs $videobootargs;" \ 758c59e1b4dSTimur Tabi "tftp $ramdiskaddr $ramdiskfile;" \ 759c59e1b4dSTimur Tabi "tftp $loadaddr $bootfile;" \ 760c59e1b4dSTimur Tabi "tftp $fdtaddr $fdtfile;" \ 761c59e1b4dSTimur Tabi "bootm $loadaddr $ramdiskaddr $fdtaddr" 762c59e1b4dSTimur Tabi 763c59e1b4dSTimur Tabi #define CONFIG_BOOTCOMMAND CONFIG_RAMBOOTCOMMAND 764c59e1b4dSTimur Tabi 765c59e1b4dSTimur Tabi #endif 766