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 * 7*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 881ca8409SOtavio Salvador */ 981ca8409SOtavio Salvador #ifndef __MX23EVK_CONFIG_H__ 1081ca8409SOtavio Salvador #define __MX23EVK_CONFIG_H__ 1181ca8409SOtavio Salvador 1281ca8409SOtavio Salvador /* SoC configurations */ 1381ca8409SOtavio Salvador #define CONFIG_MX23 /* i.MX23 SoC */ 1481ca8409SOtavio Salvador 1581ca8409SOtavio Salvador #include <asm/arch/regs-base.h> 1681ca8409SOtavio Salvador 1781ca8409SOtavio Salvador #define CONFIG_MXS_GPIO /* GPIO control */ 1881ca8409SOtavio Salvador #define CONFIG_SYS_HZ 1000 /* Ticks per second */ 1981ca8409SOtavio Salvador 2081ca8409SOtavio Salvador #define CONFIG_MACH_TYPE MACH_TYPE_MX23EVK 2181ca8409SOtavio Salvador 2281ca8409SOtavio Salvador #define CONFIG_SYS_NO_FLASH 2381ca8409SOtavio Salvador #define CONFIG_BOARD_EARLY_INIT_F 2481ca8409SOtavio Salvador #define CONFIG_ARCH_MISC_INIT 2581ca8409SOtavio Salvador 2681ca8409SOtavio Salvador /* SPL */ 2781ca8409SOtavio Salvador #define CONFIG_SPL 2881ca8409SOtavio Salvador #define CONFIG_SPL_NO_CPU_SUPPORT_CODE 2981ca8409SOtavio Salvador #define CONFIG_SPL_START_S_PATH "arch/arm/cpu/arm926ejs/mxs" 3081ca8409SOtavio Salvador #define CONFIG_SPL_LDSCRIPT "arch/arm/cpu/arm926ejs/mxs/u-boot-spl.lds" 3181ca8409SOtavio Salvador #define CONFIG_SPL_LIBCOMMON_SUPPORT 3281ca8409SOtavio Salvador #define CONFIG_SPL_LIBGENERIC_SUPPORT 3381ca8409SOtavio Salvador #define CONFIG_SPL_GPIO_SUPPORT 3481ca8409SOtavio Salvador 3581ca8409SOtavio Salvador /* U-Boot Commands */ 3681ca8409SOtavio Salvador #include <config_cmd_default.h> 3781ca8409SOtavio Salvador #undef CONFIG_CMD_NET 3881ca8409SOtavio Salvador #undef CONFIG_CMD_NFS 3981ca8409SOtavio Salvador 4081ca8409SOtavio Salvador #define CONFIG_DISPLAY_CPUINFO 4181ca8409SOtavio Salvador #define CONFIG_DOS_PARTITION 4281ca8409SOtavio Salvador 4381ca8409SOtavio Salvador #define CONFIG_CMD_CACHE 4481ca8409SOtavio Salvador #define CONFIG_CMD_EXT2 4581ca8409SOtavio Salvador #define CONFIG_CMD_FAT 4681ca8409SOtavio Salvador #define CONFIG_CMD_GPIO 4781ca8409SOtavio Salvador #define CONFIG_CMD_MMC 48e895aa45SOtavio Salvador #define CONFIG_CMD_USB 4981ca8409SOtavio Salvador #define CONFIG_CMD_BOOTZ 50eadfc135SFabio Estevam #define CONFIG_VIDEO 5181ca8409SOtavio Salvador 5281ca8409SOtavio Salvador /* Memory configurations */ 5381ca8409SOtavio Salvador #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */ 5481ca8409SOtavio Salvador #define PHYS_SDRAM_1 0x40000000 /* Base address */ 5581ca8409SOtavio Salvador #define PHYS_SDRAM_1_SIZE 0x08000000 /* Max 128 MB RAM */ 5681ca8409SOtavio Salvador #define CONFIG_STACKSIZE (128 * 1024) /* 128 KB stack */ 5781ca8409SOtavio Salvador #define CONFIG_SYS_MALLOC_LEN 0x00400000 /* 4 MB for malloc */ 5881ca8409SOtavio Salvador #define CONFIG_SYS_MEMTEST_START 0x40000000 /* Memtest start adr */ 5981ca8409SOtavio Salvador #define CONFIG_SYS_MEMTEST_END 0x40400000 /* 4 MB RAM test */ 6081ca8409SOtavio Salvador #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1 6181ca8409SOtavio Salvador /* Point initial SP in SRAM so SPL can use it too. */ 6281ca8409SOtavio Salvador 6381ca8409SOtavio Salvador #define CONFIG_SYS_INIT_RAM_ADDR 0x00000000 6481ca8409SOtavio Salvador #define CONFIG_SYS_INIT_RAM_SIZE (128 * 1024) 6581ca8409SOtavio Salvador 6681ca8409SOtavio Salvador #define CONFIG_SYS_INIT_SP_OFFSET \ 6781ca8409SOtavio Salvador (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 6881ca8409SOtavio Salvador #define CONFIG_SYS_INIT_SP_ADDR \ 6981ca8409SOtavio Salvador (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) 7081ca8409SOtavio Salvador 7181ca8409SOtavio Salvador /* 7281ca8409SOtavio Salvador * We need to sacrifice first 4 bytes of RAM here to avoid triggering some 7381ca8409SOtavio Salvador * strange BUG in ROM corrupting first 4 bytes of RAM when loading U-Boot 7481ca8409SOtavio Salvador * binary. In case there was more of this mess, 0x100 bytes are skipped. 7581ca8409SOtavio Salvador */ 7681ca8409SOtavio Salvador #define CONFIG_SYS_TEXT_BASE 0x40000100 7781ca8409SOtavio Salvador 7881ca8409SOtavio Salvador #define CONFIG_ENV_OVERWRITE 7981ca8409SOtavio Salvador 8081ca8409SOtavio Salvador /* U-Boot general configurations */ 8181ca8409SOtavio Salvador #define CONFIG_SYS_LONGHELP 8281ca8409SOtavio Salvador #define CONFIG_SYS_PROMPT "=> " 8381ca8409SOtavio Salvador #define CONFIG_SYS_CBSIZE 256 /* Console I/O buffer size */ 8481ca8409SOtavio Salvador #define CONFIG_SYS_PBSIZE \ 8581ca8409SOtavio Salvador (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 8681ca8409SOtavio Salvador /* Print buffer size */ 8781ca8409SOtavio Salvador #define CONFIG_SYS_MAXARGS 32 /* Max number of command args */ 8881ca8409SOtavio Salvador #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 8981ca8409SOtavio Salvador /* Boot argument buffer size */ 9081ca8409SOtavio Salvador #define CONFIG_VERSION_VARIABLE /* U-BOOT version */ 9181ca8409SOtavio Salvador #define CONFIG_AUTO_COMPLETE /* Command auto complete */ 9281ca8409SOtavio Salvador #define CONFIG_CMDLINE_EDITING /* Command history etc */ 9381ca8409SOtavio Salvador #define CONFIG_SYS_HUSH_PARSER 9481ca8409SOtavio Salvador #define CONFIG_SYS_PROMPT_HUSH_PS2 "> " 9581ca8409SOtavio Salvador 9681ca8409SOtavio Salvador /* Serial Driver */ 9781ca8409SOtavio Salvador #define CONFIG_PL011_SERIAL 9881ca8409SOtavio Salvador #define CONFIG_PL011_CLOCK 24000000 9981ca8409SOtavio Salvador #define CONFIG_PL01x_PORTS { (void *)MXS_UARTDBG_BASE } 10081ca8409SOtavio Salvador #define CONFIG_CONS_INDEX 0 10181ca8409SOtavio Salvador #define CONFIG_BAUDRATE 115200 /* Default baud rate */ 10281ca8409SOtavio Salvador 10381ca8409SOtavio Salvador /* DMA */ 10481ca8409SOtavio Salvador #define CONFIG_APBH_DMA 10581ca8409SOtavio Salvador 10681ca8409SOtavio Salvador /* MMC Driver */ 10781ca8409SOtavio Salvador #ifdef CONFIG_CMD_MMC 10881ca8409SOtavio Salvador #define CONFIG_MMC 10981ca8409SOtavio Salvador #define CONFIG_GENERIC_MMC 11081ca8409SOtavio Salvador #define CONFIG_BOUNCE_BUFFER 11181ca8409SOtavio Salvador #define CONFIG_MXS_MMC 11281ca8409SOtavio Salvador #endif 11381ca8409SOtavio Salvador 114e895aa45SOtavio Salvador /* USB */ 115e895aa45SOtavio Salvador #ifdef CONFIG_CMD_USB 116e895aa45SOtavio Salvador #define CONFIG_USB_EHCI 117e895aa45SOtavio Salvador #define CONFIG_USB_EHCI_MXS 118e895aa45SOtavio Salvador #define CONFIG_EHCI_MXS_PORT0 119e895aa45SOtavio Salvador #define CONFIG_USB_MAX_CONTROLLER_COUNT 1 120e895aa45SOtavio Salvador #define CONFIG_EHCI_IS_TDI 121e895aa45SOtavio Salvador #define CONFIG_USB_STORAGE 122e895aa45SOtavio Salvador #endif 123e895aa45SOtavio Salvador 124eadfc135SFabio Estevam /* Framebuffer support */ 125eadfc135SFabio Estevam #ifdef CONFIG_VIDEO 126eadfc135SFabio Estevam #define CONFIG_CFB_CONSOLE 127eadfc135SFabio Estevam #define CONFIG_VIDEO_MXS 128eadfc135SFabio Estevam #define CONFIG_VIDEO_LOGO 129eadfc135SFabio Estevam #define CONFIG_VIDEO_SW_CURSOR 130eadfc135SFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE 131eadfc135SFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV 132eadfc135SFabio Estevam #define CONFIG_SPLASH_SCREEN 133eadfc135SFabio Estevam #define CONFIG_CMD_BMP 134eadfc135SFabio Estevam #define CONFIG_BMP_16BPP 135eadfc135SFabio Estevam #define CONFIG_VIDEO_BMP_RLE8 136eadfc135SFabio Estevam #define CONFIG_VIDEO_BMP_GZIP 137eadfc135SFabio Estevam #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (512 << 10) 138eadfc135SFabio Estevam #endif 139eadfc135SFabio Estevam 14081ca8409SOtavio Salvador /* Boot Linux */ 14181ca8409SOtavio Salvador #define CONFIG_CMDLINE_TAG 14281ca8409SOtavio Salvador #define CONFIG_SETUP_MEMORY_TAGS 14381ca8409SOtavio Salvador #define CONFIG_BOOTDELAY 1 14481ca8409SOtavio Salvador #define CONFIG_BOOTFILE "uImage" 14581ca8409SOtavio Salvador #define CONFIG_LOADADDR 0x42000000 14681ca8409SOtavio Salvador #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR 14781ca8409SOtavio Salvador #define CONFIG_OF_LIBFDT 14881ca8409SOtavio Salvador 14981ca8409SOtavio Salvador /* Environment */ 15081ca8409SOtavio Salvador #define CONFIG_ENV_IS_IN_MMC 15181ca8409SOtavio Salvador #ifdef CONFIG_ENV_IS_IN_MMC 15281ca8409SOtavio Salvador #define CONFIG_ENV_OFFSET (256 * 1024) 15381ca8409SOtavio Salvador #define CONFIG_ENV_SIZE (16 * 1024) 15481ca8409SOtavio Salvador #define CONFIG_SYS_MMC_ENV_DEV 0 15581ca8409SOtavio Salvador #endif 15681ca8409SOtavio Salvador 15781ca8409SOtavio Salvador /* Extra Environments */ 15881ca8409SOtavio Salvador #define CONFIG_EXTRA_ENV_SETTINGS \ 15981ca8409SOtavio Salvador "update_sd_firmware_filename=u-boot.sd\0" \ 16081ca8409SOtavio Salvador "update_sd_firmware=" /* Update the SD firmware partition */ \ 16181ca8409SOtavio Salvador "if mmc rescan ; then " \ 16281ca8409SOtavio Salvador "if tftp ${update_sd_firmware_filename} ; then " \ 16381ca8409SOtavio Salvador "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \ 16481ca8409SOtavio Salvador "setexpr fw_sz ${fw_sz} + 1 ; " \ 16581ca8409SOtavio Salvador "mmc write ${loadaddr} 0x800 ${fw_sz} ; " \ 16681ca8409SOtavio Salvador "fi ; " \ 16781ca8409SOtavio Salvador "fi\0" \ 16881ca8409SOtavio Salvador "script=boot.scr\0" \ 16981ca8409SOtavio Salvador "uimage=uImage\0" \ 17081ca8409SOtavio Salvador "console=ttyAMA0\0" \ 17181ca8409SOtavio Salvador "fdt_file=imx23-evk.dtb\0" \ 17281ca8409SOtavio Salvador "fdt_addr=0x41000000\0" \ 17381ca8409SOtavio Salvador "boot_fdt=try\0" \ 17481ca8409SOtavio Salvador "mmcdev=0\0" \ 17581ca8409SOtavio Salvador "mmcpart=2\0" \ 17681ca8409SOtavio Salvador "mmcroot=/dev/mmcblk0p3 rw rootwait\0" \ 17781ca8409SOtavio Salvador "mmcargs=setenv bootargs console=${console},${baudrate} " \ 17881ca8409SOtavio Salvador "root=${mmcroot}\0" \ 17981ca8409SOtavio Salvador "loadbootscript=" \ 18081ca8409SOtavio Salvador "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \ 18181ca8409SOtavio Salvador "bootscript=echo Running bootscript from mmc ...; " \ 18281ca8409SOtavio Salvador "source\0" \ 18381ca8409SOtavio Salvador "loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \ 18481ca8409SOtavio Salvador "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \ 18581ca8409SOtavio Salvador "mmcboot=echo Booting from mmc ...; " \ 18681ca8409SOtavio Salvador "run mmcargs; " \ 18781ca8409SOtavio Salvador "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \ 18881ca8409SOtavio Salvador "if run loadfdt; then " \ 18981ca8409SOtavio Salvador "bootm ${loadaddr} - ${fdt_addr}; " \ 19081ca8409SOtavio Salvador "else " \ 19181ca8409SOtavio Salvador "if test ${boot_fdt} = try; then " \ 19281ca8409SOtavio Salvador "bootm; " \ 19381ca8409SOtavio Salvador "else " \ 19481ca8409SOtavio Salvador "echo WARN: Cannot load the DT; " \ 19581ca8409SOtavio Salvador "fi; " \ 19681ca8409SOtavio Salvador "fi; " \ 19781ca8409SOtavio Salvador "else " \ 19881ca8409SOtavio Salvador "bootm; " \ 19981ca8409SOtavio Salvador "fi;\0" 20081ca8409SOtavio Salvador 20181ca8409SOtavio Salvador #define CONFIG_BOOTCOMMAND \ 20281ca8409SOtavio Salvador "mmc dev ${mmcdev}; if mmc rescan; then " \ 20381ca8409SOtavio Salvador "if run loadbootscript; then " \ 20481ca8409SOtavio Salvador "run bootscript; " \ 20581ca8409SOtavio Salvador "else " \ 20681ca8409SOtavio Salvador "if run loaduimage; then " \ 20781ca8409SOtavio Salvador "run mmcboot; " \ 20881ca8409SOtavio Salvador "else " \ 20981ca8409SOtavio Salvador "echo ERR: Fail to boot from MMC; " \ 21081ca8409SOtavio Salvador "fi; " \ 21181ca8409SOtavio Salvador "fi; " \ 21281ca8409SOtavio Salvador "else exit; fi" 21381ca8409SOtavio Salvador 21481ca8409SOtavio Salvador #endif /* __MX23EVK_CONFIG_H__ */ 215