18ae158cdSTsiChungLiew /* 28ae158cdSTsiChungLiew * Configuation settings for the Freescale MCF54455 EVB board. 38ae158cdSTsiChungLiew * 48ae158cdSTsiChungLiew * Copyright (C) 2004-2007 Freescale Semiconductor, Inc. 58ae158cdSTsiChungLiew * TsiChung Liew (Tsi-Chung.Liew@freescale.com) 68ae158cdSTsiChungLiew * 78ae158cdSTsiChungLiew * See file CREDITS for list of people who contributed to this 88ae158cdSTsiChungLiew * project. 98ae158cdSTsiChungLiew * 108ae158cdSTsiChungLiew * This program is free software; you can redistribute it and/or 118ae158cdSTsiChungLiew * modify it under the terms of the GNU General Public License as 128ae158cdSTsiChungLiew * published by the Free Software Foundation; either version 2 of 138ae158cdSTsiChungLiew * the License, or (at your option) any later version. 148ae158cdSTsiChungLiew * 158ae158cdSTsiChungLiew * This program is distributed in the hope that it will be useful, 168ae158cdSTsiChungLiew * but WITHOUT ANY WARRANTY; without even the implied warranty of 178ae158cdSTsiChungLiew * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 188ae158cdSTsiChungLiew * GNU General Public License for more details. 198ae158cdSTsiChungLiew * 208ae158cdSTsiChungLiew * You should have received a copy of the GNU General Public License 218ae158cdSTsiChungLiew * along with this program; if not, write to the Free Software 228ae158cdSTsiChungLiew * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 238ae158cdSTsiChungLiew * MA 02111-1307 USA 248ae158cdSTsiChungLiew */ 258ae158cdSTsiChungLiew 268ae158cdSTsiChungLiew /* 278ae158cdSTsiChungLiew * board/config.h - configuration options, board specific 288ae158cdSTsiChungLiew */ 298ae158cdSTsiChungLiew 30e8ee8f3aSTsiChungLiew #ifndef _M54455EVB_H 31e8ee8f3aSTsiChungLiew #define _M54455EVB_H 328ae158cdSTsiChungLiew 338ae158cdSTsiChungLiew /* 348ae158cdSTsiChungLiew * High Level Configuration Options 358ae158cdSTsiChungLiew * (easy to change) 368ae158cdSTsiChungLiew */ 378ae158cdSTsiChungLiew #define CONFIG_MCF5445x /* define processor family */ 388ae158cdSTsiChungLiew #define CONFIG_M54455 /* define processor type */ 398ae158cdSTsiChungLiew #define CONFIG_M54455EVB /* M54455EVB board */ 408ae158cdSTsiChungLiew 418ae158cdSTsiChungLiew #define CONFIG_MCFUART 426d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_UART_PORT (0) 438ae158cdSTsiChungLiew #define CONFIG_BAUDRATE 115200 446d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_BAUDRATE_TABLE { 9600 , 19200 , 38400 , 57600, 115200 } 458ae158cdSTsiChungLiew 468ae158cdSTsiChungLiew #undef CONFIG_WATCHDOG 478ae158cdSTsiChungLiew 488ae158cdSTsiChungLiew #define CONFIG_TIMESTAMP /* Print image info with timestamp */ 498ae158cdSTsiChungLiew 508ae158cdSTsiChungLiew /* 518ae158cdSTsiChungLiew * BOOTP options 528ae158cdSTsiChungLiew */ 538ae158cdSTsiChungLiew #define CONFIG_BOOTP_BOOTFILESIZE 548ae158cdSTsiChungLiew #define CONFIG_BOOTP_BOOTPATH 558ae158cdSTsiChungLiew #define CONFIG_BOOTP_GATEWAY 568ae158cdSTsiChungLiew #define CONFIG_BOOTP_HOSTNAME 578ae158cdSTsiChungLiew 588ae158cdSTsiChungLiew /* Command line configuration */ 598ae158cdSTsiChungLiew #include <config_cmd_default.h> 608ae158cdSTsiChungLiew 618ae158cdSTsiChungLiew #define CONFIG_CMD_BOOTD 628ae158cdSTsiChungLiew #define CONFIG_CMD_CACHE 638ae158cdSTsiChungLiew #define CONFIG_CMD_DATE 648ae158cdSTsiChungLiew #define CONFIG_CMD_DHCP 658ae158cdSTsiChungLiew #define CONFIG_CMD_ELF 668ae158cdSTsiChungLiew #define CONFIG_CMD_EXT2 678ae158cdSTsiChungLiew #define CONFIG_CMD_FAT 688ae158cdSTsiChungLiew #define CONFIG_CMD_FLASH 698ae158cdSTsiChungLiew #define CONFIG_CMD_I2C 708ae158cdSTsiChungLiew #define CONFIG_CMD_IDE 718ae158cdSTsiChungLiew #define CONFIG_CMD_JFFS2 728ae158cdSTsiChungLiew #define CONFIG_CMD_MEMORY 738ae158cdSTsiChungLiew #define CONFIG_CMD_MISC 748ae158cdSTsiChungLiew #define CONFIG_CMD_MII 758ae158cdSTsiChungLiew #define CONFIG_CMD_NET 76e8ee8f3aSTsiChungLiew #undef CONFIG_CMD_PCI 778ae158cdSTsiChungLiew #define CONFIG_CMD_PING 788ae158cdSTsiChungLiew #define CONFIG_CMD_REGINFO 79a7323bbaSTsiChung Liew #define CONFIG_CMD_SPI 80922cd751STsiChung Liew #define CONFIG_CMD_SF 818ae158cdSTsiChungLiew 828ae158cdSTsiChungLiew #undef CONFIG_CMD_LOADB 838ae158cdSTsiChungLiew #undef CONFIG_CMD_LOADS 848ae158cdSTsiChungLiew 858ae158cdSTsiChungLiew /* Network configuration */ 868ae158cdSTsiChungLiew #define CONFIG_MCFFEC 878ae158cdSTsiChungLiew #ifdef CONFIG_MCFFEC 888ae158cdSTsiChungLiew # define CONFIG_NET_MULTI 1 898ae158cdSTsiChungLiew # define CONFIG_MII 1 900f3ba7e9STsiChung Liew # define CONFIG_MII_INIT 1 916d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_DISCOVER_PHY 926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_RX_ETH_BUFFER 8 936d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FAULT_ECHO_LINK_DOWN 948ae158cdSTsiChungLiew 956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FEC0_PINMUX 0 966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FEC1_PINMUX 0 976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FEC0_MIIBASE CONFIG_SYS_FEC0_IOBASE 986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FEC1_MIIBASE CONFIG_SYS_FEC0_IOBASE 998ae158cdSTsiChungLiew # define MCFFEC_TOUT_LOOP 50000 1008ae158cdSTsiChungLiew # define CONFIG_HAS_ETH1 1018ae158cdSTsiChungLiew 1028ae158cdSTsiChungLiew # define CONFIG_BOOTDELAY 1 /* autoboot after 5 seconds */ 1038ae158cdSTsiChungLiew # define CONFIG_BOOTARGS "root=/dev/mtdblock1 rw rootfstype=jffs2 ip=none mtdparts=physmap-flash.0:5M(kernel)ro,-(jffs2)" 1048ae158cdSTsiChungLiew # define CONFIG_ETHADDR 00:e0:0c:bc:e5:60 1058ae158cdSTsiChungLiew # define CONFIG_ETH1ADDR 00:e0:0c:bc:e5:61 1068ae158cdSTsiChungLiew # define CONFIG_ETHPRIME "FEC0" 1078ae158cdSTsiChungLiew # define CONFIG_IPADDR 192.162.1.2 1088ae158cdSTsiChungLiew # define CONFIG_NETMASK 255.255.255.0 1098ae158cdSTsiChungLiew # define CONFIG_SERVERIP 192.162.1.1 1108ae158cdSTsiChungLiew # define CONFIG_GATEWAYIP 192.162.1.1 1118ae158cdSTsiChungLiew # define CONFIG_OVERWRITE_ETHADDR_ONCE 1128ae158cdSTsiChungLiew 1136d0f6bcfSJean-Christophe PLAGNIOL-VILLARD /* If CONFIG_SYS_DISCOVER_PHY is not defined - hardcoded */ 1146d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # ifndef CONFIG_SYS_DISCOVER_PHY 1158ae158cdSTsiChungLiew # define FECDUPLEX FULL 1168ae158cdSTsiChungLiew # define FECSPEED _100BASET 1178ae158cdSTsiChungLiew # else 1186d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # ifndef CONFIG_SYS_FAULT_ECHO_LINK_DOWN 1196d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FAULT_ECHO_LINK_DOWN 1208ae158cdSTsiChungLiew # endif 1216d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # endif /* CONFIG_SYS_DISCOVER_PHY */ 1228ae158cdSTsiChungLiew #endif 1238ae158cdSTsiChungLiew 1248ae158cdSTsiChungLiew #define CONFIG_HOSTNAME M54455EVB 1256d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_STMICRO_BOOT 1269f751551STsiChung Liew /* ST Micro serial flash */ 1276d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOAD_ADDR2 0x40010013 1288ae158cdSTsiChungLiew #define CONFIG_EXTRA_ENV_SETTINGS \ 1298ae158cdSTsiChungLiew "netdev=eth0\0" \ 1306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "inpclk=" MK_STR(CONFIG_SYS_INPUT_CLKSRC) "\0" \ 1319f751551STsiChung Liew "loadaddr=0x40010000\0" \ 1329f751551STsiChung Liew "sbfhdr=sbfhdr.bin\0" \ 1339f751551STsiChung Liew "uboot=u-boot.bin\0" \ 1349f751551STsiChung Liew "load=tftp ${loadaddr} ${sbfhdr};" \ 1356d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "tftp " MK_STR(CONFIG_SYS_LOAD_ADDR2) " ${uboot} \0" \ 1368ae158cdSTsiChungLiew "upd=run load; run prog\0" \ 1379f751551STsiChung Liew "prog=sf probe 0:1 10000 1;" \ 1389f751551STsiChung Liew "sf erase 0 30000;" \ 1399f751551STsiChung Liew "sf write ${loadaddr} 0 0x30000;" \ 1408ae158cdSTsiChungLiew "save\0" \ 1418ae158cdSTsiChungLiew "" 1429f751551STsiChung Liew #else 1439f751551STsiChung Liew /* Atmel and Intel */ 1446d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_ATMEL_BOOT 1456d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_UBOOT_END 0x0403FFFF 1466d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #elif defined(CONFIG_SYS_INTEL_BOOT) 1476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_UBOOT_END 0x3FFFF 1489f751551STsiChung Liew #endif 1499f751551STsiChung Liew #define CONFIG_EXTRA_ENV_SETTINGS \ 1509f751551STsiChung Liew "netdev=eth0\0" \ 1516d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "inpclk=" MK_STR(CONFIG_SYS_INPUT_CLKSRC) "\0" \ 1529f751551STsiChung Liew "loadaddr=0x40010000\0" \ 1539f751551STsiChung Liew "uboot=u-boot.bin\0" \ 1549f751551STsiChung Liew "load=tftp ${loadaddr} ${uboot}\0" \ 1559f751551STsiChung Liew "upd=run load; run prog\0" \ 1566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "prog=prot off " MK_STR(CONFIG_SYS_FLASH_BASE) \ 1576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD " " MK_STR(CONFIG_SYS_UBOOT_END) ";" \ 1586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "era " MK_STR(CONFIG_SYS_FLASH_BASE) " " \ 1596d0f6bcfSJean-Christophe PLAGNIOL-VILLARD MK_STR(CONFIG_SYS_UBOOT_END) ";" \ 1606d0f6bcfSJean-Christophe PLAGNIOL-VILLARD "cp.b ${loadaddr} " MK_STR(CONFIG_SYS_FLASH_BASE) \ 1619f751551STsiChung Liew " ${filesize}; save\0" \ 1629f751551STsiChung Liew "" 1639f751551STsiChung Liew #endif 1648ae158cdSTsiChungLiew 1658ae158cdSTsiChungLiew /* ATA configuration */ 1668ae158cdSTsiChungLiew #define CONFIG_ISO_PARTITION 1678ae158cdSTsiChungLiew #define CONFIG_DOS_PARTITION 1688ae158cdSTsiChungLiew #define CONFIG_IDE_RESET 1 1698ae158cdSTsiChungLiew #define CONFIG_IDE_PREINIT 1 1708ae158cdSTsiChungLiew #define CONFIG_ATAPI 1718ae158cdSTsiChungLiew #undef CONFIG_LBA48 1728ae158cdSTsiChungLiew 1736d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IDE_MAXBUS 1 1746d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IDE_MAXDEVICE 2 1758ae158cdSTsiChungLiew 1766d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_BASE_ADDR 0x90000000 1776d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_IDE0_OFFSET 0 1788ae158cdSTsiChungLiew 1796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_DATA_OFFSET 0xA0 /* Offset for data I/O */ 1806d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_REG_OFFSET 0xA0 /* Offset for normal register accesses */ 1816d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_ALT_OFFSET 0xC0 /* Offset for alternate registers */ 1826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATA_STRIDE 4 /* Interval between registers */ 1838ae158cdSTsiChungLiew 1848ae158cdSTsiChungLiew /* Realtime clock */ 1858ae158cdSTsiChungLiew #define CONFIG_MCFRTC 1868ae158cdSTsiChungLiew #undef RTC_DEBUG 1876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_RTC_OSCILLATOR (32 * CONFIG_SYS_HZ) 1888ae158cdSTsiChungLiew 1898ae158cdSTsiChungLiew /* Timer */ 1908ae158cdSTsiChungLiew #define CONFIG_MCFTMR 1918ae158cdSTsiChungLiew #undef CONFIG_MCFPIT 1928ae158cdSTsiChungLiew 1938ae158cdSTsiChungLiew /* I2c */ 1948ae158cdSTsiChungLiew #define CONFIG_FSL_I2C 1958ae158cdSTsiChungLiew #define CONFIG_HARD_I2C /* I2C with hardware support */ 1968ae158cdSTsiChungLiew #undef CONFIG_SOFT_I2C /* I2C bit-banged */ 1976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_SPEED 80000 /* I2C speed and slave address */ 1986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_SLAVE 0x7F 1996d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_OFFSET 0x58000 2006d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_IMMR CONFIG_SYS_MBAR 2018ae158cdSTsiChungLiew 202bae61eefSTsiChung Liew /* DSPI and Serial Flash */ 203ee0a8462STsiChung Liew #define CONFIG_CF_SPI 204bae61eefSTsiChung Liew #define CONFIG_CF_DSPI 205a7323bbaSTsiChung Liew #define CONFIG_HARD_SPI 2066d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SBFHDR_SIZE 0x13 207a7323bbaSTsiChung Liew #ifdef CONFIG_CMD_SPI 208922cd751STsiChung Liew # define CONFIG_SPI_FLASH 209922cd751STsiChung Liew # define CONFIG_SPI_FLASH_STMICRO 210922cd751STsiChung Liew 211ee0a8462STsiChung Liew # define CONFIG_SYS_DSPI_CTAR0 (DSPI_CTAR_TRSZ(7) | \ 212ee0a8462STsiChung Liew DSPI_CTAR_PCSSCK_1CLK | \ 213ee0a8462STsiChung Liew DSPI_CTAR_PASC(0) | \ 214ee0a8462STsiChung Liew DSPI_CTAR_PDT(0) | \ 215ee0a8462STsiChung Liew DSPI_CTAR_CSSCK(0) | \ 216ee0a8462STsiChung Liew DSPI_CTAR_ASC(0) | \ 217ee0a8462STsiChung Liew DSPI_CTAR_DT(1)) 218a7323bbaSTsiChung Liew #endif 219bae61eefSTsiChung Liew 2208ae158cdSTsiChungLiew /* PCI */ 221e8ee8f3aSTsiChungLiew #ifdef CONFIG_CMD_PCI 2228ae158cdSTsiChungLiew #define CONFIG_PCI 1 2232e72ad06STsiChungLiew #define CONFIG_PCI_PNP 1 224f33fca22STsiChung Liew #define CONFIG_PCIAUTO_SKIP_HOST_BRIDGE 1 2252e72ad06STsiChungLiew 2266d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_CACHE_LINE_SIZE 4 2278ae158cdSTsiChungLiew 2286d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_BUS 0xA0000000 2296d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_PHYS CONFIG_SYS_PCI_MEM_BUS 2306d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_MEM_SIZE 0x10000000 2318ae158cdSTsiChungLiew 2326d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_BUS 0xB1000000 2336d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_PHYS CONFIG_SYS_PCI_IO_BUS 2346d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_IO_SIZE 0x01000000 2358ae158cdSTsiChungLiew 2366d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_CFG_BUS 0xB0000000 2376d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_CFG_PHYS CONFIG_SYS_PCI_CFG_BUS 2386d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PCI_CFG_SIZE 0x01000000 239e8ee8f3aSTsiChungLiew #endif 2408ae158cdSTsiChungLiew 2418ae158cdSTsiChungLiew /* FPGA - Spartan 2 */ 2428ae158cdSTsiChungLiew /* experiment 2436d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_FPGA CONFIG_SYS_SPARTAN3 2448ae158cdSTsiChungLiew #define CONFIG_FPGA_COUNT 1 2456d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FPGA_PROG_FEEDBACK 2466d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FPGA_CHECK_CTRLC 2478ae158cdSTsiChungLiew */ 2488ae158cdSTsiChungLiew 2498ae158cdSTsiChungLiew /* Input, PCI, Flexbus, and VCO */ 2508ae158cdSTsiChungLiew #define CONFIG_EXTRA_CLOCK 2518ae158cdSTsiChungLiew 2529f751551STsiChung Liew #define CONFIG_PRAM 2048 /* 2048 KB */ 2538ae158cdSTsiChungLiew 2546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PROMPT "-> " 2556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LONGHELP /* undef to save memory */ 2568ae158cdSTsiChungLiew 2578ae158cdSTsiChungLiew #if defined(CONFIG_CMD_KGDB) 2586d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */ 2598ae158cdSTsiChungLiew #else 2606d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */ 2618ae158cdSTsiChungLiew #endif 2626d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) /* Print Buffer Size */ 2636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MAXARGS 16 /* max number of command args */ 2646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */ 2658ae158cdSTsiChungLiew 2666d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x10000) 2678ae158cdSTsiChungLiew 2686d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HZ 1000 2698ae158cdSTsiChungLiew 2706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MBAR 0xFC000000 2718ae158cdSTsiChungLiew 2728ae158cdSTsiChungLiew /* 2738ae158cdSTsiChungLiew * Low Level Configuration Settings 2748ae158cdSTsiChungLiew * (address mappings, register initial values, etc.) 2758ae158cdSTsiChungLiew * You should know what you are doing if you make changes here. 2768ae158cdSTsiChungLiew */ 2778ae158cdSTsiChungLiew 2788ae158cdSTsiChungLiew /*----------------------------------------------------------------------- 2798ae158cdSTsiChungLiew * Definitions for initial stack pointer and data area (in DPRAM) 2808ae158cdSTsiChungLiew */ 2816d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_RAM_ADDR 0x80000000 2826d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_RAM_END 0x8000 /* End of used area in internal SRAM */ 2836d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_RAM_CTRL 0x221 2846d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_GBL_DATA_SIZE 128 /* size in bytes reserved for initial data */ 2856d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_GBL_DATA_OFFSET ((CONFIG_SYS_INIT_RAM_END - CONFIG_SYS_GBL_DATA_SIZE) - 32) 2866d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET 2876d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SBFHDR_DATA_OFFSET (CONFIG_SYS_INIT_RAM_END - 32) 2888ae158cdSTsiChungLiew 2898ae158cdSTsiChungLiew /*----------------------------------------------------------------------- 2908ae158cdSTsiChungLiew * Start addresses for the final memory configuration 2918ae158cdSTsiChungLiew * (Set up by the startup code) 2926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD * Please note that CONFIG_SYS_SDRAM_BASE _must_ start at 0 2938ae158cdSTsiChungLiew */ 2946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_BASE 0x40000000 2956d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_BASE1 0x48000000 2966d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_SIZE 256 /* SDRAM size in MB */ 2976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_CFG1 0x65311610 2986d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_CFG2 0x59670000 2996d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_CTRL 0xEA0B2000 3006d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_EMOD 0x40010000 3016d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_MODE 0x00010033 3026d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_SDRAM_DRV_STRENGTH 0xAA 3038ae158cdSTsiChungLiew 3046d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_START CONFIG_SYS_SDRAM_BASE + 0x400 3056d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_END ((CONFIG_SYS_SDRAM_SIZE - 3) << 20) 3068ae158cdSTsiChungLiew 3079f751551STsiChung Liew #ifdef CONFIG_CF_SBF 3086d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_MONITOR_BASE (TEXT_BASE + 0x400) 3099f751551STsiChung Liew #else 3106d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_MONITOR_BASE (CONFIG_SYS_FLASH_BASE + 0x400) 3119f751551STsiChung Liew #endif 3126d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_BOOTPARAMS_LEN 64*1024 3136d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MONITOR_LEN (256 << 10) /* Reserve 256 kB for Monitor */ 3146d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MALLOC_LEN (128 << 10) /* Reserve 128 kB for malloc() */ 3158ae158cdSTsiChungLiew 3168ae158cdSTsiChungLiew /* 3178ae158cdSTsiChungLiew * For booting Linux, the board info and command line data 3188ae158cdSTsiChungLiew * have to be in the first 8 MB of memory, since this is 3198ae158cdSTsiChungLiew * the maximum mapped by the Linux kernel during initialization ?? 3208ae158cdSTsiChungLiew */ 3218ae158cdSTsiChungLiew /* Initial Memory map for Linux */ 3226d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_BOOTMAPSZ (CONFIG_SYS_SDRAM_BASE + (CONFIG_SYS_SDRAM_SIZE << 20)) 3238ae158cdSTsiChungLiew 3249f751551STsiChung Liew /* 3259f751551STsiChung Liew * Configuration for environment 3268ae158cdSTsiChungLiew * Environment is embedded in u-boot in the second sector of the flash 3278ae158cdSTsiChungLiew */ 3289f751551STsiChung Liew #ifdef CONFIG_CF_SBF 3290b5099a8SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_IS_IN_SPI_FLASH 3300e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SPI_CS 1 3319f751551STsiChung Liew #else 3325a1aceb0SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_IS_IN_FLASH 1 3339f751551STsiChung Liew #endif 3349f751551STsiChung Liew #undef CONFIG_ENV_OVERWRITE 3358ae158cdSTsiChungLiew 3368ae158cdSTsiChungLiew /*----------------------------------------------------------------------- 3378ae158cdSTsiChungLiew * FLASH organization 3388ae158cdSTsiChungLiew */ 3396d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_STMICRO_BOOT 340ee0a8462STsiChung Liew # define CONFIG_SYS_FLASH_BASE CONFIG_SYS_CS0_BASE 341ee0a8462STsiChung Liew # define CONFIG_SYS_FLASH0_BASE CONFIG_SYS_CS1_BASE 3420e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_OFFSET 0x30000 3430e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SIZE 0x2000 3440e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SECT_SIZE 0x10000 3459f751551STsiChung Liew #endif 3466d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_ATMEL_BOOT 3476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_BASE CONFIG_SYS_CS0_BASE 3486d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH0_BASE CONFIG_SYS_CS0_BASE 3496d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH1_BASE CONFIG_SYS_CS1_BASE 3506d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_ADDR (CONFIG_SYS_FLASH_BASE + 0x4000) 3510e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SECT_SIZE 0x2000 3529f751551STsiChung Liew #endif 3536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_INTEL_BOOT 3546d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_BASE CONFIG_SYS_CS0_BASE 3556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH0_BASE CONFIG_SYS_CS0_BASE 3566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH1_BASE CONFIG_SYS_CS1_BASE 3576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_ADDR (CONFIG_SYS_FLASH_BASE + 0x40000) 3580e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SIZE 0x2000 3590e8d1586SJean-Christophe PLAGNIOL-VILLARD # define CONFIG_ENV_SECT_SIZE 0x20000 3608ae158cdSTsiChungLiew #endif 3618ae158cdSTsiChungLiew 3626d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_CFI 3636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_FLASH_CFI 3648ae158cdSTsiChungLiew 36500b1883aSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_FLASH_CFI_DRIVER 1 366bbf6bbffSTsiChung Liew # define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1 3676d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_SIZE 0x1000000 /* Max size that the board might have */ 3686d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_CFI_WIDTH FLASH_CFI_8BIT 3696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_MAX_FLASH_BANKS 2 /* max number of memory banks */ 3706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_MAX_FLASH_SECT 137 /* max number of sectors on one chip */ 3716d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_PROTECTION /* "Real" (hardware) sectors protection */ 3726d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_CHECKSUM 3736d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_CS0_BASE, CONFIG_SYS_CS1_BASE } 374b2d022d1STsiChung Liew # define CONFIG_FLASH_CFI_LEGACY 3758ae158cdSTsiChungLiew 376b2d022d1STsiChung Liew #ifdef CONFIG_FLASH_CFI_LEGACY 3776d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_ATMEL_REGION 4 3786d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_ATMEL_TOTALSECT 11 3796d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_ATMEL_SECT {1, 2, 1, 7} 3806d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_SYS_ATMEL_SECTSZ {0x4000, 0x2000, 0x8000, 0x10000} 381b2d022d1STsiChung Liew #endif 382b2d022d1STsiChung Liew #endif 3838ae158cdSTsiChungLiew 3848ae158cdSTsiChungLiew /* 3858ae158cdSTsiChungLiew * This is setting for JFFS2 support in u-boot. 3868ae158cdSTsiChungLiew * NOTE: Enable CONFIG_CMD_JFFS2 for JFFS2 support. 3878ae158cdSTsiChungLiew */ 3889f751551STsiChung Liew #ifdef CONFIG_CMD_JFFS2 3899f751551STsiChung Liew #ifdef CF_STMICRO_BOOT 3909f751551STsiChung Liew # define CONFIG_JFFS2_DEV "nor1" 3919f751551STsiChung Liew # define CONFIG_JFFS2_PART_SIZE 0x01000000 3926d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_JFFS2_PART_OFFSET (CONFIG_SYS_FLASH2_BASE + 0x500000) 3939f751551STsiChung Liew #endif 3946d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_ATMEL_BOOT 395e8ee8f3aSTsiChungLiew # define CONFIG_JFFS2_DEV "nor1" 3968ae158cdSTsiChungLiew # define CONFIG_JFFS2_PART_SIZE 0x01000000 3976d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_JFFS2_PART_OFFSET (CONFIG_SYS_FLASH1_BASE + 0x500000) 3989f751551STsiChung Liew #endif 3996d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #ifdef CONFIG_SYS_INTEL_BOOT 4008ae158cdSTsiChungLiew # define CONFIG_JFFS2_DEV "nor0" 4018ae158cdSTsiChungLiew # define CONFIG_JFFS2_PART_SIZE (0x01000000 - 0x500000) 4026d0f6bcfSJean-Christophe PLAGNIOL-VILLARD # define CONFIG_JFFS2_PART_OFFSET (CONFIG_SYS_FLASH0_BASE + 0x500000) 4038ae158cdSTsiChungLiew #endif 4049f751551STsiChung Liew #endif 4058ae158cdSTsiChungLiew 4068ae158cdSTsiChungLiew /*----------------------------------------------------------------------- 4078ae158cdSTsiChungLiew * Cache Configuration 4088ae158cdSTsiChungLiew */ 4096d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CACHELINE_SIZE 16 410*dd9f054eSTsiChung Liew 411*dd9f054eSTsiChung Liew #define ICACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \ 412*dd9f054eSTsiChung Liew CONFIG_SYS_INIT_RAM_END - 8) 413*dd9f054eSTsiChung Liew #define DCACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \ 414*dd9f054eSTsiChung Liew CONFIG_SYS_INIT_RAM_END - 4) 415*dd9f054eSTsiChung Liew #define CONFIG_SYS_ICACHE_INV (CF_CACR_BCINVA + CF_CACR_ICINVA) 416*dd9f054eSTsiChung Liew #define CONFIG_SYS_DCACHE_INV (CF_CACR_DCINVA) 417*dd9f054eSTsiChung Liew #define CONFIG_SYS_CACHE_ACR2 (CONFIG_SYS_SDRAM_BASE | \ 418*dd9f054eSTsiChung Liew CF_ADDRMASK(CONFIG_SYS_SDRAM_SIZE) | \ 419*dd9f054eSTsiChung Liew CF_ACR_EN | CF_ACR_SM_ALL) 420*dd9f054eSTsiChung Liew #define CONFIG_SYS_CACHE_ICACR (CF_CACR_BEC | CF_CACR_IEC | \ 421*dd9f054eSTsiChung Liew CF_CACR_ICINVA | CF_CACR_EUSP) 422*dd9f054eSTsiChung Liew #define CONFIG_SYS_CACHE_DCACR ((CONFIG_SYS_CACHE_ICACR | \ 423*dd9f054eSTsiChung Liew CF_CACR_DEC | CF_CACR_DDCM_P | \ 424*dd9f054eSTsiChung Liew CF_CACR_DCINVA) & ~CF_CACR_ICINVA) 4258ae158cdSTsiChungLiew 4268ae158cdSTsiChungLiew /*----------------------------------------------------------------------- 4278ae158cdSTsiChungLiew * Memory bank definitions 4288ae158cdSTsiChungLiew */ 4298ae158cdSTsiChungLiew /* 4308ae158cdSTsiChungLiew * CS0 - NOR Flash 1, 2, 4, or 8MB 4318ae158cdSTsiChungLiew * CS1 - CompactFlash and registers 4328ae158cdSTsiChungLiew * CS2 - CPLD 4338ae158cdSTsiChungLiew * CS3 - FPGA 4348ae158cdSTsiChungLiew * CS4 - Available 4358ae158cdSTsiChungLiew * CS5 - Available 4368ae158cdSTsiChungLiew */ 4378ae158cdSTsiChungLiew 4386d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #if defined(CONFIG_SYS_ATMEL_BOOT) || defined(CONFIG_SYS_STMICRO_BOOT) 4398ae158cdSTsiChungLiew /* Atmel Flash */ 4406d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_BASE 0x04000000 4416d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_MASK 0x00070001 4426d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_CTRL 0x00001140 4438ae158cdSTsiChungLiew /* Intel Flash */ 4446d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_BASE 0x00000000 4456d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_MASK 0x01FF0001 4466d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_CTRL 0x00000D60 4478ae158cdSTsiChungLiew 4486d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATMEL_BASE CONFIG_SYS_CS0_BASE 4498ae158cdSTsiChungLiew #else 4508ae158cdSTsiChungLiew /* Intel Flash */ 4516d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_BASE 0x00000000 4526d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_MASK 0x01FF0001 4536d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS0_CTRL 0x00000D60 4548ae158cdSTsiChungLiew /* Atmel Flash */ 4556d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_BASE 0x04000000 4566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_MASK 0x00070001 4576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS1_CTRL 0x00001140 4588ae158cdSTsiChungLiew 4596d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_ATMEL_BASE CONFIG_SYS_CS1_BASE 4608ae158cdSTsiChungLiew #endif 4618ae158cdSTsiChungLiew 4628ae158cdSTsiChungLiew /* CPLD */ 4636d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS2_BASE 0x08000000 4646d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS2_MASK 0x00070001 4656d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS2_CTRL 0x003f1140 4668ae158cdSTsiChungLiew 4678ae158cdSTsiChungLiew /* FPGA */ 4686d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS3_BASE 0x09000000 4696d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS3_MASK 0x00070001 4706d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_CS3_CTRL 0x00000020 4718ae158cdSTsiChungLiew 472e8ee8f3aSTsiChungLiew #endif /* _M54455EVB_H */ 473