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 \ 2787d6a0982SJoe Hershberger | BR_PS_16 /* 16 bit port */ \ 2797d6a0982SJoe Hershberger | BR_MS_GPCM /* MSEL = GPCM */ \ 2805afe9722SJoe Hershberger | BR_V) /* valid */ 2817d6a0982SJoe Hershberger #define CONFIG_SYS_OR0_PRELIM (MEG_TO_AM(CONFIG_SYS_FLASH_SIZE) \ 2825e918a98SKim Phillips | OR_GPCM_XACS \ 2835e918a98SKim Phillips | OR_GPCM_SCY_9 \ 2847d6a0982SJoe Hershberger | OR_GPCM_EHTR_SET \ 2855e918a98SKim Phillips | OR_GPCM_EAD) 2867d6a0982SJoe 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 */ 2987d6a0982SJoe Hershberger #define CONFIG_SYS_NAND_BASE 0xE0600000 2995afe9722SJoe Hershberger #define CONFIG_SYS_BR1_PRELIM (CONFIG_SYS_NAND_BASE \ 3007d6a0982SJoe Hershberger | BR_DECC_CHK_GEN /* Use HW ECC */ \ 3017d6a0982SJoe Hershberger | BR_PS_8 /* 8 bit port */ \ 3027d6a0982SJoe Hershberger | BR_MS_FCM /* MSEL = FCM */ \ 3035afe9722SJoe Hershberger | BR_V) /* valid */ 3047d6a0982SJoe 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 3127d6a0982SJoe 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 3207d6a0982SJoe Hershberger #define CONFIG_SYS_BR2_PRELIM (CONFIG_SYS_VSC7385_BASE \ 3217d6a0982SJoe Hershberger | BR_PS_8 \ 3227d6a0982SJoe Hershberger | BR_MS_GPCM \ 3237d6a0982SJoe Hershberger | BR_V) 3247d6a0982SJoe Hershberger /* 0xF0000801 */ 3257d6a0982SJoe Hershberger #define CONFIG_SYS_OR2_PRELIM (OR_AM_128KB \ 3267d6a0982SJoe Hershberger | OR_GPCM_CSNT \ 3277d6a0982SJoe Hershberger | OR_GPCM_XACS \ 3287d6a0982SJoe Hershberger | OR_GPCM_SCY_15 \ 3297d6a0982SJoe Hershberger | OR_GPCM_SETA \ 3307d6a0982SJoe Hershberger | OR_GPCM_TRLX_SET \ 3317d6a0982SJoe Hershberger | OR_GPCM_EHTR_SET \ 3327d6a0982SJoe Hershberger | OR_GPCM_EAD) 3337d6a0982SJoe Hershberger /* 0xfffe09ff */ 3347d6a0982SJoe Hershberger 3355afe9722SJoe Hershberger /* Access Base */ 3365afe9722SJoe Hershberger #define CONFIG_SYS_LBLAWBAR2_PRELIM CONFIG_SYS_VSC7385_BASE 3377d6a0982SJoe 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 3635e918a98SKim Phillips 3645e918a98SKim Phillips /* Pass open firmware flat tree */ 3655e918a98SKim Phillips #define CONFIG_OF_LIBFDT 1 3665e918a98SKim Phillips #define CONFIG_OF_BOARD_SETUP 1 367aabce7fbSAnton Vorontsov #define CONFIG_OF_STDOUT_VIA_ALIAS 1 3685e918a98SKim Phillips 3695e918a98SKim Phillips /* I2C */ 370*00f792e0SHeiko Schocher #define CONFIG_SYS_I2C 371*00f792e0SHeiko Schocher #define CONFIG_SYS_I2C_FSL 372*00f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_SPEED 400000 373*00f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_SLAVE 0x7F 374*00f792e0SHeiko Schocher #define CONFIG_SYS_FSL_I2C_OFFSET 0x3000 375*00f792e0SHeiko Schocher #define CONFIG_SYS_I2C_NOPROBES { {0, 0x51} } 3765e918a98SKim Phillips 3775e918a98SKim Phillips /* 3785e918a98SKim Phillips * Config on-board RTC 3795e918a98SKim Phillips */ 3805e918a98SKim Phillips #define CONFIG_RTC_DS1374 /* use ds1374 rtc via i2c */ 3816d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_RTC_ADDR 0x68 /* at address 0x68 */ 3825e918a98SKim Phillips 3835e918a98SKim Phillips /* 3845e918a98SKim Phillips * General PCI 3855e918a98SKim Phillips * Addresses are mapped 1-1. 3865e918a98SKim Phillips */ 3876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_BASE 0x80000000 3886d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_PHYS CONFIG_SYS_PCI_MEM_BASE 3896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_SIZE 0x10000000 /* 256M */ 3906d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_BASE 0x90000000 3916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_PHYS CONFIG_SYS_PCI_MMIO_BASE 3926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MMIO_SIZE 0x10000000 /* 256M */ 3936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_BASE 0x00000000 3946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_PHYS 0xE0300000 3956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_SIZE 0x100000 /* 1M */ 3965e918a98SKim Phillips 3976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_LOCAL CONFIG_SYS_SDRAM_BASE 3986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_BUS 0x00000000 3996d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SLV_MEM_SIZE 0x80000000 4005e918a98SKim Phillips 4017e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_BASE 0xA0000000 4027e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_CFG_BASE 0xA0000000 4037e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_CFG_SIZE 0x08000000 4047e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_BASE 0xA8000000 4057e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_PHYS 0xA8000000 4067e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_MEM_SIZE 0x10000000 4077e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_BASE 0x00000000 4087e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_PHYS 0xB8000000 4097e915580SAnton Vorontsov #define CONFIG_SYS_PCIE1_IO_SIZE 0x00800000 4107e915580SAnton Vorontsov 4117e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_BASE 0xC0000000 4127e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_CFG_BASE 0xC0000000 4137e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_CFG_SIZE 0x08000000 4147e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_BASE 0xC8000000 4157e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_PHYS 0xC8000000 4167e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_MEM_SIZE 0x10000000 4177e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_BASE 0x00000000 4187e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_PHYS 0xD8000000 4197e915580SAnton Vorontsov #define CONFIG_SYS_PCIE2_IO_SIZE 0x00800000 4207e915580SAnton Vorontsov 4215e918a98SKim Phillips #ifdef CONFIG_PCI 422842033e6SGabor Juhos #define CONFIG_PCI_INDIRECT_BRIDGE 4235e918a98SKim Phillips #define CONFIG_PCI_PNP /* do pci plug-and-play */ 4245e918a98SKim Phillips 4255e918a98SKim Phillips #undef CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */ 4266d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_SUBSYS_VENDORID 0x1957 /* Freescale */ 4275e918a98SKim Phillips #endif /* CONFIG_PCI */ 4285e918a98SKim Phillips 4295e918a98SKim Phillips /* 4305e918a98SKim Phillips * TSEC 4315e918a98SKim Phillips */ 43289c7784eSTimur Tabi #ifdef CONFIG_TSEC_ENET 4335e918a98SKim Phillips 43489c7784eSTimur Tabi #define CONFIG_GMII /* MII PHY management */ 43589c7784eSTimur Tabi 43689c7784eSTimur Tabi #define CONFIG_TSEC1 43789c7784eSTimur Tabi 43889c7784eSTimur Tabi #ifdef CONFIG_TSEC1 43989c7784eSTimur Tabi #define CONFIG_HAS_ETH0 4405e918a98SKim Phillips #define CONFIG_TSEC1_NAME "TSEC0" 4416d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_TSEC1_OFFSET 0x24000 4425e918a98SKim Phillips #define TSEC1_PHY_ADDR 2 4435e918a98SKim Phillips #define TSEC1_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 4445e918a98SKim Phillips #define TSEC1_PHYIDX 0 44589c7784eSTimur Tabi #endif 4465e918a98SKim Phillips 44789c7784eSTimur Tabi #ifdef CONFIG_TSEC2 44889c7784eSTimur Tabi #define CONFIG_HAS_ETH1 44989c7784eSTimur Tabi #define CONFIG_TSEC2_NAME "TSEC1" 4506d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_TSEC2_OFFSET 0x25000 45189c7784eSTimur Tabi #define TSEC2_PHY_ADDR 0x1c 45289c7784eSTimur Tabi #define TSEC2_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 45389c7784eSTimur Tabi #define TSEC2_PHYIDX 0 45489c7784eSTimur Tabi #endif 4555e918a98SKim Phillips 4565e918a98SKim Phillips /* Options are: TSEC[0-1] */ 4575e918a98SKim Phillips #define CONFIG_ETHPRIME "TSEC0" 4585e918a98SKim Phillips 45989c7784eSTimur Tabi #endif 46089c7784eSTimur Tabi 4615e918a98SKim Phillips /* 462730e7929SKim Phillips * SATA 463730e7929SKim Phillips */ 464730e7929SKim Phillips #define CONFIG_LIBATA 465730e7929SKim Phillips #define CONFIG_FSL_SATA 466730e7929SKim Phillips 4676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA_MAX_DEVICE 2 468730e7929SKim Phillips #define CONFIG_SATA1 4696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1_OFFSET 0x18000 4706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1 (CONFIG_SYS_IMMR + CONFIG_SYS_SATA1_OFFSET) 4716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA1_FLAGS FLAGS_DMA 472730e7929SKim Phillips #define CONFIG_SATA2 4736d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2_OFFSET 0x19000 4746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2 (CONFIG_SYS_IMMR + CONFIG_SYS_SATA2_OFFSET) 4756d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SATA2_FLAGS FLAGS_DMA 476730e7929SKim Phillips 477730e7929SKim Phillips #ifdef CONFIG_FSL_SATA 478730e7929SKim Phillips #define CONFIG_LBA48 479730e7929SKim Phillips #define CONFIG_CMD_SATA 480730e7929SKim Phillips #define CONFIG_DOS_PARTITION 481730e7929SKim Phillips #define CONFIG_CMD_EXT2 482730e7929SKim Phillips #endif 483730e7929SKim Phillips 484730e7929SKim Phillips /* 4855e918a98SKim Phillips * Environment 4865e918a98SKim Phillips */ 4876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifndef CONFIG_SYS_RAMBOOT 4885a1aceb0SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_IS_IN_FLASH 1 4895afe9722SJoe Hershberger #define CONFIG_ENV_ADDR \ 4905afe9722SJoe Hershberger (CONFIG_SYS_MONITOR_BASE+CONFIG_SYS_MONITOR_LEN) 4910e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SECT_SIZE 0x10000 /* 64K (one sector) for env */ 4920e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SIZE 0x4000 4935e918a98SKim Phillips #else 4946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_NO_FLASH 1 /* Flash is not usable now */ 49593f6d725SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_IS_NOWHERE 1 /* Store ENV in memory only */ 4966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE-0x1000) 4970e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SIZE 0x2000 4985e918a98SKim Phillips #endif 4995e918a98SKim Phillips 5005e918a98SKim Phillips #define CONFIG_LOADS_ECHO 1 /* echo on for serial download */ 5016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOADS_BAUD_CHANGE 1 /* allow baudrate change */ 5025e918a98SKim Phillips 5035e918a98SKim Phillips /* 5045e918a98SKim Phillips * BOOTP options 5055e918a98SKim Phillips */ 5065e918a98SKim Phillips #define CONFIG_BOOTP_BOOTFILESIZE 5075e918a98SKim Phillips #define CONFIG_BOOTP_BOOTPATH 5085e918a98SKim Phillips #define CONFIG_BOOTP_GATEWAY 5095e918a98SKim Phillips #define CONFIG_BOOTP_HOSTNAME 5105e918a98SKim Phillips 5115e918a98SKim Phillips 5125e918a98SKim Phillips /* 5135e918a98SKim Phillips * Command line configuration. 5145e918a98SKim Phillips */ 5155e918a98SKim Phillips #include <config_cmd_default.h> 5165e918a98SKim Phillips 5175e918a98SKim Phillips #define CONFIG_CMD_PING 5185e918a98SKim Phillips #define CONFIG_CMD_I2C 5195e918a98SKim Phillips #define CONFIG_CMD_MII 5205e918a98SKim Phillips #define CONFIG_CMD_DATE 5215e918a98SKim Phillips 5225e918a98SKim Phillips #if defined(CONFIG_PCI) 5235e918a98SKim Phillips #define CONFIG_CMD_PCI 5245e918a98SKim Phillips #endif 5255e918a98SKim Phillips 5266d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_RAMBOOT) 527bdab39d3SMike Frysinger #undef CONFIG_CMD_SAVEENV 5285e918a98SKim Phillips #undef CONFIG_CMD_LOADS 5295e918a98SKim Phillips #endif 5305e918a98SKim Phillips 5315e918a98SKim Phillips #define CONFIG_CMDLINE_EDITING 1 /* add command line history */ 532a059e90eSKim Phillips #define CONFIG_AUTO_COMPLETE /* add autocompletion support */ 5335e918a98SKim Phillips 5345e918a98SKim Phillips #undef CONFIG_WATCHDOG /* watchdog disabled */ 5355e918a98SKim Phillips 536c9646ed7SAnton Vorontsov #define CONFIG_MMC 1 537c9646ed7SAnton Vorontsov 538c9646ed7SAnton Vorontsov #ifdef CONFIG_MMC 539c9646ed7SAnton Vorontsov #define CONFIG_FSL_ESDHC 540a6da8b81SChenhui Zhao #define CONFIG_FSL_ESDHC_PIN_MUX 541c9646ed7SAnton Vorontsov #define CONFIG_SYS_FSL_ESDHC_ADDR CONFIG_SYS_MPC83xx_ESDHC_ADDR 542c9646ed7SAnton Vorontsov #define CONFIG_CMD_MMC 543c9646ed7SAnton Vorontsov #define CONFIG_GENERIC_MMC 544c9646ed7SAnton Vorontsov #define CONFIG_CMD_EXT2 545c9646ed7SAnton Vorontsov #define CONFIG_CMD_FAT 546c9646ed7SAnton Vorontsov #define CONFIG_DOS_PARTITION 547c9646ed7SAnton Vorontsov #endif 548c9646ed7SAnton Vorontsov 5495e918a98SKim Phillips /* 5505e918a98SKim Phillips * Miscellaneous configurable options 5515e918a98SKim Phillips */ 5526d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LONGHELP /* undef to save memory */ 5536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOAD_ADDR 0x2000000 /* default load address */ 5546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PROMPT "=> " /* Monitor Command Prompt */ 5555e918a98SKim Phillips 5565e918a98SKim Phillips #if defined(CONFIG_CMD_KGDB) 5576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ 5585e918a98SKim Phillips #else 5596d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */ 5605e918a98SKim Phillips #endif 5615e918a98SKim Phillips 5625afe9722SJoe Hershberger /* Print Buffer Size */ 5635afe9722SJoe Hershberger #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) 5646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MAXARGS 16 /* max number of command args */ 5655afe9722SJoe Hershberger /* Boot Argument Buffer Size */ 5665afe9722SJoe Hershberger #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 5676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HZ 1000 /* decrementer freq: 1ms ticks */ 5685e918a98SKim Phillips 5695e918a98SKim Phillips /* 5705e918a98SKim Phillips * For booting Linux, the board info and command line data 5719f530d59SIra W. Snyder * have to be in the first 256 MB of memory, since this is 5725e918a98SKim Phillips * the maximum mapped by the Linux kernel during initialization. 5735e918a98SKim Phillips */ 5749f530d59SIra W. Snyder #define CONFIG_SYS_BOOTMAPSZ (256 << 20) /* Initial Memory map for Linux */ 5755e918a98SKim Phillips 5765e918a98SKim Phillips /* 5775e918a98SKim Phillips * Core HID Setup 5785e918a98SKim Phillips */ 5796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HID0_INIT 0x000000000 5805afe9722SJoe Hershberger #define CONFIG_SYS_HID0_FINAL (HID0_ENABLE_MACHINE_CHECK \ 5815afe9722SJoe Hershberger | HID0_ENABLE_INSTRUCTION_CACHE) 5826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HID2 HID2_HBE 5835e918a98SKim Phillips 5845e918a98SKim Phillips /* 5855e918a98SKim Phillips * MMU Setup 5865e918a98SKim Phillips */ 5875e918a98SKim Phillips 58831d82672SBecky Bruce #define CONFIG_HIGH_BATS 1 /* High BATs supported */ 58931d82672SBecky Bruce 5905e918a98SKim Phillips /* DDR: cache cacheable */ 5916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_LOWER CONFIG_SYS_SDRAM_BASE 5926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_UPPER (CONFIG_SYS_SDRAM_BASE + 0x10000000) 5935e918a98SKim Phillips 5945afe9722SJoe Hershberger #define CONFIG_SYS_IBAT0L (CONFIG_SYS_SDRAM_LOWER \ 59572cd4087SJoe Hershberger | BATL_PP_RW \ 5965afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 5975afe9722SJoe Hershberger #define CONFIG_SYS_IBAT0U (CONFIG_SYS_SDRAM_LOWER \ 5985afe9722SJoe Hershberger | BATU_BL_256M \ 5995afe9722SJoe Hershberger | BATU_VS \ 6005afe9722SJoe Hershberger | BATU_VP) 6016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT0L CONFIG_SYS_IBAT0L 6026d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT0U CONFIG_SYS_IBAT0U 6035e918a98SKim Phillips 6045afe9722SJoe Hershberger #define CONFIG_SYS_IBAT1L (CONFIG_SYS_SDRAM_UPPER \ 60572cd4087SJoe Hershberger | BATL_PP_RW \ 6065afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6075afe9722SJoe Hershberger #define CONFIG_SYS_IBAT1U (CONFIG_SYS_SDRAM_UPPER \ 6085afe9722SJoe Hershberger | BATU_BL_256M \ 6095afe9722SJoe Hershberger | BATU_VS \ 6105afe9722SJoe Hershberger | BATU_VP) 6116d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT1L CONFIG_SYS_IBAT1L 6126d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT1U CONFIG_SYS_IBAT1U 6135e918a98SKim Phillips 6145e918a98SKim Phillips /* IMMRBAR, PCI IO and NAND: cache-inhibit and guarded */ 6155afe9722SJoe Hershberger #define CONFIG_SYS_IBAT2L (CONFIG_SYS_IMMR \ 61672cd4087SJoe Hershberger | BATL_PP_RW \ 6175afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6185afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6195afe9722SJoe Hershberger #define CONFIG_SYS_IBAT2U (CONFIG_SYS_IMMR \ 6205afe9722SJoe Hershberger | BATU_BL_8M \ 6215afe9722SJoe Hershberger | BATU_VS \ 6225afe9722SJoe Hershberger | BATU_VP) 6236d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT2L CONFIG_SYS_IBAT2L 6246d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT2U CONFIG_SYS_IBAT2U 6255e918a98SKim Phillips 6265e918a98SKim Phillips /* L2 Switch: cache-inhibit and guarded */ 6275afe9722SJoe Hershberger #define CONFIG_SYS_IBAT3L (CONFIG_SYS_VSC7385_BASE \ 62872cd4087SJoe Hershberger | BATL_PP_RW \ 6295afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6305afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6315afe9722SJoe Hershberger #define CONFIG_SYS_IBAT3U (CONFIG_SYS_VSC7385_BASE \ 6325afe9722SJoe Hershberger | BATU_BL_128K \ 6335afe9722SJoe Hershberger | BATU_VS \ 6345afe9722SJoe Hershberger | BATU_VP) 6356d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT3L CONFIG_SYS_IBAT3L 6366d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT3U CONFIG_SYS_IBAT3U 6375e918a98SKim Phillips 6385e918a98SKim Phillips /* FLASH: icache cacheable, but dcache-inhibit and guarded */ 6395afe9722SJoe Hershberger #define CONFIG_SYS_IBAT4L (CONFIG_SYS_FLASH_BASE \ 64072cd4087SJoe Hershberger | BATL_PP_RW \ 6415afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6425afe9722SJoe Hershberger #define CONFIG_SYS_IBAT4U (CONFIG_SYS_FLASH_BASE \ 6435afe9722SJoe Hershberger | BATU_BL_32M \ 6445afe9722SJoe Hershberger | BATU_VS \ 6455afe9722SJoe Hershberger | BATU_VP) 6465afe9722SJoe Hershberger #define CONFIG_SYS_DBAT4L (CONFIG_SYS_FLASH_BASE \ 64772cd4087SJoe Hershberger | BATL_PP_RW \ 6485afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6495afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6506d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT4U CONFIG_SYS_IBAT4U 6515e918a98SKim Phillips 6525e918a98SKim Phillips /* Stack in dcache: cacheable, no memory coherence */ 65372cd4087SJoe Hershberger #define CONFIG_SYS_IBAT5L (CONFIG_SYS_INIT_RAM_ADDR | BATL_PP_RW) 6545afe9722SJoe Hershberger #define CONFIG_SYS_IBAT5U (CONFIG_SYS_INIT_RAM_ADDR \ 6555afe9722SJoe Hershberger | BATU_BL_128K \ 6565afe9722SJoe Hershberger | BATU_VS \ 6575afe9722SJoe Hershberger | BATU_VP) 6586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT5L CONFIG_SYS_IBAT5L 6596d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT5U CONFIG_SYS_IBAT5U 6605e918a98SKim Phillips 6615e918a98SKim Phillips #ifdef CONFIG_PCI 6625e918a98SKim Phillips /* PCI MEM space: cacheable */ 6635afe9722SJoe Hershberger #define CONFIG_SYS_IBAT6L (CONFIG_SYS_PCI_MEM_PHYS \ 66472cd4087SJoe Hershberger | BATL_PP_RW \ 6655afe9722SJoe Hershberger | BATL_MEMCOHERENCE) 6665afe9722SJoe Hershberger #define CONFIG_SYS_IBAT6U (CONFIG_SYS_PCI_MEM_PHYS \ 6675afe9722SJoe Hershberger | BATU_BL_256M \ 6685afe9722SJoe Hershberger | BATU_VS \ 6695afe9722SJoe Hershberger | BATU_VP) 6706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6L CONFIG_SYS_IBAT6L 6716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6U CONFIG_SYS_IBAT6U 6725e918a98SKim Phillips /* PCI MMIO space: cache-inhibit and guarded */ 6735afe9722SJoe Hershberger #define CONFIG_SYS_IBAT7L (CONFIG_SYS_PCI_MMIO_PHYS \ 67472cd4087SJoe Hershberger | BATL_PP_RW \ 6755afe9722SJoe Hershberger | BATL_CACHEINHIBIT \ 6765afe9722SJoe Hershberger | BATL_GUARDEDSTORAGE) 6775afe9722SJoe Hershberger #define CONFIG_SYS_IBAT7U (CONFIG_SYS_PCI_MMIO_PHYS \ 6785afe9722SJoe Hershberger | BATU_BL_256M \ 6795afe9722SJoe Hershberger | BATU_VS \ 6805afe9722SJoe Hershberger | BATU_VP) 6816d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7L CONFIG_SYS_IBAT7L 6826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7U CONFIG_SYS_IBAT7U 6835e918a98SKim Phillips #else 6846d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT6L (0) 6856d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT6U (0) 6866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT7L (0) 6876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IBAT7U (0) 6886d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6L CONFIG_SYS_IBAT6L 6896d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT6U CONFIG_SYS_IBAT6U 6906d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7L CONFIG_SYS_IBAT7L 6916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_DBAT7U CONFIG_SYS_IBAT7U 6925e918a98SKim Phillips #endif 6935e918a98SKim Phillips 6945e918a98SKim Phillips #if defined(CONFIG_CMD_KGDB) 6955e918a98SKim Phillips #define CONFIG_KGDB_BAUDRATE 230400 /* speed of kgdb serial port */ 6965e918a98SKim Phillips #define CONFIG_KGDB_SER_INDEX 2 /* which serial port to use */ 6975e918a98SKim Phillips #endif 6985e918a98SKim Phillips 6995e918a98SKim Phillips /* 7005e918a98SKim Phillips * Environment Configuration 7015e918a98SKim Phillips */ 7025e918a98SKim Phillips #define CONFIG_ENV_OVERWRITE 7035e918a98SKim Phillips 70418e69a35SAnton Vorontsov #define CONFIG_HAS_FSL_DR_USB 70518e69a35SAnton Vorontsov 7065afe9722SJoe Hershberger #define CONFIG_NETDEV "eth1" 7075e918a98SKim Phillips 7085e918a98SKim Phillips #define CONFIG_HOSTNAME mpc837x_rdb 7098b3637c6SJoe Hershberger #define CONFIG_ROOTPATH "/nfsroot" 7105afe9722SJoe Hershberger #define CONFIG_RAMDISKFILE "rootfs.ext2.gz.uboot" 711b3f44c21SJoe Hershberger #define CONFIG_BOOTFILE "uImage" 7125afe9722SJoe Hershberger /* U-Boot image on TFTP server */ 7135afe9722SJoe Hershberger #define CONFIG_UBOOTPATH "u-boot.bin" 7145afe9722SJoe Hershberger #define CONFIG_FDTFILE "mpc8379_rdb.dtb" 7155e918a98SKim Phillips 7165afe9722SJoe Hershberger /* default location for tftp and bootm */ 7175afe9722SJoe Hershberger #define CONFIG_LOADADDR 800000 7187fd0bea2SKim Phillips #define CONFIG_BOOTDELAY 6 /* -1 disables auto-boot */ 7195e918a98SKim Phillips #define CONFIG_BAUDRATE 115200 7205e918a98SKim Phillips 7215e918a98SKim Phillips #define CONFIG_EXTRA_ENV_SETTINGS \ 7225afe9722SJoe Hershberger "netdev=" CONFIG_NETDEV "\0" \ 7235afe9722SJoe Hershberger "uboot=" CONFIG_UBOOTPATH "\0" \ 7245e918a98SKim Phillips "tftpflash=tftp $loadaddr $uboot;" \ 7255368c55dSMarek Vasut "protect off " __stringify(CONFIG_SYS_TEXT_BASE) \ 7265368c55dSMarek Vasut " +$filesize; " \ 7275368c55dSMarek Vasut "erase " __stringify(CONFIG_SYS_TEXT_BASE) \ 7285368c55dSMarek Vasut " +$filesize; " \ 7295368c55dSMarek Vasut "cp.b $loadaddr " __stringify(CONFIG_SYS_TEXT_BASE) \ 7305368c55dSMarek Vasut " $filesize; " \ 7315368c55dSMarek Vasut "protect on " __stringify(CONFIG_SYS_TEXT_BASE) \ 7325368c55dSMarek Vasut " +$filesize; " \ 7335368c55dSMarek Vasut "cmp.b $loadaddr " __stringify(CONFIG_SYS_TEXT_BASE) \ 7345368c55dSMarek Vasut " $filesize\0" \ 73579f516bcSKim Phillips "fdtaddr=780000\0" \ 7365afe9722SJoe Hershberger "fdtfile=" CONFIG_FDTFILE "\0" \ 7375e918a98SKim Phillips "ramdiskaddr=1000000\0" \ 7385afe9722SJoe Hershberger "ramdiskfile=" CONFIG_RAMDISKFILE "\0" \ 7395e918a98SKim Phillips "console=ttyS0\0" \ 7405e918a98SKim Phillips "setbootargs=setenv bootargs " \ 7415e918a98SKim Phillips "root=$rootdev rw console=$console,$baudrate $othbootargs\0" \ 7425e918a98SKim Phillips "setipargs=setenv bootargs nfsroot=$serverip:$rootpath " \ 7435afe9722SJoe Hershberger "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:" \ 7445afe9722SJoe Hershberger "$netdev:off " \ 7455e918a98SKim Phillips "root=$rootdev rw console=$console,$baudrate $othbootargs\0" 7465e918a98SKim Phillips 7475e918a98SKim Phillips #define CONFIG_NFSBOOTCOMMAND \ 7485e918a98SKim Phillips "setenv rootdev /dev/nfs;" \ 7495e918a98SKim Phillips "run setbootargs;" \ 7505e918a98SKim Phillips "run setipargs;" \ 7515e918a98SKim Phillips "tftp $loadaddr $bootfile;" \ 7525e918a98SKim Phillips "tftp $fdtaddr $fdtfile;" \ 7535e918a98SKim Phillips "bootm $loadaddr - $fdtaddr" 7545e918a98SKim Phillips 7555e918a98SKim Phillips #define CONFIG_RAMBOOTCOMMAND \ 7565e918a98SKim Phillips "setenv rootdev /dev/ram;" \ 7575e918a98SKim Phillips "run setbootargs;" \ 7585e918a98SKim Phillips "tftp $ramdiskaddr $ramdiskfile;" \ 7595e918a98SKim Phillips "tftp $loadaddr $bootfile;" \ 7605e918a98SKim Phillips "tftp $fdtaddr $fdtfile;" \ 7615e918a98SKim Phillips "bootm $loadaddr $ramdiskaddr $fdtaddr" 7625e918a98SKim Phillips 7635e918a98SKim Phillips #endif /* __CONFIG_H */ 764