1c8a7d9daSWang Huan /* 2c8a7d9daSWang Huan * Copyright 2014 Freescale Semiconductor, Inc. 3c8a7d9daSWang Huan * 4c8a7d9daSWang Huan * SPDX-License-Identifier: GPL-2.0+ 5c8a7d9daSWang Huan */ 6c8a7d9daSWang Huan 7c8a7d9daSWang Huan #ifndef __CONFIG_H 8c8a7d9daSWang Huan #define __CONFIG_H 9c8a7d9daSWang Huan 10c8a7d9daSWang Huan #include <config_cmd_default.h> 11c8a7d9daSWang Huan 12c8a7d9daSWang Huan #define CONFIG_LS102XA 13c8a7d9daSWang Huan 14c8a7d9daSWang Huan #define CONFIG_SYS_GENERIC_BOARD 15c8a7d9daSWang Huan 16c8a7d9daSWang Huan #define CONFIG_DISPLAY_CPUINFO 17c8a7d9daSWang Huan #define CONFIG_DISPLAY_BOARDINFO 18c8a7d9daSWang Huan 19c8a7d9daSWang Huan #define CONFIG_SKIP_LOWLEVEL_INIT 20c8a7d9daSWang Huan #define CONFIG_BOARD_EARLY_INIT_F 21c8a7d9daSWang Huan 22c8a7d9daSWang Huan /* 23c8a7d9daSWang Huan * Size of malloc() pool 24c8a7d9daSWang Huan */ 25c8a7d9daSWang Huan #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 16 * 1024 * 1024) 26c8a7d9daSWang Huan 27c8a7d9daSWang Huan #define CONFIG_SYS_INIT_RAM_ADDR OCRAM_BASE_ADDR 28c8a7d9daSWang Huan #define CONFIG_SYS_INIT_RAM_SIZE OCRAM_SIZE 29c8a7d9daSWang Huan 30c8a7d9daSWang Huan /* 31c8a7d9daSWang Huan * Generic Timer Definitions 32c8a7d9daSWang Huan */ 33c8a7d9daSWang Huan #define GENERIC_TIMER_CLK 12500000 34c8a7d9daSWang Huan 35c8a7d9daSWang Huan #define CONFIG_SYS_CLK_FREQ 100000000 36c8a7d9daSWang Huan #define CONFIG_DDR_CLK_FREQ 100000000 37c8a7d9daSWang Huan 38c8a7d9daSWang Huan #ifndef CONFIG_SYS_TEXT_BASE 39c8a7d9daSWang Huan #define CONFIG_SYS_TEXT_BASE 0x67f80000 40c8a7d9daSWang Huan #endif 41c8a7d9daSWang Huan 42c8a7d9daSWang Huan #define CONFIG_NR_DRAM_BANKS 1 43c8a7d9daSWang Huan #define PHYS_SDRAM 0x80000000 44c8a7d9daSWang Huan #define PHYS_SDRAM_SIZE (1u * 1024 * 1024 * 1024) 45c8a7d9daSWang Huan 46c8a7d9daSWang Huan #define CONFIG_SYS_DDR_SDRAM_BASE 0x80000000UL 47c8a7d9daSWang Huan #define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_DDR_SDRAM_BASE 48c8a7d9daSWang Huan 49c8a7d9daSWang Huan #define CONFIG_SYS_HAS_SERDES 50c8a7d9daSWang Huan 51*4ba4a095SRuchika Gupta #define CONFIG_FSL_CAAM /* Enable CAAM */ 52*4ba4a095SRuchika Gupta 53c8a7d9daSWang Huan /* 54c8a7d9daSWang Huan * IFC Definitions 55c8a7d9daSWang Huan */ 56c8a7d9daSWang Huan #define CONFIG_FSL_IFC 57c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_BASE 0x60000000 58c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_BASE_PHYS CONFIG_SYS_FLASH_BASE 59c8a7d9daSWang Huan 60c8a7d9daSWang Huan #define CONFIG_SYS_NOR0_CSPR_EXT (0x0) 61c8a7d9daSWang Huan #define CONFIG_SYS_NOR0_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | \ 62c8a7d9daSWang Huan CSPR_PORT_SIZE_16 | \ 63c8a7d9daSWang Huan CSPR_MSEL_NOR | \ 64c8a7d9daSWang Huan CSPR_V) 65c8a7d9daSWang Huan #define CONFIG_SYS_NOR_AMASK IFC_AMASK(128 * 1024 * 1024) 66c8a7d9daSWang Huan 67c8a7d9daSWang Huan /* NOR Flash Timing Params */ 68c8a7d9daSWang Huan #define CONFIG_SYS_NOR_CSOR (CSOR_NOR_ADM_SHIFT(4) | \ 69c8a7d9daSWang Huan CSOR_NOR_TRHZ_80) 70c8a7d9daSWang Huan #define CONFIG_SYS_NOR_FTIM0 (FTIM0_NOR_TACSE(0x4) | \ 71c8a7d9daSWang Huan FTIM0_NOR_TEADC(0x5) | \ 72c8a7d9daSWang Huan FTIM0_NOR_TAVDS(0x0) | \ 73c8a7d9daSWang Huan FTIM0_NOR_TEAHC(0x5)) 74c8a7d9daSWang Huan #define CONFIG_SYS_NOR_FTIM1 (FTIM1_NOR_TACO(0x35) | \ 75c8a7d9daSWang Huan FTIM1_NOR_TRAD_NOR(0x1A) | \ 76c8a7d9daSWang Huan FTIM1_NOR_TSEQRAD_NOR(0x13)) 77c8a7d9daSWang Huan #define CONFIG_SYS_NOR_FTIM2 (FTIM2_NOR_TCS(0x4) | \ 78c8a7d9daSWang Huan FTIM2_NOR_TCH(0x4) | \ 79c8a7d9daSWang Huan FTIM2_NOR_TWP(0x1c) | \ 80c8a7d9daSWang Huan FTIM2_NOR_TWPH(0x0e)) 81c8a7d9daSWang Huan #define CONFIG_SYS_NOR_FTIM3 0 82c8a7d9daSWang Huan 83c8a7d9daSWang Huan #define CONFIG_FLASH_CFI_DRIVER 84c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_CFI 85c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 86c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_QUIET_TEST 87c8a7d9daSWang Huan #define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */ 88c8a7d9daSWang Huan 89c8a7d9daSWang Huan #define CONFIG_SYS_MAX_FLASH_BANKS 1 /* number of banks */ 90c8a7d9daSWang Huan #define CONFIG_SYS_MAX_FLASH_SECT 1024 /* sectors per device */ 91c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_ERASE_TOUT 60000 /* Flash Erase Timeout (ms) */ 92c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout (ms) */ 93c8a7d9daSWang Huan 94c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_EMPTY_INFO 95c8a7d9daSWang Huan #define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_FLASH_BASE_PHYS } 96c8a7d9daSWang Huan 97c8a7d9daSWang Huan #define CONFIG_CFI_FLASH_USE_WEAK_ACCESSORS 98c8a7d9daSWang Huan 99c8a7d9daSWang Huan /* CPLD */ 100c8a7d9daSWang Huan 101c8a7d9daSWang Huan #define CONFIG_SYS_CPLD_BASE 0x7fb00000 102c8a7d9daSWang Huan #define CPLD_BASE_PHYS CONFIG_SYS_CPLD_BASE 103c8a7d9daSWang Huan 104c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_CSPR_EXT (0x0) 105c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_CSPR (CSPR_PHYS_ADDR(CPLD_BASE_PHYS) | \ 106c8a7d9daSWang Huan CSPR_PORT_SIZE_8 | \ 107c8a7d9daSWang Huan CSPR_MSEL_GPCM | \ 108c8a7d9daSWang Huan CSPR_V) 109c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_AMASK IFC_AMASK(64 * 1024) 110c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_CSOR (CSOR_NOR_ADM_SHIFT(4) | \ 111c8a7d9daSWang Huan CSOR_NOR_NOR_MODE_AVD_NOR | \ 112c8a7d9daSWang Huan CSOR_NOR_TRHZ_80) 113c8a7d9daSWang Huan 114c8a7d9daSWang Huan /* CPLD Timing parameters for IFC GPCM */ 115c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_FTIM0 (FTIM0_GPCM_TACSE(0xf) | \ 116c8a7d9daSWang Huan FTIM0_GPCM_TEADC(0xf) | \ 117c8a7d9daSWang Huan FTIM0_GPCM_TEAHC(0xf)) 118c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_FTIM1 (FTIM1_GPCM_TACO(0xff) | \ 119c8a7d9daSWang Huan FTIM1_GPCM_TRAD(0x3f)) 120c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_FTIM2 (FTIM2_GPCM_TCS(0xf) | \ 121c8a7d9daSWang Huan FTIM2_GPCM_TCH(0xf) | \ 122c8a7d9daSWang Huan FTIM2_GPCM_TWP(0xff)) 123c8a7d9daSWang Huan #define CONFIG_SYS_FPGA_FTIM3 0x0 124c8a7d9daSWang Huan #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT 125c8a7d9daSWang Huan #define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR 126c8a7d9daSWang Huan #define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK 127c8a7d9daSWang Huan #define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR 128c8a7d9daSWang Huan #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0 129c8a7d9daSWang Huan #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1 130c8a7d9daSWang Huan #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2 131c8a7d9daSWang Huan #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3 132c8a7d9daSWang Huan #define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_FPGA_CSPR_EXT 133c8a7d9daSWang Huan #define CONFIG_SYS_CSPR1 CONFIG_SYS_FPGA_CSPR 134c8a7d9daSWang Huan #define CONFIG_SYS_AMASK1 CONFIG_SYS_FPGA_AMASK 135c8a7d9daSWang Huan #define CONFIG_SYS_CSOR1 CONFIG_SYS_FPGA_CSOR 136c8a7d9daSWang Huan #define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_FPGA_FTIM0 137c8a7d9daSWang Huan #define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_FPGA_FTIM1 138c8a7d9daSWang Huan #define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_FPGA_FTIM2 139c8a7d9daSWang Huan #define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_FPGA_FTIM3 140c8a7d9daSWang Huan 141c8a7d9daSWang Huan /* 142c8a7d9daSWang Huan * Serial Port 143c8a7d9daSWang Huan */ 144c8a7d9daSWang Huan #define CONFIG_CONS_INDEX 1 145c8a7d9daSWang Huan #define CONFIG_SYS_NS16550 146c8a7d9daSWang Huan #define CONFIG_SYS_NS16550_SERIAL 147c8a7d9daSWang Huan #define CONFIG_SYS_NS16550_REG_SIZE 1 148c8a7d9daSWang Huan #define CONFIG_SYS_NS16550_CLK get_serial_clock() 149c8a7d9daSWang Huan 150c8a7d9daSWang Huan #define CONFIG_BAUDRATE 115200 151c8a7d9daSWang Huan 152c8a7d9daSWang Huan /* 153c8a7d9daSWang Huan * I2C 154c8a7d9daSWang Huan */ 155c8a7d9daSWang Huan #define CONFIG_CMD_I2C 156c8a7d9daSWang Huan #define CONFIG_SYS_I2C 157c8a7d9daSWang Huan #define CONFIG_SYS_I2C_MXC 158c8a7d9daSWang Huan 159c8a7d9daSWang Huan /* 160c8a7d9daSWang Huan * MMC 161c8a7d9daSWang Huan */ 162c8a7d9daSWang Huan #define CONFIG_MMC 163c8a7d9daSWang Huan #define CONFIG_CMD_MMC 164c8a7d9daSWang Huan #define CONFIG_FSL_ESDHC 165c8a7d9daSWang Huan #define CONFIG_GENERIC_MMC 166c8a7d9daSWang Huan 167c8a7d9daSWang Huan /* 168b4ecc8c6SWang Huan * Video 169b4ecc8c6SWang Huan */ 170b4ecc8c6SWang Huan #define CONFIG_FSL_DCU_FB 171b4ecc8c6SWang Huan 172b4ecc8c6SWang Huan #ifdef CONFIG_FSL_DCU_FB 173b4ecc8c6SWang Huan #define CONFIG_VIDEO 174b4ecc8c6SWang Huan #define CONFIG_CMD_BMP 175b4ecc8c6SWang Huan #define CONFIG_CFB_CONSOLE 176b4ecc8c6SWang Huan #define CONFIG_VGA_AS_SINGLE_DEVICE 177b4ecc8c6SWang Huan #define CONFIG_VIDEO_LOGO 178b4ecc8c6SWang Huan #define CONFIG_VIDEO_BMP_LOGO 179b4ecc8c6SWang Huan 180b4ecc8c6SWang Huan #define CONFIG_FSL_DCU_SII9022A 181b4ecc8c6SWang Huan #define CONFIG_SYS_I2C_DVI_BUS_NUM 1 182b4ecc8c6SWang Huan #define CONFIG_SYS_I2C_DVI_ADDR 0x39 183b4ecc8c6SWang Huan #endif 184b4ecc8c6SWang Huan 185b4ecc8c6SWang Huan /* 186c8a7d9daSWang Huan * eTSEC 187c8a7d9daSWang Huan */ 188c8a7d9daSWang Huan #define CONFIG_TSEC_ENET 189c8a7d9daSWang Huan 190c8a7d9daSWang Huan #ifdef CONFIG_TSEC_ENET 191c8a7d9daSWang Huan #define CONFIG_MII 192c8a7d9daSWang Huan #define CONFIG_MII_DEFAULT_TSEC 1 193c8a7d9daSWang Huan #define CONFIG_TSEC1 1 194c8a7d9daSWang Huan #define CONFIG_TSEC1_NAME "eTSEC1" 195c8a7d9daSWang Huan #define CONFIG_TSEC2 1 196c8a7d9daSWang Huan #define CONFIG_TSEC2_NAME "eTSEC2" 197c8a7d9daSWang Huan #define CONFIG_TSEC3 1 198c8a7d9daSWang Huan #define CONFIG_TSEC3_NAME "eTSEC3" 199c8a7d9daSWang Huan 200c8a7d9daSWang Huan #define TSEC1_PHY_ADDR 2 201c8a7d9daSWang Huan #define TSEC2_PHY_ADDR 0 202c8a7d9daSWang Huan #define TSEC3_PHY_ADDR 1 203c8a7d9daSWang Huan 204c8a7d9daSWang Huan #define TSEC1_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 205c8a7d9daSWang Huan #define TSEC2_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 206c8a7d9daSWang Huan #define TSEC3_FLAGS (TSEC_GIGABIT | TSEC_REDUCED) 207c8a7d9daSWang Huan 208c8a7d9daSWang Huan #define TSEC1_PHYIDX 0 209c8a7d9daSWang Huan #define TSEC2_PHYIDX 0 210c8a7d9daSWang Huan #define TSEC3_PHYIDX 0 211c8a7d9daSWang Huan 212c8a7d9daSWang Huan #define CONFIG_ETHPRIME "eTSEC1" 213c8a7d9daSWang Huan 214c8a7d9daSWang Huan #define CONFIG_PHY_GIGE 215c8a7d9daSWang Huan #define CONFIG_PHYLIB 216c8a7d9daSWang Huan #define CONFIG_PHY_ATHEROS 217c8a7d9daSWang Huan 218c8a7d9daSWang Huan #define CONFIG_HAS_ETH0 219c8a7d9daSWang Huan #define CONFIG_HAS_ETH1 220c8a7d9daSWang Huan #define CONFIG_HAS_ETH2 221c8a7d9daSWang Huan #endif 222c8a7d9daSWang Huan 223c8a7d9daSWang Huan #define CONFIG_CMD_PING 224c8a7d9daSWang Huan #define CONFIG_CMD_DHCP 225c8a7d9daSWang Huan #define CONFIG_CMD_MII 226c8a7d9daSWang Huan #define CONFIG_CMD_NET 227c8a7d9daSWang Huan 228c8a7d9daSWang Huan #define CONFIG_CMDLINE_TAG 229c8a7d9daSWang Huan #define CONFIG_CMDLINE_EDITING 230c8a7d9daSWang Huan #define CONFIG_CMD_IMLS 231c8a7d9daSWang Huan 232c8a7d9daSWang Huan #define CONFIG_HWCONFIG 233c8a7d9daSWang Huan #define HWCONFIG_BUFFER_SIZE 128 234c8a7d9daSWang Huan 235c8a7d9daSWang Huan #define CONFIG_BOOTDELAY 3 236c8a7d9daSWang Huan 237c8a7d9daSWang Huan #define CONFIG_EXTRA_ENV_SETTINGS \ 238c8a7d9daSWang Huan "bootargs=root=/dev/ram0 rw console=ttyS0,115200\0" \ 239c8a7d9daSWang Huan "initrd_high=0xcfffffff\0" \ 240c8a7d9daSWang Huan "fdt_high=0xcfffffff\0" 241c8a7d9daSWang Huan 242c8a7d9daSWang Huan /* 243c8a7d9daSWang Huan * Miscellaneous configurable options 244c8a7d9daSWang Huan */ 245c8a7d9daSWang Huan #define CONFIG_SYS_LONGHELP /* undef to save memory */ 246c8a7d9daSWang Huan #define CONFIG_SYS_HUSH_PARSER /* use "hush" command parser */ 247c8a7d9daSWang Huan #define CONFIG_SYS_PROMPT_HUSH_PS2 "> " 248c8a7d9daSWang Huan #define CONFIG_SYS_PROMPT "=> " 249c8a7d9daSWang Huan #define CONFIG_AUTO_COMPLETE 250c8a7d9daSWang Huan #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */ 251c8a7d9daSWang Huan #define CONFIG_SYS_PBSIZE \ 252c8a7d9daSWang Huan (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 253c8a7d9daSWang Huan #define CONFIG_SYS_MAXARGS 16 /* max number of command args */ 254c8a7d9daSWang Huan #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 255c8a7d9daSWang Huan 256c8a7d9daSWang Huan #define CONFIG_CMD_ENV_EXISTS 257c8a7d9daSWang Huan #define CONFIG_CMD_GREPENV 258c8a7d9daSWang Huan #define CONFIG_CMD_MEMINFO 259c8a7d9daSWang Huan #define CONFIG_CMD_MEMTEST 260c8a7d9daSWang Huan #define CONFIG_SYS_MEMTEST_START 0x80000000 261c8a7d9daSWang Huan #define CONFIG_SYS_MEMTEST_END 0x9fffffff 262c8a7d9daSWang Huan 263c8a7d9daSWang Huan #define CONFIG_SYS_LOAD_ADDR 0x82000000 264c8a7d9daSWang Huan #define CONFIG_SYS_HZ 1000 265c8a7d9daSWang Huan 266c8a7d9daSWang Huan /* 267c8a7d9daSWang Huan * Stack sizes 268c8a7d9daSWang Huan * The stack sizes are set up in start.S using the settings below 269c8a7d9daSWang Huan */ 270c8a7d9daSWang Huan #define CONFIG_STACKSIZE (30 * 1024) 271c8a7d9daSWang Huan 272c8a7d9daSWang Huan #define CONFIG_SYS_INIT_SP_OFFSET \ 273c8a7d9daSWang Huan (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 274c8a7d9daSWang Huan #define CONFIG_SYS_INIT_SP_ADDR \ 275c8a7d9daSWang Huan (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET) 276c8a7d9daSWang Huan 277c8a7d9daSWang Huan #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE /* start of monitor */ 278c8a7d9daSWang Huan 279c8a7d9daSWang Huan /* 280c8a7d9daSWang Huan * Environment 281c8a7d9daSWang Huan */ 282c8a7d9daSWang Huan #define CONFIG_ENV_OVERWRITE 283c8a7d9daSWang Huan 284c8a7d9daSWang Huan #define CONFIG_ENV_IS_IN_FLASH 285c8a7d9daSWang Huan #define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE) 286c8a7d9daSWang Huan #define CONFIG_ENV_SIZE 0x20000 287c8a7d9daSWang Huan #define CONFIG_ENV_SECT_SIZE 0x20000 /* 128K (one sector) */ 288c8a7d9daSWang Huan 289c8a7d9daSWang Huan #define CONFIG_OF_LIBFDT 290c8a7d9daSWang Huan #define CONFIG_OF_BOARD_SETUP 291c8a7d9daSWang Huan #define CONFIG_CMD_BOOTZ 292c8a7d9daSWang Huan 293*4ba4a095SRuchika Gupta #define CONFIG_MISC_INIT_R 294*4ba4a095SRuchika Gupta 295*4ba4a095SRuchika Gupta /* Hash command with SHA acceleration supported in hardware */ 296*4ba4a095SRuchika Gupta #define CONFIG_CMD_HASH 297*4ba4a095SRuchika Gupta #define CONFIG_SHA_HW_ACCEL 298*4ba4a095SRuchika Gupta 299c8a7d9daSWang Huan #endif 300