15e918a98SKim Phillips /* 25e918a98SKim Phillips * Copyright (C) 2007 Freescale Semiconductor, Inc. 35e918a98SKim Phillips * Kevin Lam <kevin.lam@freescale.com> 45e918a98SKim Phillips * Joe D'Abbraccio <joe.d'abbraccio@freescale.com> 55e918a98SKim Phillips * 65e918a98SKim Phillips * This program is free software; you can redistribute it and/or 75e918a98SKim Phillips * modify it under the terms of the GNU General Public License as 85e918a98SKim Phillips * published by the Free Software Foundation; either version 2 of 95e918a98SKim Phillips * the License, or (at your option) any later version. 105e918a98SKim Phillips * 115e918a98SKim Phillips * This program is distributed in the hope that it will be useful, 125e918a98SKim Phillips * but WITHOUT ANY WARRANTY; without even the implied warranty of 135e918a98SKim Phillips * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 145e918a98SKim Phillips * GNU General Public License for more details. 155e918a98SKim Phillips * 165e918a98SKim Phillips * You should have received a copy of the GNU General Public License 175e918a98SKim Phillips * along with this program; if not, write to the Free Software 185e918a98SKim Phillips * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 195e918a98SKim Phillips * MA 02111-1307 USA 205e918a98SKim Phillips */ 215e918a98SKim Phillips 225e918a98SKim Phillips #ifndef __CONFIG_H 235e918a98SKim Phillips #define __CONFIG_H 245e918a98SKim Phillips 255e918a98SKim Phillips /* 265e918a98SKim Phillips * High Level Configuration Options 275e918a98SKim Phillips */ 285e918a98SKim Phillips #define CONFIG_E300 1 /* E300 family */ 292c7920afSPeter Tyser #define CONFIG_MPC83xx 1 /* MPC83xx family */ 302c7920afSPeter Tyser #define CONFIG_MPC837x 1 /* MPC837x CPU specific */ 315e918a98SKim Phillips #define CONFIG_MPC837XERDB 1 325e918a98SKim Phillips 332ae18241SWolfgang Denk #define CONFIG_SYS_TEXT_BASE 0xFE000000 342ae18241SWolfgang Denk 355e918a98SKim Phillips #define CONFIG_PCI 1 365e918a98SKim Phillips 372bd7460eSAnton Vorontsov #define CONFIG_BOARD_EARLY_INIT_F 3889c7784eSTimur Tabi #define CONFIG_MISC_INIT_R 39c9646ed7SAnton Vorontsov #define CONFIG_HWCONFIG 4089c7784eSTimur Tabi 4189c7784eSTimur Tabi /* 4289c7784eSTimur Tabi * On-board devices 4389c7784eSTimur Tabi */ 4489c7784eSTimur Tabi #define CONFIG_TSEC_ENET /* TSEC Ethernet support */ 4589c7784eSTimur Tabi #define CONFIG_VSC7385_ENET 4689c7784eSTimur Tabi 475e918a98SKim Phillips /* 485e918a98SKim Phillips * System Clock Setup 495e918a98SKim Phillips */ 505e918a98SKim Phillips #ifdef CONFIG_PCISLAVE 515e918a98SKim Phillips #define CONFIG_83XX_PCICLK 66666667 /* in HZ */ 525e918a98SKim Phillips #else 535e918a98SKim Phillips #define CONFIG_83XX_CLKIN 66666667 /* in Hz */ 54be9b56dfSKim Phillips #define CONFIG_PCIE 555e918a98SKim Phillips #endif 565e918a98SKim Phillips 575e918a98SKim Phillips #ifndef CONFIG_SYS_CLK_FREQ 585e918a98SKim Phillips #define CONFIG_SYS_CLK_FREQ CONFIG_83XX_CLKIN 595e918a98SKim Phillips #endif 605e918a98SKim Phillips 615e918a98SKim Phillips /* 625e918a98SKim Phillips * Hardware Reset Configuration Word 635e918a98SKim Phillips */ 646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HRCW_LOW (\ 655e918a98SKim Phillips HRCWL_LCL_BUS_TO_SCB_CLK_1X1 |\ 665e918a98SKim Phillips HRCWL_DDR_TO_SCB_CLK_1X1 |\ 675e918a98SKim Phillips HRCWL_SVCOD_DIV_2 |\ 685e918a98SKim Phillips HRCWL_CSB_TO_CLKIN_5X1 |\ 695e918a98SKim Phillips HRCWL_CORE_TO_CSB_2X1) 705e918a98SKim Phillips 715e918a98SKim Phillips #ifdef CONFIG_PCISLAVE 726d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HRCW_HIGH (\ 735e918a98SKim Phillips HRCWH_PCI_AGENT |\ 745e918a98SKim Phillips HRCWH_PCI1_ARBITER_DISABLE |\ 755e918a98SKim Phillips HRCWH_CORE_ENABLE |\ 765e918a98SKim Phillips HRCWH_FROM_0XFFF00100 |\ 775e918a98SKim Phillips HRCWH_BOOTSEQ_DISABLE |\ 785e918a98SKim Phillips HRCWH_SW_WATCHDOG_DISABLE |\ 795e918a98SKim Phillips HRCWH_ROM_LOC_LOCAL_16BIT |\ 805e918a98SKim Phillips HRCWH_RL_EXT_LEGACY |\ 815e918a98SKim Phillips HRCWH_TSEC1M_IN_RGMII |\ 825e918a98SKim Phillips HRCWH_TSEC2M_IN_RGMII |\ 835e918a98SKim Phillips HRCWH_BIG_ENDIAN |\ 845e918a98SKim Phillips HRCWH_LDP_CLEAR) 855e918a98SKim Phillips #else 866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HRCW_HIGH (\ 875e918a98SKim Phillips HRCWH_PCI_HOST |\ 885e918a98SKim Phillips HRCWH_PCI1_ARBITER_ENABLE |\ 895e918a98SKim Phillips HRCWH_CORE_ENABLE |\ 905e918a98SKim Phillips HRCWH_FROM_0X00000100 |\ 915e918a98SKim Phillips HRCWH_BOOTSEQ_DISABLE |\ 925e918a98SKim Phillips HRCWH_SW_WATCHDOG_DISABLE |\ 935e918a98SKim Phillips HRCWH_ROM_LOC_LOCAL_16BIT |\ 945e918a98SKim Phillips HRCWH_RL_EXT_LEGACY |\ 955e918a98SKim Phillips HRCWH_TSEC1M_IN_RGMII |\ 965e918a98SKim Phillips HRCWH_TSEC2M_IN_RGMII |\ 975e918a98SKim Phillips HRCWH_BIG_ENDIAN |\ 985e918a98SKim Phillips HRCWH_LDP_CLEAR) 995e918a98SKim Phillips #endif 1005e918a98SKim Phillips 1016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD /* System performance - define the value i.e. CONFIG_SYS_XXX 1025e918a98SKim Phillips */ 1035e918a98SKim Phillips 1045e918a98SKim Phillips /* Arbiter Configuration Register */ 1056d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ACR_PIPE_DEP 3 /* Arbiter pipeline depth (0-3) */ 1066d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ACR_RPTCNT 3 /* Arbiter repeat count (0-7) */ 1075e918a98SKim Phillips 1085e918a98SKim Phillips /* System Priority Control Regsiter */ 1096d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SPCR_TSECEP 3 /* eTSEC1&2 emergency priority (0-3) */ 1105e918a98SKim Phillips 1115e918a98SKim Phillips /* System Clock Configuration Register */ 1126d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SCCR_TSEC1CM 1 /* eTSEC1 clock mode (0-3) */ 1136d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SCCR_TSEC2CM 1 /* eTSEC2 clock mode (0-3) */ 1146d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SCCR_SATACM SCCR_SATACM_2 /* SATA1-4 clock mode (0-3) */ 1155e918a98SKim Phillips 1165e918a98SKim Phillips /* 1175e918a98SKim Phillips * System IO Config 1185e918a98SKim Phillips */ 1196d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SICRH 0x08200000 1206d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SICRL 0x00000000 1215e918a98SKim Phillips 1225e918a98SKim Phillips /* 1235e918a98SKim Phillips * Output Buffer Impedance 1245e918a98SKim Phillips */ 1256d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_OBIR 0x30100000 1265e918a98SKim Phillips 1275e918a98SKim Phillips /* 1285e918a98SKim Phillips * IMMR new address 1295e918a98SKim Phillips */ 1306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IMMR 0xE0000000 1315e918a98SKim Phillips 1325e918a98SKim Phillips /* 13389c7784eSTimur Tabi * Device configurations 13489c7784eSTimur Tabi */ 13589c7784eSTimur Tabi 13689c7784eSTimur Tabi /* Vitesse 7385 */ 13789c7784eSTimur Tabi 13889c7784eSTimur Tabi #ifdef CONFIG_VSC7385_ENET 13989c7784eSTimur Tabi 14089c7784eSTimur Tabi #define CONFIG_TSEC2 14189c7784eSTimur Tabi 14289c7784eSTimur Tabi /* The flash address and size of the VSC7385 firmware image */ 14389c7784eSTimur Tabi #define CONFIG_VSC7385_IMAGE 0xFE7FE000 14489c7784eSTimur Tabi #define CONFIG_VSC7385_IMAGE_SIZE 8192 14589c7784eSTimur Tabi 14689c7784eSTimur Tabi #endif 14789c7784eSTimur Tabi 14889c7784eSTimur Tabi /* 1495e918a98SKim Phillips * DDR Setup 1505e918a98SKim Phillips */ 1516d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_BASE 0x00000000 /* DDR is system memory */ 1526d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_BASE 1536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SDRAM_BASE CONFIG_SYS_DDR_BASE 1546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SDRAM_CLK_CNTL 0x03000000 1556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_83XX_DDR_USES_CS0 1565e918a98SKim Phillips 1576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDRCDR_VALUE (DDRCDR_DHC_EN | DDRCDR_ODT | DDRCDR_Q_DRN) 1585e918a98SKim Phillips 1595e918a98SKim Phillips #undef CONFIG_DDR_ECC /* support DDR ECC function */ 1605e918a98SKim Phillips #undef CONFIG_DDR_ECC_CMD /* Use DDR ECC user commands */ 1615e918a98SKim Phillips 1625e918a98SKim Phillips #undef CONFIG_NEVER_ASSERT_ODT_TO_CPU /* Never assert ODT to internal IOs */ 1635e918a98SKim Phillips 1645e918a98SKim Phillips /* 1655e918a98SKim Phillips * Manually set up DDR parameters 1665e918a98SKim Phillips */ 1676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SIZE 256 /* MB */ 1686d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_CS0_BNDS 0x0000000f 1692fef4020SJoe Hershberger #define CONFIG_SYS_DDR_CS0_CONFIG (CSCONFIG_EN \ 1702fef4020SJoe Hershberger | CSCONFIG_ODT_WR_ONLY_CURRENT \ 1712fef4020SJoe Hershberger | CSCONFIG_ROW_BIT_13 \ 1722fef4020SJoe Hershberger | CSCONFIG_COL_BIT_10) 1735e918a98SKim Phillips 1746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_TIMING_3 0x00000000 1756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_TIMING_0 ((0 << TIMING_CFG0_RWT_SHIFT) \ 1765e918a98SKim Phillips | (0 << TIMING_CFG0_WRT_SHIFT) \ 1775e918a98SKim Phillips | (0 << TIMING_CFG0_RRT_SHIFT) \ 1785e918a98SKim Phillips | (0 << TIMING_CFG0_WWT_SHIFT) \ 1795e918a98SKim Phillips | (2 << TIMING_CFG0_ACT_PD_EXIT_SHIFT) \ 1805e918a98SKim Phillips | (6 << TIMING_CFG0_PRE_PD_EXIT_SHIFT) \ 1815e918a98SKim Phillips | (8 << TIMING_CFG0_ODT_PD_EXIT_SHIFT) \ 1825e918a98SKim Phillips | (2 << TIMING_CFG0_MRS_CYC_SHIFT)) 1835e918a98SKim Phillips /* 0x00260802 */ /* DDR400 */ 1846d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_TIMING_1 ((3 << TIMING_CFG1_PRETOACT_SHIFT) \ 1855e918a98SKim Phillips | (9 << TIMING_CFG1_ACTTOPRE_SHIFT) \ 1865e918a98SKim Phillips | (3 << TIMING_CFG1_ACTTORW_SHIFT) \ 1875e918a98SKim Phillips | (7 << TIMING_CFG1_CASLAT_SHIFT) \ 1885e918a98SKim Phillips | (13 << TIMING_CFG1_REFREC_SHIFT) \ 1895e918a98SKim Phillips | (3 << TIMING_CFG1_WRREC_SHIFT) \ 1905e918a98SKim Phillips | (2 << TIMING_CFG1_ACTTOACT_SHIFT) \ 1915e918a98SKim Phillips | (2 << TIMING_CFG1_WRTORD_SHIFT)) 1925e918a98SKim Phillips /* 0x3937d322 */ 1932fef4020SJoe Hershberger #define CONFIG_SYS_DDR_TIMING_2 ((0 << TIMING_CFG2_ADD_LAT_SHIFT) \ 1942fef4020SJoe Hershberger | (5 << TIMING_CFG2_CPO_SHIFT) \ 1952fef4020SJoe Hershberger | (3 << TIMING_CFG2_WR_LAT_DELAY_SHIFT) \ 1962fef4020SJoe Hershberger | (2 << TIMING_CFG2_RD_TO_PRE_SHIFT) \ 1972fef4020SJoe Hershberger | (3 << TIMING_CFG2_WR_DATA_DELAY_SHIFT) \ 1982fef4020SJoe Hershberger | (3 << TIMING_CFG2_CKE_PLS_SHIFT) \ 1992fef4020SJoe Hershberger | (8 << TIMING_CFG2_FOUR_ACT_SHIFT)) 2002fef4020SJoe Hershberger /* 0x02984cc8 */ 2015e918a98SKim Phillips 2028eceeb7fSKim Phillips #define CONFIG_SYS_DDR_INTERVAL ((1024 << SDRAM_INTERVAL_REFINT_SHIFT) \ 2038eceeb7fSKim Phillips | (0 << SDRAM_INTERVAL_BSTOPRE_SHIFT)) 2045e918a98SKim Phillips /* 0x06090100 */ 2055e918a98SKim Phillips 2065e918a98SKim Phillips #if defined(CONFIG_DDR_2T_TIMING) 2076d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SDRAM_CFG (SDRAM_CFG_SREN \ 2082fef4020SJoe Hershberger | SDRAM_CFG_SDRAM_TYPE_DDR2 \ 2092fef4020SJoe Hershberger | SDRAM_CFG_32_BE \ 2102fef4020SJoe Hershberger | SDRAM_CFG_2T_EN) 2112fef4020SJoe Hershberger /* 0x43088000 */ 2125e918a98SKim Phillips #else 2136d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SDRAM_CFG (SDRAM_CFG_SREN \ 2142fef4020SJoe Hershberger | SDRAM_CFG_SDRAM_TYPE_DDR2) 2155e918a98SKim Phillips /* 0x43000000 */ 2165e918a98SKim Phillips #endif 2176d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_SDRAM_CFG2 0x00001000 /* 1 posted refresh */ 2188eceeb7fSKim Phillips #define CONFIG_SYS_DDR_MODE ((0x0406 << SDRAM_MODE_ESD_SHIFT) \ 2195e918a98SKim Phillips | (0x0442 << SDRAM_MODE_SD_SHIFT)) 2205e918a98SKim Phillips /* 0x04400442 */ /* DDR400 */ 2216d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DDR_MODE2 0x00000000 2225e918a98SKim Phillips 2235e918a98SKim Phillips /* 2245e918a98SKim Phillips * Memory test 2255e918a98SKim Phillips */ 2266d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #undef CONFIG_SYS_DRAM_TEST /* memory test, takes time */ 2276d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_START 0x00040000 /* memtest region */ 2286d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_END 0x0ef70010 2295e918a98SKim Phillips 2305e918a98SKim Phillips /* 2315e918a98SKim Phillips * The reserved memory 2325e918a98SKim Phillips */ 23314d0a02aSWolfgang Denk #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE /* start of monitor */ 2345e918a98SKim Phillips 2356d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if (CONFIG_SYS_MONITOR_BASE < CONFIG_SYS_FLASH_BASE) 2366d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_RAMBOOT 2375e918a98SKim Phillips #else 2386d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #undef CONFIG_SYS_RAMBOOT 2395e918a98SKim Phillips #endif 2405e918a98SKim Phillips 2414a9932a4SKim Phillips #define CONFIG_SYS_MONITOR_LEN (384 * 1024) /* Reserve 384 kB for Mon */ 2426d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MALLOC_LEN (512 * 1024) /* Reserved for malloc */ 2435e918a98SKim Phillips 2445e918a98SKim Phillips /* 2455e918a98SKim Phillips * Initial RAM Base Address Setup 2465e918a98SKim Phillips */ 2476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_RAM_LOCK 1 2486d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_RAM_ADDR 0xE6000000 /* Initial RAM address */ 249553f0982SWolfgang Denk #define CONFIG_SYS_INIT_RAM_SIZE 0x1000 /* Size of used area in RAM */ 2505afe9722SJoe Hershberger #define CONFIG_SYS_GBL_DATA_OFFSET \ 2515afe9722SJoe Hershberger (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 2525e918a98SKim Phillips 2535e918a98SKim Phillips /* 2545e918a98SKim Phillips * Local Bus Configuration & Clock Setup 2555e918a98SKim Phillips */ 256c7190f02SKim Phillips #define CONFIG_SYS_LCRR_DBYP LCRR_DBYP 257c7190f02SKim Phillips #define CONFIG_SYS_LCRR_CLKDIV LCRR_CLKDIV_8 2586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LBC_LBCR 0x00000000 2590914f483SBecky Bruce #define CONFIG_FSL_ELBC 1 2605e918a98SKim Phillips 2615e918a98SKim Phillips /* 2625e918a98SKim Phillips * FLASH on the Local Bus 2635e918a98SKim Phillips */ 2646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_CFI /* use the Common Flash Interface */ 26500b1883aSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_FLASH_CFI_DRIVER /* use the CFI driver */ 2666d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_BASE 0xFE000000 /* FLASH base address */ 2676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_SIZE 8 /* max FLASH size is 32M */ 2685e918a98SKim Phillips 2696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_PROTECTION 1 /* Use h/w Flash protection. */ 2706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_EMPTY_INFO /* display empty sectors */ 2716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE /* buffer up multiple bytes */ 2725e918a98SKim Phillips 2735afe9722SJoe Hershberger /* Window base at flash base */ 2745afe9722SJoe Hershberger #define CONFIG_SYS_LBLAWBAR0_PRELIM CONFIG_SYS_FLASH_BASE 2756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LBLAWAR0_PRELIM 0x80000016 /* 8 MB window size */ 2765e918a98SKim Phillips 2775afe9722SJoe Hershberger #define CONFIG_SYS_BR0_PRELIM (CONFIG_SYS_FLASH_BASE \ 278*7d6a0982SJoe Hershberger | BR_PS_16 /* 16 bit port */ \ 279*7d6a0982SJoe Hershberger | BR_MS_GPCM /* MSEL = GPCM */ \ 2805afe9722SJoe Hershberger | BR_V) /* valid */ 281*7d6a0982SJoe Hershberger #define CONFIG_SYS_OR0_PRELIM (MEG_TO_AM(CONFIG_SYS_FLASH_SIZE) \ 2825e918a98SKim Phillips | OR_GPCM_XACS \ 2835e918a98SKim Phillips | OR_GPCM_SCY_9 \ 284*7d6a0982SJoe Hershberger | OR_GPCM_EHTR_SET \ 2855e918a98SKim Phillips | OR_GPCM_EAD) 286*7d6a0982SJoe Hershberger /* 0xFF800191 */ 2875e918a98SKim Phillips 2886d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MAX_FLASH_BANKS 1 /* number of banks */ 2896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MAX_FLASH_SECT 256 /* max sectors per device */ 2905e918a98SKim Phillips 2916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #undef CONFIG_SYS_FLASH_CHECKSUM 2926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_ERASE_TOUT 60000 /* Flash Erase Timeout (ms) */ 2936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout (ms) */ 2945e918a98SKim Phillips 29546a3aeeaSAnton Vorontsov /* 29646a3aeeaSAnton Vorontsov * NAND Flash on the Local Bus 29746a3aeeaSAnton Vorontsov */ 298*7d6a0982SJoe Hershberger #define CONFIG_SYS_NAND_BASE 0xE0600000 2995afe9722SJoe Hershberger #define CONFIG_SYS_BR1_PRELIM (CONFIG_SYS_NAND_BASE \ 300*7d6a0982SJoe Hershberger | BR_DECC_CHK_GEN /* Use HW ECC */ \ 301*7d6a0982SJoe Hershberger | BR_PS_8 /* 8 bit port */ \ 302*7d6a0982SJoe Hershberger | BR_MS_FCM /* MSEL = FCM */ \ 3035afe9722SJoe Hershberger | BR_V) /* valid */ 304*7d6a0982SJoe Hershberger #define CONFIG_SYS_OR1_PRELIM (OR_AM_32KB \ 3055afe9722SJoe Hershberger | OR_FCM_CSCT \ 3065afe9722SJoe Hershberger | OR_FCM_CST \ 3075afe9722SJoe Hershberger | OR_FCM_CHT \ 3085afe9722SJoe Hershberger | OR_FCM_SCY_1 \ 3095afe9722SJoe Hershberger | OR_FCM_TRLX \ 3105afe9722SJoe Hershberger | OR_FCM_EHTR) 3116d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LBLAWBAR1_PRELIM CONFIG_SYS_NAND_BASE 312*7d6a0982SJoe Hershberger #define CONFIG_SYS_LBLAWAR1_PRELIM (LBLAWAR_EN | LBLAWAR_32KB) 31346a3aeeaSAnton Vorontsov 31489c7784eSTimur Tabi /* Vitesse 7385 */ 31589c7784eSTimur Tabi 3166d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_VSC7385_BASE 0xF0000000 3175e918a98SKim Phillips 31889c7784eSTimur Tabi #ifdef CONFIG_VSC7385_ENET 31989c7784eSTimur Tabi 320*7d6a0982SJoe Hershberger #define CONFIG_SYS_BR2_PRELIM (CONFIG_SYS_VSC7385_BASE \ 321*7d6a0982SJoe Hershberger | BR_PS_8 \ 322*7d6a0982SJoe Hershberger | BR_MS_GPCM \ 323*7d6a0982SJoe Hershberger | BR_V) 324*7d6a0982SJoe Hershberger /* 0xF0000801 */ 325*7d6a0982SJoe Hershberger #define CONFIG_SYS_OR2_PRELIM (OR_AM_128KB \ 326*7d6a0982SJoe Hershberger | OR_GPCM_CSNT \ 327*7d6a0982SJoe Hershberger | OR_GPCM_XACS \ 328*7d6a0982SJoe Hershberger | OR_GPCM_SCY_15 \ 329*7d6a0982SJoe Hershberger | OR_GPCM_SETA \ 330*7d6a0982SJoe Hershberger | OR_GPCM_TRLX_SET \ 331*7d6a0982SJoe Hershberger | OR_GPCM_EHTR_SET \ 332*7d6a0982SJoe Hershberger | OR_GPCM_EAD) 333*7d6a0982SJoe Hershberger /* 0xfffe09ff */ 334*7d6a0982SJoe Hershberger 3355afe9722SJoe Hershberger /* Access Base */ 3365afe9722SJoe Hershberger #define CONFIG_SYS_LBLAWBAR2_PRELIM CONFIG_SYS_VSC7385_BASE 337*7d6a0982SJoe Hershberger #define CONFIG_SYS_LBLAWAR2_PRELIM (LBLAWAR_EN | LBLAWAR_128KB) 3385e918a98SKim Phillips 33989c7784eSTimur Tabi #endif 34089c7784eSTimur Tabi 3415e918a98SKim Phillips /* 3425e918a98SKim Phillips * Serial Port 3435e918a98SKim Phillips */ 3445e918a98SKim Phillips #define CONFIG_CONS_INDEX 1 3456d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550 3466d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550_SERIAL 3476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550_REG_SIZE 1 3486d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550_CLK get_bus_freq(0) 3495e918a98SKim Phillips 3506d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_BAUDRATE_TABLE \ 3515e918a98SKim Phillips {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 115200} 3525e918a98SKim Phillips 3536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_IMMR+0x4500) 3546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_IMMR+0x4600) 3555e918a98SKim Phillips 3562bd7460eSAnton Vorontsov /* SERDES */ 3572bd7460eSAnton Vorontsov #define CONFIG_FSL_SERDES 3582bd7460eSAnton Vorontsov #define CONFIG_FSL_SERDES1 0xe3000 3592bd7460eSAnton Vorontsov #define CONFIG_FSL_SERDES2 0xe3100 3602bd7460eSAnton Vorontsov 3615e918a98SKim Phillips /* Use the HUSH parser */ 3626d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HUSH_PARSER 3636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_HUSH_PARSER 3646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PROMPT_HUSH_PS2 "> " 3655e918a98SKim Phillips #endif 3665e918a98SKim Phillips 3675e918a98SKim Phillips /* Pass open firmware flat tree */ 3685e918a98SKim Phillips #define CONFIG_OF_LIBFDT 1 3695e918a98SKim Phillips #define CONFIG_OF_BOARD_SETUP 1 370aabce7fbSAnton Vorontsov #define CONFIG_OF_STDOUT_VIA_ALIAS 1 3715e918a98SKim Phillips 3725e918a98SKim Phillips /* I2C */ 3735e918a98SKim Phillips #define CONFIG_HARD_I2C /* I2C with hardware support */ 3745e918a98SKim Phillips #undef CONFIG_SOFT_I2C /* I2C bit-banged */ 3755e918a98SKim Phillips #define CONFIG_FSL_I2C 3766d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_SPEED 400000 /* I2C speed and slave address */ 3776d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_SLAVE 0x7F 3786d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_NOPROBES {0x51} /* Don't probe these addrs */ 3796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_OFFSET 0x3000 3806d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C2_OFFSET 0x3100 3815e918a98SKim Phillips 3825e918a98SKim Phillips /* 3835e918a98SKim Phillips * Config on-board RTC 3845e918a98SKim Phillips */ 3855e918a98SKim Phillips #define CONFIG_RTC_DS1374 /* use ds1374 rtc via i2c */ 3866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_RTC_ADDR 0x68 /* at address 0x68 */ 3875e918a98SKim Phillips 3885e918a98SKim Phillips /* 3895e918a98SKim Phillips * General PCI 3905e918a98SKim Phillips * Addresses are mapped 1-1. 3915e918a98SKim Phillips */ 3926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_BASE 0x80000000 3936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_PHYS CONFIG_SYS_PCI_MEM_BASE 3946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_SIZE 0x10000000 /* 256M */ 3956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_BASE 0x90000000 3966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_PHYS CONFIG_SYS_PCI_MMIO_BASE 3976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_SIZE 0x10000000 /* 256M */ 3986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_BASE 0x00000000 3996d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_PHYS 0xE0300000 4006d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_SIZE 0x100000 /* 1M */ 4015e918a98SKim Phillips 4026d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_LOCAL CONFIG_SYS_SDRAM_BASE 4036d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_BUS 0x00000000 4046d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_SIZE 0x80000000 4055e918a98SKim Phillips 4067e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_BASE 0xA0000000 4077e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_CFG_BASE 0xA0000000 4087e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_CFG_SIZE 0x08000000 4097e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_BASE 0xA8000000 4107e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_PHYS 0xA8000000 4117e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_SIZE 0x10000000 4127e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_BASE 0x00000000 4137e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_PHYS 0xB8000000 4147e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_SIZE 0x00800000 4157e915580SAnton Vorontsov 4167e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_BASE 0xC0000000 4177e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_CFG_BASE 0xC0000000 4187e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_CFG_SIZE 0x08000000 4197e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_BASE 0xC8000000 4207e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_PHYS 0xC8000000 4217e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_SIZE 0x10000000 4227e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_BASE 0x00000000 4237e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_PHYS 0xD8000000 4247e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_SIZE 0x00800000 4257e915580SAnton Vorontsov 4265e918a98SKim Phillips #ifdef CONFIG_PCI 4275e918a98SKim Phillips #define CONFIG_PCI_PNP /* do pci plug-and-play */ 4285e918a98SKim Phillips 4295e918a98SKim Phillips #undef CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */ 4306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SUBSYS_VENDORID 0x1957 /* Freescale */ 4315e918a98SKim Phillips #endif /* CONFIG_PCI */ 4325e918a98SKim Phillips 4335e918a98SKim Phillips /* 4345e918a98SKim Phillips * TSEC 4355e918a98SKim Phillips */ 43689c7784eSTimur Tabi #ifdef CONFIG_TSEC_ENET 4375e918a98SKim Phillips 43889c7784eSTimur Tabi #define CONFIG_GMII /* MII PHY management */ 43989c7784eSTimur Tabi 44089c7784eSTimur Tabi #define CONFIG_TSEC1 44189c7784eSTimur Tabi 44289c7784eSTimur Tabi #ifdef CONFIG_TSEC1 44389c7784eSTimur Tabi #define CONFIG_HAS_ETH0 4445e918a98SKim Phillips #define CONFIG_TSEC1_NAME "TSEC0" 4456d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_TSEC1_OFFSET 0x24000 4465e918a98SKim Phillips #define TSEC1_PHY_ADDR 2 4475e918a98SKim Phillips #define TSEC1_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 4485e918a98SKim Phillips #define TSEC1_PHYIDX 0 44989c7784eSTimur Tabi #endif 4505e918a98SKim Phillips 45189c7784eSTimur Tabi #ifdef CONFIG_TSEC2 45289c7784eSTimur Tabi #define CONFIG_HAS_ETH1 45389c7784eSTimur Tabi #define CONFIG_TSEC2_NAME "TSEC1" 4546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_TSEC2_OFFSET 0x25000 45589c7784eSTimur Tabi #define TSEC2_PHY_ADDR 0x1c 45689c7784eSTimur Tabi #define TSEC2_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 45789c7784eSTimur Tabi #define TSEC2_PHYIDX 0 45889c7784eSTimur Tabi #endif 4595e918a98SKim Phillips 4605e918a98SKim Phillips /* Options are: TSEC[0-1] */ 4615e918a98SKim Phillips #define CONFIG_ETHPRIME "TSEC0" 4625e918a98SKim Phillips 46389c7784eSTimur Tabi #endif 46489c7784eSTimur Tabi 4655e918a98SKim Phillips /* 466730e7929SKim Phillips * SATA 467730e7929SKim Phillips */ 468730e7929SKim Phillips #define CONFIG_LIBATA 469730e7929SKim Phillips #define CONFIG_FSL_SATA 470730e7929SKim Phillips 4716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA_MAX_DEVICE 2 472730e7929SKim Phillips #define CONFIG_SATA1 4736d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1_OFFSET 0x18000 4746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1 (CONFIG_SYS_IMMR + CONFIG_SYS_SATA1_OFFSET) 4756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1_FLAGS FLAGS_DMA 476730e7929SKim Phillips #define CONFIG_SATA2 4776d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2_OFFSET 0x19000 4786d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2 (CONFIG_SYS_IMMR + CONFIG_SYS_SATA2_OFFSET) 4796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2_FLAGS FLAGS_DMA 480730e7929SKim Phillips 481730e7929SKim Phillips #ifdef CONFIG_FSL_SATA 482730e7929SKim Phillips #define CONFIG_LBA48 483730e7929SKim Phillips #define CONFIG_CMD_SATA 484730e7929SKim Phillips #define CONFIG_DOS_PARTITION 485730e7929SKim Phillips #define CONFIG_CMD_EXT2 486730e7929SKim Phillips #endif 487730e7929SKim Phillips 488730e7929SKim Phillips /* 4895e918a98SKim Phillips * Environment 4905e918a98SKim Phillips */ 4916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifndef CONFIG_SYS_RAMBOOT 4925a1aceb0SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_IS_IN_FLASH 1 4935afe9722SJoe Hershberger #define CONFIG_ENV_ADDR \ 4945afe9722SJoe Hershberger (CONFIG_SYS_MONITOR_BASE+CONFIG_SYS_MONITOR_LEN) 4950e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SECT_SIZE 0x10000 /* 64K (one sector) for env */ 4960e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SIZE 0x4000 4975e918a98SKim Phillips #else 4986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NO_FLASH 1 /* Flash is not usable now */ 49993f6d725SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_IS_NOWHERE 1 /* Store ENV in memory only */ 5006d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE-0x1000) 5010e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SIZE 0x2000 5025e918a98SKim Phillips #endif 5035e918a98SKim Phillips 5045e918a98SKim Phillips #define CONFIG_LOADS_ECHO 1 /* echo on for serial download */ 5056d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOADS_BAUD_CHANGE 1 /* allow baudrate change */ 5065e918a98SKim Phillips 5075e918a98SKim Phillips /* 5085e918a98SKim Phillips * BOOTP options 5095e918a98SKim Phillips */ 5105e918a98SKim Phillips #define CONFIG_BOOTP_BOOTFILESIZE 5115e918a98SKim Phillips #define CONFIG_BOOTP_BOOTPATH 5125e918a98SKim Phillips #define CONFIG_BOOTP_GATEWAY 5135e918a98SKim Phillips #define CONFIG_BOOTP_HOSTNAME 5145e918a98SKim Phillips 5155e918a98SKim Phillips 5165e918a98SKim Phillips /* 5175e918a98SKim Phillips * Command line configuration. 5185e918a98SKim Phillips */ 5195e918a98SKim Phillips #include <config_cmd_default.h> 5205e918a98SKim Phillips 5215e918a98SKim Phillips #define CONFIG_CMD_PING 5225e918a98SKim Phillips #define CONFIG_CMD_I2C 5235e918a98SKim Phillips #define CONFIG_CMD_MII 5245e918a98SKim Phillips #define CONFIG_CMD_DATE 5255e918a98SKim Phillips 5265e918a98SKim Phillips #if defined(CONFIG_PCI) 5275e918a98SKim Phillips #define CONFIG_CMD_PCI 5285e918a98SKim Phillips #endif 5295e918a98SKim Phillips 5306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_RAMBOOT) 531bdab39d3SMike Frysinger #undef CONFIG_CMD_SAVEENV 5325e918a98SKim Phillips #undef CONFIG_CMD_LOADS 5335e918a98SKim Phillips #endif 5345e918a98SKim Phillips 5355e918a98SKim Phillips #define CONFIG_CMDLINE_EDITING 1 /* add command line history */ 536a059e90eSKim Phillips #define CONFIG_AUTO_COMPLETE /* add autocompletion support */ 5375e918a98SKim Phillips 5385e918a98SKim Phillips #undef CONFIG_WATCHDOG /* watchdog disabled */ 5395e918a98SKim Phillips 540c9646ed7SAnton Vorontsov #define CONFIG_MMC 1 541c9646ed7SAnton Vorontsov 542c9646ed7SAnton Vorontsov #ifdef CONFIG_MMC 543c9646ed7SAnton Vorontsov #define CONFIG_FSL_ESDHC 544a6da8b81SChenhui Zhao #define CONFIG_FSL_ESDHC_PIN_MUX 545c9646ed7SAnton Vorontsov #define CONFIG_SYS_FSL_ESDHC_ADDR CONFIG_SYS_MPC83xx_ESDHC_ADDR 546c9646ed7SAnton Vorontsov #define CONFIG_CMD_MMC 547c9646ed7SAnton Vorontsov #define CONFIG_GENERIC_MMC 548c9646ed7SAnton Vorontsov #define CONFIG_CMD_EXT2 549c9646ed7SAnton Vorontsov #define CONFIG_CMD_FAT 550c9646ed7SAnton Vorontsov #define CONFIG_DOS_PARTITION 551c9646ed7SAnton Vorontsov #endif 552c9646ed7SAnton Vorontsov 5535e918a98SKim Phillips /* 5545e918a98SKim Phillips * Miscellaneous configurable options 5555e918a98SKim Phillips */ 5566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LONGHELP /* undef to save memory */ 5576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOAD_ADDR 0x2000000 /* default load address */ 5586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PROMPT "=> " /* Monitor Command Prompt */ 5595e918a98SKim Phillips 5605e918a98SKim Phillips #if defined(CONFIG_CMD_KGDB) 5616d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ 5625e918a98SKim Phillips #else 5636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */ 5645e918a98SKim Phillips #endif 5655e918a98SKim Phillips 5665afe9722SJoe Hershberger /* Print Buffer Size */ 5675afe9722SJoe Hershberger #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) 5686d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MAXARGS 16 /* max number of command args */ 5695afe9722SJoe Hershberger /* Boot Argument Buffer Size */ 5705afe9722SJoe Hershberger #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 5716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HZ 1000 /* decrementer freq: 1ms ticks */ 5725e918a98SKim Phillips 5735e918a98SKim Phillips /* 5745e918a98SKim Phillips * For booting Linux, the board info and command line data 5759f530d59SIra W. Snyder * have to be in the first 256 MB of memory, since this is 5765e918a98SKim Phillips * the maximum mapped by the Linux kernel during initialization. 5775e918a98SKim Phillips */ 5789f530d59SIra W. Snyder #define CONFIG_SYS_BOOTMAPSZ (256 << 20) /* Initial Memory map for Linux */ 5795e918a98SKim Phillips 5805e918a98SKim Phillips /* 5815e918a98SKim Phillips * Core HID Setup 5825e918a98SKim Phillips */ 5836d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HID0_INIT 0x000000000 5845afe9722SJoe Hershberger #define CONFIG_SYS_HID0_FINAL (HID0_ENABLE_MACHINE_CHECK \ 5855afe9722SJoe Hershberger | HID0_ENABLE_INSTRUCTION_CACHE) 5866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HID2 HID2_HBE 5875e918a98SKim Phillips 5885e918a98SKim Phillips /* 5895e918a98SKim Phillips * MMU Setup 5905e918a98SKim Phillips */ 5915e918a98SKim Phillips 59231d82672SBecky Bruce #define CONFIG_HIGH_BATS 1 /* High BATs supported */ 59331d82672SBecky Bruce 5945e918a98SKim Phillips /* DDR: cache cacheable */ 5956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_LOWER CONFIG_SYS_SDRAM_BASE 5966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_UPPER (CONFIG_SYS_SDRAM_BASE + 0x10000000) 5975e918a98SKim Phillips 5985afe9722SJoe Hershberger #define CONFIG_SYS_IBAT0L (CONFIG_SYS_SDRAM_LOWER \ 59972cd4087SJoe Hershberger | BATL_PP_RW \ 6005afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6015afe9722SJoe Hershberger #define CONFIG_SYS_IBAT0U (CONFIG_SYS_SDRAM_LOWER \ 6025afe9722SJoe Hershberger | BATU_BL_256M \ 6035afe9722SJoe Hershberger | BATU_VS \ 6045afe9722SJoe Hershberger | BATU_VP) 6056d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT0L CONFIG_SYS_IBAT0L 6066d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT0U CONFIG_SYS_IBAT0U 6075e918a98SKim Phillips 6085afe9722SJoe Hershberger #define CONFIG_SYS_IBAT1L (CONFIG_SYS_SDRAM_UPPER \ 60972cd4087SJoe Hershberger | BATL_PP_RW \ 6105afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6115afe9722SJoe Hershberger #define CONFIG_SYS_IBAT1U (CONFIG_SYS_SDRAM_UPPER \ 6125afe9722SJoe Hershberger | BATU_BL_256M \ 6135afe9722SJoe Hershberger | BATU_VS \ 6145afe9722SJoe Hershberger | BATU_VP) 6156d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT1L CONFIG_SYS_IBAT1L 6166d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT1U CONFIG_SYS_IBAT1U 6175e918a98SKim Phillips 6185e918a98SKim Phillips /* IMMRBAR, PCI IO and NAND: cache-inhibit and guarded */ 6195afe9722SJoe Hershberger #define CONFIG_SYS_IBAT2L (CONFIG_SYS_IMMR \ 62072cd4087SJoe Hershberger | BATL_PP_RW \ 6215afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6225afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6235afe9722SJoe Hershberger #define CONFIG_SYS_IBAT2U (CONFIG_SYS_IMMR \ 6245afe9722SJoe Hershberger | BATU_BL_8M \ 6255afe9722SJoe Hershberger | BATU_VS \ 6265afe9722SJoe Hershberger | BATU_VP) 6276d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT2L CONFIG_SYS_IBAT2L 6286d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT2U CONFIG_SYS_IBAT2U 6295e918a98SKim Phillips 6305e918a98SKim Phillips /* L2 Switch: cache-inhibit and guarded */ 6315afe9722SJoe Hershberger #define CONFIG_SYS_IBAT3L (CONFIG_SYS_VSC7385_BASE \ 63272cd4087SJoe Hershberger | BATL_PP_RW \ 6335afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6345afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6355afe9722SJoe Hershberger #define CONFIG_SYS_IBAT3U (CONFIG_SYS_VSC7385_BASE \ 6365afe9722SJoe Hershberger | BATU_BL_128K \ 6375afe9722SJoe Hershberger | BATU_VS \ 6385afe9722SJoe Hershberger | BATU_VP) 6396d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT3L CONFIG_SYS_IBAT3L 6406d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT3U CONFIG_SYS_IBAT3U 6415e918a98SKim Phillips 6425e918a98SKim Phillips /* FLASH: icache cacheable, but dcache-inhibit and guarded */ 6435afe9722SJoe Hershberger #define CONFIG_SYS_IBAT4L (CONFIG_SYS_FLASH_BASE \ 64472cd4087SJoe Hershberger | BATL_PP_RW \ 6455afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6465afe9722SJoe Hershberger #define CONFIG_SYS_IBAT4U (CONFIG_SYS_FLASH_BASE \ 6475afe9722SJoe Hershberger | BATU_BL_32M \ 6485afe9722SJoe Hershberger | BATU_VS \ 6495afe9722SJoe Hershberger | BATU_VP) 6505afe9722SJoe Hershberger #define CONFIG_SYS_DBAT4L (CONFIG_SYS_FLASH_BASE \ 65172cd4087SJoe Hershberger | BATL_PP_RW \ 6525afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6535afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT4U CONFIG_SYS_IBAT4U 6555e918a98SKim Phillips 6565e918a98SKim Phillips /* Stack in dcache: cacheable, no memory coherence */ 65772cd4087SJoe Hershberger #define CONFIG_SYS_IBAT5L (CONFIG_SYS_INIT_RAM_ADDR | BATL_PP_RW) 6585afe9722SJoe Hershberger #define CONFIG_SYS_IBAT5U (CONFIG_SYS_INIT_RAM_ADDR \ 6595afe9722SJoe Hershberger | BATU_BL_128K \ 6605afe9722SJoe Hershberger | BATU_VS \ 6615afe9722SJoe Hershberger | BATU_VP) 6626d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT5L CONFIG_SYS_IBAT5L 6636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT5U CONFIG_SYS_IBAT5U 6645e918a98SKim Phillips 6655e918a98SKim Phillips #ifdef CONFIG_PCI 6665e918a98SKim Phillips /* PCI MEM space: cacheable */ 6675afe9722SJoe Hershberger #define CONFIG_SYS_IBAT6L (CONFIG_SYS_PCI_MEM_PHYS \ 66872cd4087SJoe Hershberger | BATL_PP_RW \ 6695afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6705afe9722SJoe Hershberger #define CONFIG_SYS_IBAT6U (CONFIG_SYS_PCI_MEM_PHYS \ 6715afe9722SJoe Hershberger | BATU_BL_256M \ 6725afe9722SJoe Hershberger | BATU_VS \ 6735afe9722SJoe Hershberger | BATU_VP) 6746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6L CONFIG_SYS_IBAT6L 6756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6U CONFIG_SYS_IBAT6U 6765e918a98SKim Phillips /* PCI MMIO space: cache-inhibit and guarded */ 6775afe9722SJoe Hershberger #define CONFIG_SYS_IBAT7L (CONFIG_SYS_PCI_MMIO_PHYS \ 67872cd4087SJoe Hershberger | BATL_PP_RW \ 6795afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6805afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6815afe9722SJoe Hershberger #define CONFIG_SYS_IBAT7U (CONFIG_SYS_PCI_MMIO_PHYS \ 6825afe9722SJoe Hershberger | BATU_BL_256M \ 6835afe9722SJoe Hershberger | BATU_VS \ 6845afe9722SJoe Hershberger | BATU_VP) 6856d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7L CONFIG_SYS_IBAT7L 6866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7U CONFIG_SYS_IBAT7U 6875e918a98SKim Phillips #else 6886d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT6L (0) 6896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT6U (0) 6906d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT7L (0) 6916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT7U (0) 6926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6L CONFIG_SYS_IBAT6L 6936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6U CONFIG_SYS_IBAT6U 6946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7L CONFIG_SYS_IBAT7L 6956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7U CONFIG_SYS_IBAT7U 6965e918a98SKim Phillips #endif 6975e918a98SKim Phillips 6985e918a98SKim Phillips #if defined(CONFIG_CMD_KGDB) 6995e918a98SKim Phillips #define CONFIG_KGDB_BAUDRATE 230400 /* speed of kgdb serial port */ 7005e918a98SKim Phillips #define CONFIG_KGDB_SER_INDEX 2 /* which serial port to use */ 7015e918a98SKim Phillips #endif 7025e918a98SKim Phillips 7035e918a98SKim Phillips /* 7045e918a98SKim Phillips * Environment Configuration 7055e918a98SKim Phillips */ 7065e918a98SKim Phillips #define CONFIG_ENV_OVERWRITE 7075e918a98SKim Phillips 70818e69a35SAnton Vorontsov #define CONFIG_HAS_FSL_DR_USB 70918e69a35SAnton Vorontsov 7105afe9722SJoe Hershberger #define CONFIG_NETDEV "eth1" 7115e918a98SKim Phillips 7125e918a98SKim Phillips #define CONFIG_HOSTNAME mpc837x_rdb 7138b3637c6SJoe Hershberger #define CONFIG_ROOTPATH "/nfsroot" 7145afe9722SJoe Hershberger #define CONFIG_RAMDISKFILE "rootfs.ext2.gz.uboot" 715b3f44c21SJoe Hershberger #define CONFIG_BOOTFILE "uImage" 7165afe9722SJoe Hershberger /* U-Boot image on TFTP server */ 7175afe9722SJoe Hershberger #define CONFIG_UBOOTPATH "u-boot.bin" 7185afe9722SJoe Hershberger #define CONFIG_FDTFILE "mpc8379_rdb.dtb" 7195e918a98SKim Phillips 7205afe9722SJoe Hershberger /* default location for tftp and bootm */ 7215afe9722SJoe Hershberger #define CONFIG_LOADADDR 800000 7227fd0bea2SKim Phillips #define CONFIG_BOOTDELAY 6 /* -1 disables auto-boot */ 7235e918a98SKim Phillips #define CONFIG_BAUDRATE 115200 7245e918a98SKim Phillips 7255e918a98SKim Phillips #define XMK_STR(x) #x 7265e918a98SKim Phillips #define MK_STR(x) XMK_STR(x) 7275e918a98SKim Phillips 7285e918a98SKim Phillips #define CONFIG_EXTRA_ENV_SETTINGS \ 7295afe9722SJoe Hershberger "netdev=" CONFIG_NETDEV "\0" \ 7305afe9722SJoe Hershberger "uboot=" CONFIG_UBOOTPATH "\0" \ 7315e918a98SKim Phillips "tftpflash=tftp $loadaddr $uboot;" \ 73214d0a02aSWolfgang Denk "protect off " MK_STR(CONFIG_SYS_TEXT_BASE) " +$filesize; " \ 73314d0a02aSWolfgang Denk "erase " MK_STR(CONFIG_SYS_TEXT_BASE) " +$filesize; " \ 73414d0a02aSWolfgang Denk "cp.b $loadaddr " MK_STR(CONFIG_SYS_TEXT_BASE) " $filesize; " \ 73514d0a02aSWolfgang Denk "protect on " MK_STR(CONFIG_SYS_TEXT_BASE) " +$filesize; " \ 73614d0a02aSWolfgang Denk "cmp.b $loadaddr " MK_STR(CONFIG_SYS_TEXT_BASE) " $filesize\0" \ 73779f516bcSKim Phillips "fdtaddr=780000\0" \ 7385afe9722SJoe Hershberger "fdtfile=" CONFIG_FDTFILE "\0" \ 7395e918a98SKim Phillips "ramdiskaddr=1000000\0" \ 7405afe9722SJoe Hershberger "ramdiskfile=" CONFIG_RAMDISKFILE "\0" \ 7415e918a98SKim Phillips "console=ttyS0\0" \ 7425e918a98SKim Phillips "setbootargs=setenv bootargs " \ 7435e918a98SKim Phillips "root=$rootdev rw console=$console,$baudrate $othbootargs\0" \ 7445e918a98SKim Phillips "setipargs=setenv bootargs nfsroot=$serverip:$rootpath " \ 7455afe9722SJoe Hershberger "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:" \ 7465afe9722SJoe Hershberger "$netdev:off " \ 7475e918a98SKim Phillips "root=$rootdev rw console=$console,$baudrate $othbootargs\0" 7485e918a98SKim Phillips 7495e918a98SKim Phillips #define CONFIG_NFSBOOTCOMMAND \ 7505e918a98SKim Phillips "setenv rootdev /dev/nfs;" \ 7515e918a98SKim Phillips "run setbootargs;" \ 7525e918a98SKim Phillips "run setipargs;" \ 7535e918a98SKim Phillips "tftp $loadaddr $bootfile;" \ 7545e918a98SKim Phillips "tftp $fdtaddr $fdtfile;" \ 7555e918a98SKim Phillips "bootm $loadaddr - $fdtaddr" 7565e918a98SKim Phillips 7575e918a98SKim Phillips #define CONFIG_RAMBOOTCOMMAND \ 7585e918a98SKim Phillips "setenv rootdev /dev/ram;" \ 7595e918a98SKim Phillips "run setbootargs;" \ 7605e918a98SKim Phillips "tftp $ramdiskaddr $ramdiskfile;" \ 7615e918a98SKim Phillips "tftp $loadaddr $bootfile;" \ 7625e918a98SKim Phillips "tftp $fdtaddr $fdtfile;" \ 7635e918a98SKim Phillips "bootm $loadaddr $ramdiskaddr $fdtaddr" 7645e918a98SKim Phillips 7655e918a98SKim Phillips #undef MK_STR 7665e918a98SKim Phillips #undef XMK_STR 7675e918a98SKim Phillips 7685e918a98SKim Phillips #endif /* __CONFIG_H */ 769