181ca8409SOtavio Salvador /* 281ca8409SOtavio Salvador * Freescale i.MX23 EVK board config 381ca8409SOtavio Salvador * 481ca8409SOtavio Salvador * Copyright (C) 2013 Otavio Salvador <otavio@ossystems.com.br> 581ca8409SOtavio Salvador * on behalf of O.S. Systems Software LTDA. 681ca8409SOtavio Salvador * 781ca8409SOtavio Salvador * This program is free software; you can redistribute it and/or modify 881ca8409SOtavio Salvador * it under the terms of the GNU General Public License as published by 981ca8409SOtavio Salvador * the Free Software Foundation; either version 2 of the License, or 1081ca8409SOtavio Salvador * (at your option) any later version. 1181ca8409SOtavio Salvador * 1281ca8409SOtavio Salvador * This program is distributed in the hope that it will be useful, 1381ca8409SOtavio Salvador * but WITHOUT ANY WARRANTY; without even the implied warranty of 1481ca8409SOtavio Salvador * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1581ca8409SOtavio Salvador * GNU General Public License for more details. 1681ca8409SOtavio Salvador * 1781ca8409SOtavio Salvador * You should have received a copy of the GNU General Public License 1881ca8409SOtavio Salvador * along with this program; if not, write to the Free Software 1981ca8409SOtavio Salvador * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 2081ca8409SOtavio Salvador * 2181ca8409SOtavio Salvador */ 2281ca8409SOtavio Salvador #ifndef __MX23EVK_CONFIG_H__ 2381ca8409SOtavio Salvador #define __MX23EVK_CONFIG_H__ 2481ca8409SOtavio Salvador 2581ca8409SOtavio Salvador /* SoC configurations */ 2681ca8409SOtavio Salvador #define CONFIG_MX23 /* i.MX23 SoC */ 2781ca8409SOtavio Salvador 2881ca8409SOtavio Salvador #include <asm/arch/regs-base.h> 2981ca8409SOtavio Salvador 3081ca8409SOtavio Salvador #define CONFIG_MXS_GPIO /* GPIO control */ 3181ca8409SOtavio Salvador #define CONFIG_SYS_HZ 1000 /* Ticks per second */ 3281ca8409SOtavio Salvador 3381ca8409SOtavio Salvador #define CONFIG_MACH_TYPE MACH_TYPE_MX23EVK 3481ca8409SOtavio Salvador 3581ca8409SOtavio Salvador #define CONFIG_SYS_NO_FLASH 3681ca8409SOtavio Salvador #define CONFIG_BOARD_EARLY_INIT_F 3781ca8409SOtavio Salvador #define CONFIG_ARCH_MISC_INIT 3881ca8409SOtavio Salvador 3981ca8409SOtavio Salvador /* SPL */ 4081ca8409SOtavio Salvador #define CONFIG_SPL 4181ca8409SOtavio Salvador #define CONFIG_SPL_NO_CPU_SUPPORT_CODE 4281ca8409SOtavio Salvador #define CONFIG_SPL_START_S_PATH "arch/arm/cpu/arm926ejs/mxs" 4381ca8409SOtavio Salvador #define CONFIG_SPL_LDSCRIPT "arch/arm/cpu/arm926ejs/mxs/u-boot-spl.lds" 4481ca8409SOtavio Salvador #define CONFIG_SPL_LIBCOMMON_SUPPORT 4581ca8409SOtavio Salvador #define CONFIG_SPL_LIBGENERIC_SUPPORT 4681ca8409SOtavio Salvador #define CONFIG_SPL_GPIO_SUPPORT 4781ca8409SOtavio Salvador 4881ca8409SOtavio Salvador /* U-Boot Commands */ 4981ca8409SOtavio Salvador #include <config_cmd_default.h> 5081ca8409SOtavio Salvador #undef CONFIG_CMD_NET 5181ca8409SOtavio Salvador #undef CONFIG_CMD_NFS 5281ca8409SOtavio Salvador 5381ca8409SOtavio Salvador #define CONFIG_DISPLAY_CPUINFO 5481ca8409SOtavio Salvador #define CONFIG_DOS_PARTITION 5581ca8409SOtavio Salvador 5681ca8409SOtavio Salvador #define CONFIG_CMD_CACHE 5781ca8409SOtavio Salvador #define CONFIG_CMD_EXT2 5881ca8409SOtavio Salvador #define CONFIG_CMD_FAT 5981ca8409SOtavio Salvador #define CONFIG_CMD_GPIO 6081ca8409SOtavio Salvador #define CONFIG_CMD_MMC 61e895aa45SOtavio Salvador #define CONFIG_CMD_USB 6281ca8409SOtavio Salvador #define CONFIG_CMD_BOOTZ 63*eadfc135SFabio Estevam #define CONFIG_VIDEO 6481ca8409SOtavio Salvador 6581ca8409SOtavio Salvador /* Memory configurations */ 6681ca8409SOtavio Salvador #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */ 6781ca8409SOtavio Salvador #define PHYS_SDRAM_1 0x40000000 /* Base address */ 6881ca8409SOtavio Salvador #define PHYS_SDRAM_1_SIZE 0x08000000 /* Max 128 MB RAM */ 6981ca8409SOtavio Salvador #define CONFIG_STACKSIZE (128 * 1024) /* 128 KB stack */ 7081ca8409SOtavio Salvador #define CONFIG_SYS_MALLOC_LEN 0x00400000 /* 4 MB for malloc */ 7181ca8409SOtavio Salvador #define CONFIG_SYS_MEMTEST_START 0x40000000 /* Memtest start adr */ 7281ca8409SOtavio Salvador #define CONFIG_SYS_MEMTEST_END 0x40400000 /* 4 MB RAM test */ 7381ca8409SOtavio Salvador #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1 7481ca8409SOtavio Salvador /* Point initial SP in SRAM so SPL can use it too. */ 7581ca8409SOtavio Salvador 7681ca8409SOtavio Salvador #define CONFIG_SYS_INIT_RAM_ADDR 0x00000000 7781ca8409SOtavio Salvador #define CONFIG_SYS_INIT_RAM_SIZE (128 * 1024) 7881ca8409SOtavio Salvador 7981ca8409SOtavio Salvador #define CONFIG_SYS_INIT_SP_OFFSET \ 8081ca8409SOtavio Salvador (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 8181ca8409SOtavio Salvador #define CONFIG_SYS_INIT_SP_ADDR \ 8281ca8409SOtavio Salvador (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) 8381ca8409SOtavio Salvador 8481ca8409SOtavio Salvador /* 8581ca8409SOtavio Salvador * We need to sacrifice first 4 bytes of RAM here to avoid triggering some 8681ca8409SOtavio Salvador * strange BUG in ROM corrupting first 4 bytes of RAM when loading U-Boot 8781ca8409SOtavio Salvador * binary. In case there was more of this mess, 0x100 bytes are skipped. 8881ca8409SOtavio Salvador */ 8981ca8409SOtavio Salvador #define CONFIG_SYS_TEXT_BASE 0x40000100 9081ca8409SOtavio Salvador 9181ca8409SOtavio Salvador #define CONFIG_ENV_OVERWRITE 9281ca8409SOtavio Salvador 9381ca8409SOtavio Salvador /* U-Boot general configurations */ 9481ca8409SOtavio Salvador #define CONFIG_SYS_LONGHELP 9581ca8409SOtavio Salvador #define CONFIG_SYS_PROMPT "=> " 9681ca8409SOtavio Salvador #define CONFIG_SYS_CBSIZE 256 /* Console I/O buffer size */ 9781ca8409SOtavio Salvador #define CONFIG_SYS_PBSIZE \ 9881ca8409SOtavio Salvador (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 9981ca8409SOtavio Salvador /* Print buffer size */ 10081ca8409SOtavio Salvador #define CONFIG_SYS_MAXARGS 32 /* Max number of command args */ 10181ca8409SOtavio Salvador #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 10281ca8409SOtavio Salvador /* Boot argument buffer size */ 10381ca8409SOtavio Salvador #define CONFIG_VERSION_VARIABLE /* U-BOOT version */ 10481ca8409SOtavio Salvador #define CONFIG_AUTO_COMPLETE /* Command auto complete */ 10581ca8409SOtavio Salvador #define CONFIG_CMDLINE_EDITING /* Command history etc */ 10681ca8409SOtavio Salvador #define CONFIG_SYS_HUSH_PARSER 10781ca8409SOtavio Salvador #define CONFIG_SYS_PROMPT_HUSH_PS2 "> " 10881ca8409SOtavio Salvador 10981ca8409SOtavio Salvador /* Serial Driver */ 11081ca8409SOtavio Salvador #define CONFIG_PL011_SERIAL 11181ca8409SOtavio Salvador #define CONFIG_PL011_CLOCK 24000000 11281ca8409SOtavio Salvador #define CONFIG_PL01x_PORTS { (void *)MXS_UARTDBG_BASE } 11381ca8409SOtavio Salvador #define CONFIG_CONS_INDEX 0 11481ca8409SOtavio Salvador #define CONFIG_BAUDRATE 115200 /* Default baud rate */ 11581ca8409SOtavio Salvador 11681ca8409SOtavio Salvador /* DMA */ 11781ca8409SOtavio Salvador #define CONFIG_APBH_DMA 11881ca8409SOtavio Salvador 11981ca8409SOtavio Salvador /* MMC Driver */ 12081ca8409SOtavio Salvador #ifdef CONFIG_CMD_MMC 12181ca8409SOtavio Salvador #define CONFIG_MMC 12281ca8409SOtavio Salvador #define CONFIG_GENERIC_MMC 12381ca8409SOtavio Salvador #define CONFIG_BOUNCE_BUFFER 12481ca8409SOtavio Salvador #define CONFIG_MXS_MMC 12581ca8409SOtavio Salvador #endif 12681ca8409SOtavio Salvador 127e895aa45SOtavio Salvador /* USB */ 128e895aa45SOtavio Salvador #ifdef CONFIG_CMD_USB 129e895aa45SOtavio Salvador #define CONFIG_USB_EHCI 130e895aa45SOtavio Salvador #define CONFIG_USB_EHCI_MXS 131e895aa45SOtavio Salvador #define CONFIG_EHCI_MXS_PORT0 132e895aa45SOtavio Salvador #define CONFIG_USB_MAX_CONTROLLER_COUNT 1 133e895aa45SOtavio Salvador #define CONFIG_EHCI_IS_TDI 134e895aa45SOtavio Salvador #define CONFIG_USB_STORAGE 135e895aa45SOtavio Salvador #endif 136e895aa45SOtavio Salvador 137*eadfc135SFabio Estevam /* Framebuffer support */ 138*eadfc135SFabio Estevam #ifdef CONFIG_VIDEO 139*eadfc135SFabio Estevam #define CONFIG_CFB_CONSOLE 140*eadfc135SFabio Estevam #define CONFIG_VIDEO_MXS 141*eadfc135SFabio Estevam #define CONFIG_VIDEO_LOGO 142*eadfc135SFabio Estevam #define CONFIG_VIDEO_SW_CURSOR 143*eadfc135SFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE 144*eadfc135SFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV 145*eadfc135SFabio Estevam #define CONFIG_SPLASH_SCREEN 146*eadfc135SFabio Estevam #define CONFIG_CMD_BMP 147*eadfc135SFabio Estevam #define CONFIG_BMP_16BPP 148*eadfc135SFabio Estevam #define CONFIG_VIDEO_BMP_RLE8 149*eadfc135SFabio Estevam #define CONFIG_VIDEO_BMP_GZIP 150*eadfc135SFabio Estevam #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (512 << 10) 151*eadfc135SFabio Estevam #endif 152*eadfc135SFabio Estevam 15381ca8409SOtavio Salvador /* Boot Linux */ 15481ca8409SOtavio Salvador #define CONFIG_CMDLINE_TAG 15581ca8409SOtavio Salvador #define CONFIG_SETUP_MEMORY_TAGS 15681ca8409SOtavio Salvador #define CONFIG_BOOTDELAY 1 15781ca8409SOtavio Salvador #define CONFIG_BOOTFILE "uImage" 15881ca8409SOtavio Salvador #define CONFIG_LOADADDR 0x42000000 15981ca8409SOtavio Salvador #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR 16081ca8409SOtavio Salvador #define CONFIG_OF_LIBFDT 16181ca8409SOtavio Salvador 16281ca8409SOtavio Salvador /* Environment */ 16381ca8409SOtavio Salvador #define CONFIG_ENV_IS_IN_MMC 16481ca8409SOtavio Salvador #ifdef CONFIG_ENV_IS_IN_MMC 16581ca8409SOtavio Salvador #define CONFIG_ENV_OFFSET (256 * 1024) 16681ca8409SOtavio Salvador #define CONFIG_ENV_SIZE (16 * 1024) 16781ca8409SOtavio Salvador #define CONFIG_SYS_MMC_ENV_DEV 0 16881ca8409SOtavio Salvador #endif 16981ca8409SOtavio Salvador 17081ca8409SOtavio Salvador /* Extra Environments */ 17181ca8409SOtavio Salvador #define CONFIG_EXTRA_ENV_SETTINGS \ 17281ca8409SOtavio Salvador "update_sd_firmware_filename=u-boot.sd\0" \ 17381ca8409SOtavio Salvador "update_sd_firmware=" /* Update the SD firmware partition */ \ 17481ca8409SOtavio Salvador "if mmc rescan ; then " \ 17581ca8409SOtavio Salvador "if tftp ${update_sd_firmware_filename} ; then " \ 17681ca8409SOtavio Salvador "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \ 17781ca8409SOtavio Salvador "setexpr fw_sz ${fw_sz} + 1 ; " \ 17881ca8409SOtavio Salvador "mmc write ${loadaddr} 0x800 ${fw_sz} ; " \ 17981ca8409SOtavio Salvador "fi ; " \ 18081ca8409SOtavio Salvador "fi\0" \ 18181ca8409SOtavio Salvador "script=boot.scr\0" \ 18281ca8409SOtavio Salvador "uimage=uImage\0" \ 18381ca8409SOtavio Salvador "console=ttyAMA0\0" \ 18481ca8409SOtavio Salvador "fdt_file=imx23-evk.dtb\0" \ 18581ca8409SOtavio Salvador "fdt_addr=0x41000000\0" \ 18681ca8409SOtavio Salvador "boot_fdt=try\0" \ 18781ca8409SOtavio Salvador "mmcdev=0\0" \ 18881ca8409SOtavio Salvador "mmcpart=2\0" \ 18981ca8409SOtavio Salvador "mmcroot=/dev/mmcblk0p3 rw rootwait\0" \ 19081ca8409SOtavio Salvador "mmcargs=setenv bootargs console=${console},${baudrate} " \ 19181ca8409SOtavio Salvador "root=${mmcroot}\0" \ 19281ca8409SOtavio Salvador "loadbootscript=" \ 19381ca8409SOtavio Salvador "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \ 19481ca8409SOtavio Salvador "bootscript=echo Running bootscript from mmc ...; " \ 19581ca8409SOtavio Salvador "source\0" \ 19681ca8409SOtavio Salvador "loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \ 19781ca8409SOtavio Salvador "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \ 19881ca8409SOtavio Salvador "mmcboot=echo Booting from mmc ...; " \ 19981ca8409SOtavio Salvador "run mmcargs; " \ 20081ca8409SOtavio Salvador "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \ 20181ca8409SOtavio Salvador "if run loadfdt; then " \ 20281ca8409SOtavio Salvador "bootm ${loadaddr} - ${fdt_addr}; " \ 20381ca8409SOtavio Salvador "else " \ 20481ca8409SOtavio Salvador "if test ${boot_fdt} = try; then " \ 20581ca8409SOtavio Salvador "bootm; " \ 20681ca8409SOtavio Salvador "else " \ 20781ca8409SOtavio Salvador "echo WARN: Cannot load the DT; " \ 20881ca8409SOtavio Salvador "fi; " \ 20981ca8409SOtavio Salvador "fi; " \ 21081ca8409SOtavio Salvador "else " \ 21181ca8409SOtavio Salvador "bootm; " \ 21281ca8409SOtavio Salvador "fi;\0" 21381ca8409SOtavio Salvador 21481ca8409SOtavio Salvador #define CONFIG_BOOTCOMMAND \ 21581ca8409SOtavio Salvador "mmc dev ${mmcdev}; if mmc rescan; then " \ 21681ca8409SOtavio Salvador "if run loadbootscript; then " \ 21781ca8409SOtavio Salvador "run bootscript; " \ 21881ca8409SOtavio Salvador "else " \ 21981ca8409SOtavio Salvador "if run loaduimage; then " \ 22081ca8409SOtavio Salvador "run mmcboot; " \ 22181ca8409SOtavio Salvador "else " \ 22281ca8409SOtavio Salvador "echo ERR: Fail to boot from MMC; " \ 22381ca8409SOtavio Salvador "fi; " \ 22481ca8409SOtavio Salvador "fi; " \ 22581ca8409SOtavio Salvador "else exit; fi" 22681ca8409SOtavio Salvador 22781ca8409SOtavio Salvador #endif /* __MX23EVK_CONFIG_H__ */ 228