15ad86216SSascha Hauer /* 25ad86216SSascha Hauer * (C) Copyright 2004 35ad86216SSascha Hauer * Texas Instruments. 45ad86216SSascha Hauer * Richard Woodruff <r-woodruff2@ti.com> 55ad86216SSascha Hauer * Kshitij Gupta <kshitij@ti.com> 65ad86216SSascha Hauer * 77064122cSMagnus Lilja * Configuration settings for the phyCORE-i.MX31 board. 85ad86216SSascha Hauer * 91a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 105ad86216SSascha Hauer */ 115ad86216SSascha Hauer 125ad86216SSascha Hauer #ifndef __CONFIG_H 135ad86216SSascha Hauer #define __CONFIG_H 145ad86216SSascha Hauer 15953ee4d0SFabio Estevam #include <asm/arch/imx-regs.h> 16953ee4d0SFabio Estevam 175ad86216SSascha Hauer /* High Level Configuration Options */ 186ac1c903SAnatolij Gustschin #define CONFIG_ARM1136 /* This is an arm1136 CPU core */ 196ac1c903SAnatolij Gustschin #define CONFIG_MX31 /* in a mx31 */ 205ad86216SSascha Hauer #define CONFIG_MX31_CLK32 32000 215ad86216SSascha Hauer 225ad86216SSascha Hauer #define CONFIG_DISPLAY_CPUINFO 235ad86216SSascha Hauer #define CONFIG_DISPLAY_BOARDINFO 245ad86216SSascha Hauer 256ac1c903SAnatolij Gustschin #define CONFIG_CMDLINE_TAG /* enable passing of ATAGs */ 266ac1c903SAnatolij Gustschin #define CONFIG_SETUP_MEMORY_TAGS 276ac1c903SAnatolij Gustschin #define CONFIG_INITRD_TAG 285ad86216SSascha Hauer 295ad86216SSascha Hauer /* 305ad86216SSascha Hauer * Size of malloc() pool 315ad86216SSascha Hauer */ 3262a22dcaSHelmut Raiger #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 512 * 1024) 335ad86216SSascha Hauer 345ad86216SSascha Hauer /* 355ad86216SSascha Hauer * Hardware drivers 365ad86216SSascha Hauer */ 375ad86216SSascha Hauer 38*b089d039Strem #define CONFIG_SYS_I2C 39*b089d039Strem #define CONFIG_SYS_I2C_MXC 40*b089d039Strem #define CONFIG_SYS_SPD_BUS_NUM 1 /* I2C2 */ 41de6f604dSTroy Kisky #define CONFIG_SYS_I2C_CLK_OFFSET I2C2_CLK_OFFSET 425ad86216SSascha Hauer 436ac1c903SAnatolij Gustschin #define CONFIG_MXC_UART 4440f6fffeSStefano Babic #define CONFIG_MXC_UART_BASE UART1_BASE 455ad86216SSascha Hauer 465ad86216SSascha Hauer /* allow to overwrite serial and ethaddr */ 475ad86216SSascha Hauer #define CONFIG_ENV_OVERWRITE 485ad86216SSascha Hauer #define CONFIG_CONS_INDEX 1 495ad86216SSascha Hauer #define CONFIG_BAUDRATE 115200 505ad86216SSascha Hauer 515ad86216SSascha Hauer /*********************************************************** 525ad86216SSascha Hauer * Command definition 535ad86216SSascha Hauer ***********************************************************/ 545ad86216SSascha Hauer 555ad86216SSascha Hauer #include <config_cmd_default.h> 565ad86216SSascha Hauer 575ad86216SSascha Hauer #define CONFIG_CMD_PING 585ad86216SSascha Hauer #define CONFIG_CMD_EEPROM 595ad86216SSascha Hauer #define CONFIG_CMD_I2C 605ad86216SSascha Hauer 615ad86216SSascha Hauer #define CONFIG_BOOTDELAY 3 625ad86216SSascha Hauer 636ac1c903SAnatolij Gustschin #define MTDPARTS_DEFAULT "mtdparts=physmap-flash.0:128k(uboot)ro," \ 646ac1c903SAnatolij Gustschin "1536k(kernel),-(root)" 655ad86216SSascha Hauer 665ad86216SSascha Hauer #define CONFIG_NETMASK 255.255.255.0 675ad86216SSascha Hauer #define CONFIG_IPADDR 192.168.23.168 685ad86216SSascha Hauer #define CONFIG_SERVERIP 192.168.23.2 695ad86216SSascha Hauer 705ad86216SSascha Hauer #define CONFIG_EXTRA_ENV_SETTINGS \ 715ad86216SSascha Hauer "bootargs_base=setenv bootargs console=ttySMX0,115200\0" \ 726ac1c903SAnatolij Gustschin "bootargs_nfs=setenv bootargs $(bootargs) root=/dev/nfs " \ 736ac1c903SAnatolij Gustschin "ip=dhcp nfsroot=$(serverip):$(nfsrootfs),v3,tcp\0" \ 746ac1c903SAnatolij Gustschin "bootargs_flash=setenv bootargs $(bootargs) " \ 756ac1c903SAnatolij Gustschin "root=/dev/mtdblock2 rootfstype=jffs2\0" \ 766ac1c903SAnatolij Gustschin "bootargs_mtd=setenv bootargs $(bootargs) $(mtdparts)\0" \ 775ad86216SSascha Hauer "bootcmd=run bootcmd_net\0" \ 786ac1c903SAnatolij Gustschin "bootcmd_net=run bootargs_base bootargs_mtd bootargs_nfs;" \ 796ac1c903SAnatolij Gustschin "tftpboot 0x80000000 $(uimage);bootm\0" \ 806ac1c903SAnatolij Gustschin "bootcmd_flash=run bootargs_base bootargs_mtd bootargs_flash;" \ 816ac1c903SAnatolij Gustschin "bootm 0x80000000\0" \ 825ad86216SSascha Hauer "unlock=yes\0" \ 835ad86216SSascha Hauer "mtdparts=" MTDPARTS_DEFAULT "\0" \ 846ac1c903SAnatolij Gustschin "prg_uboot=tftpboot 0x80000000 $(uboot);" \ 856ac1c903SAnatolij Gustschin "protect off 0xa0000000 +0x20000;" \ 866ac1c903SAnatolij Gustschin "erase 0xa0000000 +0x20000;" \ 876ac1c903SAnatolij Gustschin "cp.b 0x80000000 0xa0000000 $(filesize)\0" \ 886ac1c903SAnatolij Gustschin "prg_kernel=tftpboot 0x80000000 $(uimage);" \ 896ac1c903SAnatolij Gustschin "erase 0xa0040000 +0x180000;" \ 906ac1c903SAnatolij Gustschin "cp.b 0x80000000 0xa0040000 $(filesize)\0" \ 916ac1c903SAnatolij Gustschin "prg_jffs2=tftpboot 0x80000000 $(jffs2);" \ 926ac1c903SAnatolij Gustschin "erase 0xa01c0000 0xa1ffffff;" \ 936ac1c903SAnatolij Gustschin "cp.b 0x80000000 0xa01c0000 $(filesize)\0" \ 946ac1c903SAnatolij Gustschin "videomode=video=ctfb:x:240,y:320,depth:16,mode:0," \ 956ac1c903SAnatolij Gustschin "pclk:185925,le:9,ri:17,up:7,lo:10,hs:1,vs:1," \ 966ac1c903SAnatolij Gustschin "sync:1241513985,vmode:0\0" 975ad86216SSascha Hauer 985ad86216SSascha Hauer 996ac1c903SAnatolij Gustschin #define CONFIG_SMC911X 100736fead8SBen Warren #define CONFIG_SMC911X_BASE 0xa8000000 1016ac1c903SAnatolij Gustschin #define CONFIG_SMC911X_32_BIT 1025ad86216SSascha Hauer 1035ad86216SSascha Hauer /* 1045ad86216SSascha Hauer * Miscellaneous configurable options 1055ad86216SSascha Hauer */ 1066d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LONGHELP /* undef to save memory */ 1076d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_PROMPT "uboot> " 1086ac1c903SAnatolij Gustschin /* Console I/O Buffer Size */ 1096ac1c903SAnatolij Gustschin #define CONFIG_SYS_CBSIZE 256 1105ad86216SSascha Hauer /* Print Buffer Size */ 1116ac1c903SAnatolij Gustschin #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \ 1126ac1c903SAnatolij Gustschin sizeof(CONFIG_SYS_PROMPT) + 16) 1136ac1c903SAnatolij Gustschin /* max number of command args */ 1146ac1c903SAnatolij Gustschin #define CONFIG_SYS_MAXARGS 16 1156ac1c903SAnatolij Gustschin /* Boot Argument Buffer Size */ 1166ac1c903SAnatolij Gustschin #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 1175ad86216SSascha Hauer 1186d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_START 0 /* memtest works on */ 1196d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_MEMTEST_END 0x10000 1205ad86216SSascha Hauer 1216d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_LOAD_ADDR 0 /* default load address */ 1225ad86216SSascha Hauer 1236d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_HZ 1000 1245ad86216SSascha Hauer 1256ac1c903SAnatolij Gustschin #define CONFIG_CMDLINE_EDITING 1265ad86216SSascha Hauer 1276ac1c903SAnatolij Gustschin /* 1285ad86216SSascha Hauer * Physical Memory Map 1295ad86216SSascha Hauer */ 1305ad86216SSascha Hauer #define CONFIG_NR_DRAM_BANKS 1 1315ad86216SSascha Hauer #define PHYS_SDRAM_1 0x80000000 1325ad86216SSascha Hauer #define PHYS_SDRAM_1_SIZE (128 * 1024 * 1024) 133953ee4d0SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F 134953ee4d0SFabio Estevam #define CONFIG_SYS_TEXT_BASE 0xA0000000 135953ee4d0SFabio Estevam 136953ee4d0SFabio Estevam #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1 137953ee4d0SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR 138953ee4d0SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE 139953ee4d0SFabio Estevam #define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - \ 140953ee4d0SFabio Estevam GENERATED_GBL_DATA_SIZE) 141953ee4d0SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INIT_RAM_ADDR + \ 142953ee4d0SFabio Estevam CONFIG_SYS_GBL_DATA_OFFSET) 1435ad86216SSascha Hauer 1446ac1c903SAnatolij Gustschin /* 1455ad86216SSascha Hauer * FLASH and environment organization 1465ad86216SSascha Hauer */ 1476d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_FLASH_BASE 0xa0000000 1486ac1c903SAnatolij Gustschin #define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max # of memory banks */ 1496ac1c903SAnatolij Gustschin #define CONFIG_SYS_MAX_FLASH_SECT 259 /* max # of sectors/chip */ 1506ac1c903SAnatolij Gustschin /* Monitor at beginning of flash */ 1516ac1c903SAnatolij Gustschin #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_FLASH_BASE 1525ad86216SSascha Hauer 1536ac1c903SAnatolij Gustschin #define CONFIG_ENV_IS_IN_EEPROM 1546ac1c903SAnatolij Gustschin #define CONFIG_ENV_OFFSET 0x00 /* env. starts here */ 1550e8d1586SJean-Christophe PLAGNIOL-VILLARD #define CONFIG_ENV_SIZE 4096 1566d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_I2C_EEPROM_ADDR 0x52 1576d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 5 /* 5 bits = 32 octets */ 1586ac1c903SAnatolij Gustschin #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 10 /* 10 ms delay */ 1596ac1c903SAnatolij Gustschin #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 2 /* byte addr. lenght */ 1605ad86216SSascha Hauer 1616ac1c903SAnatolij Gustschin /* 1625ad86216SSascha Hauer * CFI FLASH driver setup 1635ad86216SSascha Hauer */ 1646ac1c903SAnatolij Gustschin #define CONFIG_SYS_FLASH_CFI /* Flash memory is CFI compliant */ 1656ac1c903SAnatolij Gustschin #define CONFIG_FLASH_CFI_DRIVER /* Use drivers/mtd/cfi_flash.c */ 1666ac1c903SAnatolij Gustschin #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE /* buffered writes (~10x faster) */ 1676ac1c903SAnatolij Gustschin #define CONFIG_SYS_FLASH_PROTECTION /* Use hardware sector protection */ 1685ad86216SSascha Hauer 1696ac1c903SAnatolij Gustschin /* 1706ac1c903SAnatolij Gustschin * Timeout for Flash Erase and Flash Write 1716ac1c903SAnatolij Gustschin * timeout values are in ticks 1726ac1c903SAnatolij Gustschin */ 1736ac1c903SAnatolij Gustschin #define CONFIG_SYS_FLASH_ERASE_TOUT (100*CONFIG_SYS_HZ) 1746ac1c903SAnatolij Gustschin #define CONFIG_SYS_FLASH_WRITE_TOUT (100*CONFIG_SYS_HZ) 1755ad86216SSascha Hauer 1765ad86216SSascha Hauer /* 1775ad86216SSascha Hauer * JFFS2 partitions 1785ad86216SSascha Hauer */ 17968d7d651SStefan Roese #undef CONFIG_CMD_MTDPARTS 1805ad86216SSascha Hauer #define CONFIG_JFFS2_DEV "nor0" 1815ad86216SSascha Hauer 182a2bb7105SGuennadi Liakhovetski /* EET platform additions */ 183a2bb7105SGuennadi Liakhovetski #ifdef CONFIG_IMX31_PHYCORE_EET 1849660e442SHelmut Raiger #define CONFIG_BOARD_LATE_INIT 185a2bb7105SGuennadi Liakhovetski 186c4ea1424SStefano Babic #define CONFIG_MXC_GPIO 187a2bb7105SGuennadi Liakhovetski 1886ac1c903SAnatolij Gustschin #define CONFIG_HARD_SPI 1896ac1c903SAnatolij Gustschin #define CONFIG_MXC_SPI 190a2bb7105SGuennadi Liakhovetski #define CONFIG_CMD_SPI 191a2bb7105SGuennadi Liakhovetski 1926ac1c903SAnatolij Gustschin #define CONFIG_S6E63D6 193a2bb7105SGuennadi Liakhovetski 19462a22dcaSHelmut Raiger #define CONFIG_VIDEO 19562a22dcaSHelmut Raiger #define CONFIG_CFB_CONSOLE 19662a22dcaSHelmut Raiger #define CONFIG_VIDEO_MX3 19762a22dcaSHelmut Raiger #define CONFIG_VIDEO_LOGO 19862a22dcaSHelmut Raiger #define CONFIG_VIDEO_SW_CURSOR 19962a22dcaSHelmut Raiger #define CONFIG_VGA_AS_SINGLE_DEVICE 20062a22dcaSHelmut Raiger #define CONFIG_SYS_CONSOLE_IS_IN_ENV 20162a22dcaSHelmut Raiger #define CONFIG_SPLASH_SCREEN 20262a22dcaSHelmut Raiger #define CONFIG_CMD_BMP 20362a22dcaSHelmut Raiger #define CONFIG_BMP_16BPP 204a2bb7105SGuennadi Liakhovetski #endif 205a2bb7105SGuennadi Liakhovetski 2065ad86216SSascha Hauer #endif /* __CONFIG_H */ 207