102b5d2edSShaohui Xie /* 202b5d2edSShaohui Xie * Copyright 2015 Freescale Semiconductor, Inc. 302b5d2edSShaohui Xie * 402b5d2edSShaohui Xie * SPDX-License-Identifier: GPL-2.0+ 502b5d2edSShaohui Xie */ 602b5d2edSShaohui Xie 702b5d2edSShaohui Xie #ifndef __LS1043AQDS_H__ 802b5d2edSShaohui Xie #define __LS1043AQDS_H__ 902b5d2edSShaohui Xie 1002b5d2edSShaohui Xie #include "ls1043a_common.h" 1102b5d2edSShaohui Xie 1202b5d2edSShaohui Xie #define CONFIG_DISPLAY_CPUINFO 13b0f20cafSQianyu Gong #ifdef CONFIG_QSPI_BOOT 14b0f20cafSQianyu Gong #define CONFIG_DISPLAY_BOARDINFO_LATE 15b0f20cafSQianyu Gong #else 1602b5d2edSShaohui Xie #define CONFIG_DISPLAY_BOARDINFO 17b0f20cafSQianyu Gong #endif 1802b5d2edSShaohui Xie 1902b5d2edSShaohui Xie #if defined(CONFIG_NAND_BOOT) || defined(CONFIG_SD_BOOT) 2002b5d2edSShaohui Xie #define CONFIG_SYS_TEXT_BASE 0x82000000 21b0f20cafSQianyu Gong #elif defined(CONFIG_QSPI_BOOT) 22b0f20cafSQianyu Gong #define CONFIG_SYS_TEXT_BASE 0x40010000 2302b5d2edSShaohui Xie #else 2402b5d2edSShaohui Xie #define CONFIG_SYS_TEXT_BASE 0x60100000 2502b5d2edSShaohui Xie #endif 2602b5d2edSShaohui Xie 2702b5d2edSShaohui Xie #ifndef __ASSEMBLY__ 2802b5d2edSShaohui Xie unsigned long get_board_sys_clk(void); 2902b5d2edSShaohui Xie unsigned long get_board_ddr_clk(void); 3002b5d2edSShaohui Xie #endif 3102b5d2edSShaohui Xie 3202b5d2edSShaohui Xie #define CONFIG_SYS_CLK_FREQ 100000000 3302b5d2edSShaohui Xie #define CONFIG_DDR_CLK_FREQ 100000000 3402b5d2edSShaohui Xie 3502b5d2edSShaohui Xie #define CONFIG_SKIP_LOWLEVEL_INIT 3602b5d2edSShaohui Xie 3702b5d2edSShaohui Xie #define CONFIG_LAYERSCAPE_NS_ACCESS 3802b5d2edSShaohui Xie 3902b5d2edSShaohui Xie #define CONFIG_DIMM_SLOTS_PER_CTLR 1 4002b5d2edSShaohui Xie /* Physical Memory Map */ 4102b5d2edSShaohui Xie #define CONFIG_CHIP_SELECTS_PER_CTRL 4 4258e4ad1dSShaohui Xie #define CONFIG_NR_DRAM_BANKS 2 4302b5d2edSShaohui Xie 4402b5d2edSShaohui Xie #define CONFIG_DDR_SPD 4502b5d2edSShaohui Xie #define SPD_EEPROM_ADDRESS 0x51 4602b5d2edSShaohui Xie #define CONFIG_SYS_SPD_BUS_NUM 0 4702b5d2edSShaohui Xie 4802b5d2edSShaohui Xie #define CONFIG_FSL_DDR_INTERACTIVE /* Interactive debugging */ 4902b5d2edSShaohui Xie #ifndef CONFIG_SYS_FSL_DDR4 5002b5d2edSShaohui Xie #define CONFIG_SYS_FSL_DDR3 /* Use DDR3 memory */ 5102b5d2edSShaohui Xie #endif 5202b5d2edSShaohui Xie 5302b5d2edSShaohui Xie #define CONFIG_DDR_ECC 5402b5d2edSShaohui Xie #ifdef CONFIG_DDR_ECC 5502b5d2edSShaohui Xie #define CONFIG_ECC_INIT_VIA_DDRCONTROLLER 5602b5d2edSShaohui Xie #define CONFIG_MEM_INIT_VALUE 0xdeadbeef 5702b5d2edSShaohui Xie #endif 5802b5d2edSShaohui Xie 5902b5d2edSShaohui Xie #define CONFIG_SYS_HAS_SERDES 6002b5d2edSShaohui Xie 6102b5d2edSShaohui Xie #ifdef CONFIG_SYS_DPAA_FMAN 6202b5d2edSShaohui Xie #define CONFIG_FMAN_ENET 6302b5d2edSShaohui Xie #define CONFIG_PHYLIB 6402b5d2edSShaohui Xie #define CONFIG_PHY_VITESSE 6502b5d2edSShaohui Xie #define CONFIG_PHY_REALTEK 6602b5d2edSShaohui Xie #define CONFIG_PHYLIB_10G 6702b5d2edSShaohui Xie #define RGMII_PHY1_ADDR 0x1 6802b5d2edSShaohui Xie #define RGMII_PHY2_ADDR 0x2 6902b5d2edSShaohui Xie #define SGMII_CARD_PORT1_PHY_ADDR 0x1C 7002b5d2edSShaohui Xie #define SGMII_CARD_PORT2_PHY_ADDR 0x1D 7102b5d2edSShaohui Xie #define SGMII_CARD_PORT3_PHY_ADDR 0x1E 7202b5d2edSShaohui Xie #define SGMII_CARD_PORT4_PHY_ADDR 0x1F 7302b5d2edSShaohui Xie /* PHY address on QSGMII riser card on slot 1 */ 7402b5d2edSShaohui Xie #define QSGMII_CARD_PORT1_PHY_ADDR_S1 0x4 7502b5d2edSShaohui Xie #define QSGMII_CARD_PORT2_PHY_ADDR_S1 0x5 7602b5d2edSShaohui Xie #define QSGMII_CARD_PORT3_PHY_ADDR_S1 0x6 7702b5d2edSShaohui Xie #define QSGMII_CARD_PORT4_PHY_ADDR_S1 0x7 7802b5d2edSShaohui Xie /* PHY address on QSGMII riser card on slot 2 */ 7902b5d2edSShaohui Xie #define QSGMII_CARD_PORT1_PHY_ADDR_S2 0x8 8002b5d2edSShaohui Xie #define QSGMII_CARD_PORT2_PHY_ADDR_S2 0x9 8102b5d2edSShaohui Xie #define QSGMII_CARD_PORT3_PHY_ADDR_S2 0xA 8202b5d2edSShaohui Xie #define QSGMII_CARD_PORT4_PHY_ADDR_S2 0xB 8302b5d2edSShaohui Xie #endif 8402b5d2edSShaohui Xie 8502b5d2edSShaohui Xie #ifdef CONFIG_RAMBOOT_PBL 8602b5d2edSShaohui Xie #define CONFIG_SYS_FSL_PBL_PBI board/freescale/ls1043aqds/ls1043aqds_pbi.cfg 8702b5d2edSShaohui Xie #endif 8802b5d2edSShaohui Xie 8902b5d2edSShaohui Xie #ifdef CONFIG_NAND_BOOT 9002b5d2edSShaohui Xie #define CONFIG_SYS_FSL_PBL_RCW board/freescale/ls1043aqds/ls1043aqds_rcw_nand.cfg 9102b5d2edSShaohui Xie #endif 9202b5d2edSShaohui Xie 9302b5d2edSShaohui Xie #ifdef CONFIG_SD_BOOT 94166ef1e9SGong Qianyu #ifdef CONFIG_SD_BOOT_QSPI 95166ef1e9SGong Qianyu #define CONFIG_SYS_FSL_PBL_RCW \ 96166ef1e9SGong Qianyu board/freescale/ls1043aqds/ls1043aqds_rcw_sd_qspi.cfg 97166ef1e9SGong Qianyu #else 9802b5d2edSShaohui Xie #define CONFIG_SYS_FSL_PBL_RCW board/freescale/ls1043aqds/ls1043aqds_rcw_sd_ifc.cfg 9902b5d2edSShaohui Xie #endif 100166ef1e9SGong Qianyu #endif 10102b5d2edSShaohui Xie 1022970e14fSWenbin Song /* LPUART */ 1032970e14fSWenbin Song #ifdef CONFIG_LPUART 1042970e14fSWenbin Song #define CONFIG_LPUART_32B_REG 1052970e14fSWenbin Song #endif 1062970e14fSWenbin Song 107989c5f0aSTang Yuantian /* SATA */ 108989c5f0aSTang Yuantian #define CONFIG_LIBATA 109989c5f0aSTang Yuantian #define CONFIG_SCSI_AHCI 110989c5f0aSTang Yuantian #define CONFIG_SCSI_AHCI_PLAT 111989c5f0aSTang Yuantian #define CONFIG_CMD_SCSI 112989c5f0aSTang Yuantian #define CONFIG_CMD_FAT 113989c5f0aSTang Yuantian #define CONFIG_CMD_EXT2 114989c5f0aSTang Yuantian #define CONFIG_DOS_PARTITION 115989c5f0aSTang Yuantian #define CONFIG_BOARD_LATE_INIT 116989c5f0aSTang Yuantian 117*ceded371SWenbin Song 118*ceded371SWenbin Song /* EEPROM */ 119*ceded371SWenbin Song #define CONFIG_ID_EEPROM 120*ceded371SWenbin Song #define CONFIG_SYS_I2C_EEPROM_NXID 121*ceded371SWenbin Song #define CONFIG_SYS_EEPROM_BUS_NUM 0 122*ceded371SWenbin Song #define CONFIG_SYS_I2C_EEPROM_ADDR 0x57 123*ceded371SWenbin Song #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1 124*ceded371SWenbin Song #define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 3 125*ceded371SWenbin Song #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 5 126*ceded371SWenbin Song 127989c5f0aSTang Yuantian #define CONFIG_SYS_SATA AHCI_BASE_ADDR 128989c5f0aSTang Yuantian 129989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_SCSI_ID 1 130989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_LUN 1 131989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_DEVICE (CONFIG_SYS_SCSI_MAX_SCSI_ID * \ 132989c5f0aSTang Yuantian CONFIG_SYS_SCSI_MAX_LUN) 133989c5f0aSTang Yuantian 13402b5d2edSShaohui Xie /* 13502b5d2edSShaohui Xie * IFC Definitions 13602b5d2edSShaohui Xie */ 137b0f20cafSQianyu Gong #if !defined(CONFIG_QSPI_BOOT) && !defined(CONFIG_SD_BOOT_QSPI) 13802b5d2edSShaohui Xie #define CONFIG_SYS_NOR0_CSPR_EXT (0x0) 13902b5d2edSShaohui Xie #define CONFIG_SYS_NOR0_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | \ 14002b5d2edSShaohui Xie CSPR_PORT_SIZE_16 | \ 14102b5d2edSShaohui Xie CSPR_MSEL_NOR | \ 14202b5d2edSShaohui Xie CSPR_V) 14302b5d2edSShaohui Xie #define CONFIG_SYS_NOR1_CSPR_EXT (0x0) 14402b5d2edSShaohui Xie #define CONFIG_SYS_NOR1_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS \ 14502b5d2edSShaohui Xie + 0x8000000) | \ 14602b5d2edSShaohui Xie CSPR_PORT_SIZE_16 | \ 14702b5d2edSShaohui Xie CSPR_MSEL_NOR | \ 14802b5d2edSShaohui Xie CSPR_V) 14902b5d2edSShaohui Xie #define CONFIG_SYS_NOR_AMASK IFC_AMASK(128 * 1024 * 1024) 15002b5d2edSShaohui Xie 15102b5d2edSShaohui Xie #define CONFIG_SYS_NOR_CSOR (CSOR_NOR_ADM_SHIFT(4) | \ 15202b5d2edSShaohui Xie CSOR_NOR_TRHZ_80) 15302b5d2edSShaohui Xie #define CONFIG_SYS_NOR_FTIM0 (FTIM0_NOR_TACSE(0x4) | \ 15402b5d2edSShaohui Xie FTIM0_NOR_TEADC(0x5) | \ 15502b5d2edSShaohui Xie FTIM0_NOR_TEAHC(0x5)) 15602b5d2edSShaohui Xie #define CONFIG_SYS_NOR_FTIM1 (FTIM1_NOR_TACO(0x35) | \ 15702b5d2edSShaohui Xie FTIM1_NOR_TRAD_NOR(0x1a) | \ 15802b5d2edSShaohui Xie FTIM1_NOR_TSEQRAD_NOR(0x13)) 15902b5d2edSShaohui Xie #define CONFIG_SYS_NOR_FTIM2 (FTIM2_NOR_TCS(0x4) | \ 16002b5d2edSShaohui Xie FTIM2_NOR_TCH(0x4) | \ 16102b5d2edSShaohui Xie FTIM2_NOR_TWPH(0xe) | \ 16202b5d2edSShaohui Xie FTIM2_NOR_TWP(0x1c)) 16302b5d2edSShaohui Xie #define CONFIG_SYS_NOR_FTIM3 0 16402b5d2edSShaohui Xie 16502b5d2edSShaohui Xie #define CONFIG_SYS_MAX_FLASH_BANKS 2 /* number of banks */ 16602b5d2edSShaohui Xie #define CONFIG_SYS_MAX_FLASH_SECT 1024 /* sectors per device */ 16702b5d2edSShaohui Xie #define CONFIG_SYS_FLASH_ERASE_TOUT 60000 /* Flash Erase Timeout (ms) */ 16802b5d2edSShaohui Xie #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout (ms) */ 16902b5d2edSShaohui Xie 17002b5d2edSShaohui Xie #define CONFIG_SYS_FLASH_EMPTY_INFO 17102b5d2edSShaohui Xie #define CONFIG_SYS_FLASH_BANKS_LIST {CONFIG_SYS_FLASH_BASE_PHYS, \ 17202b5d2edSShaohui Xie CONFIG_SYS_FLASH_BASE_PHYS + 0x8000000} 17302b5d2edSShaohui Xie 17402b5d2edSShaohui Xie #define CONFIG_CFI_FLASH_USE_WEAK_ACCESSORS 17502b5d2edSShaohui Xie #define CONFIG_SYS_WRITE_SWAPPED_DATA 17602b5d2edSShaohui Xie 17702b5d2edSShaohui Xie /* 17802b5d2edSShaohui Xie * NAND Flash Definitions 17902b5d2edSShaohui Xie */ 18002b5d2edSShaohui Xie #define CONFIG_NAND_FSL_IFC 18102b5d2edSShaohui Xie 18202b5d2edSShaohui Xie #define CONFIG_SYS_NAND_BASE 0x7e800000 18302b5d2edSShaohui Xie #define CONFIG_SYS_NAND_BASE_PHYS CONFIG_SYS_NAND_BASE 18402b5d2edSShaohui Xie 18502b5d2edSShaohui Xie #define CONFIG_SYS_NAND_CSPR_EXT (0x0) 18602b5d2edSShaohui Xie 18702b5d2edSShaohui Xie #define CONFIG_SYS_NAND_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \ 18802b5d2edSShaohui Xie | CSPR_PORT_SIZE_8 \ 18902b5d2edSShaohui Xie | CSPR_MSEL_NAND \ 19002b5d2edSShaohui Xie | CSPR_V) 19102b5d2edSShaohui Xie #define CONFIG_SYS_NAND_AMASK IFC_AMASK(64*1024) 19202b5d2edSShaohui Xie #define CONFIG_SYS_NAND_CSOR (CSOR_NAND_ECC_ENC_EN /* ECC on encode */ \ 19302b5d2edSShaohui Xie | CSOR_NAND_ECC_DEC_EN /* ECC on decode */ \ 19402b5d2edSShaohui Xie | CSOR_NAND_ECC_MODE_4 /* 4-bit ECC */ \ 19502b5d2edSShaohui Xie | CSOR_NAND_RAL_3 /* RAL = 3 Bytes */ \ 19602b5d2edSShaohui Xie | CSOR_NAND_PGS_2K /* Page Size = 2K */ \ 19702b5d2edSShaohui Xie | CSOR_NAND_SPRZ_64 /* Spare size = 64 */ \ 19802b5d2edSShaohui Xie | CSOR_NAND_PB(64)) /* 64 Pages Per Block */ 19902b5d2edSShaohui Xie 20002b5d2edSShaohui Xie #define CONFIG_SYS_NAND_ONFI_DETECTION 20102b5d2edSShaohui Xie 20202b5d2edSShaohui Xie #define CONFIG_SYS_NAND_FTIM0 (FTIM0_NAND_TCCST(0x7) | \ 20302b5d2edSShaohui Xie FTIM0_NAND_TWP(0x18) | \ 20402b5d2edSShaohui Xie FTIM0_NAND_TWCHT(0x7) | \ 20502b5d2edSShaohui Xie FTIM0_NAND_TWH(0xa)) 20602b5d2edSShaohui Xie #define CONFIG_SYS_NAND_FTIM1 (FTIM1_NAND_TADLE(0x32) | \ 20702b5d2edSShaohui Xie FTIM1_NAND_TWBE(0x39) | \ 20802b5d2edSShaohui Xie FTIM1_NAND_TRR(0xe) | \ 20902b5d2edSShaohui Xie FTIM1_NAND_TRP(0x18)) 21002b5d2edSShaohui Xie #define CONFIG_SYS_NAND_FTIM2 (FTIM2_NAND_TRAD(0xf) | \ 21102b5d2edSShaohui Xie FTIM2_NAND_TREH(0xa) | \ 21202b5d2edSShaohui Xie FTIM2_NAND_TWHRE(0x1e)) 21302b5d2edSShaohui Xie #define CONFIG_SYS_NAND_FTIM3 0x0 21402b5d2edSShaohui Xie 21502b5d2edSShaohui Xie #define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE } 21602b5d2edSShaohui Xie #define CONFIG_SYS_MAX_NAND_DEVICE 1 21702b5d2edSShaohui Xie #define CONFIG_MTD_NAND_VERIFY_WRITE 21802b5d2edSShaohui Xie #define CONFIG_CMD_NAND 21902b5d2edSShaohui Xie 22002b5d2edSShaohui Xie #define CONFIG_SYS_NAND_BLOCK_SIZE (128 * 1024) 221166ef1e9SGong Qianyu #endif 22202b5d2edSShaohui Xie 22302b5d2edSShaohui Xie #ifdef CONFIG_NAND_BOOT 22402b5d2edSShaohui Xie #define CONFIG_SPL_PAD_TO 0x20000 /* block aligned */ 22502b5d2edSShaohui Xie #define CONFIG_SYS_NAND_U_BOOT_OFFS CONFIG_SPL_PAD_TO 22602b5d2edSShaohui Xie #define CONFIG_SYS_NAND_U_BOOT_SIZE (640 << 10) 22702b5d2edSShaohui Xie #endif 22802b5d2edSShaohui Xie 229b0f20cafSQianyu Gong #if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_SD_BOOT_QSPI) 230166ef1e9SGong Qianyu #define CONFIG_QIXIS_I2C_ACCESS 231166ef1e9SGong Qianyu #define CONFIG_SYS_NO_FLASH 232166ef1e9SGong Qianyu #undef CONFIG_CMD_IMLS 233166ef1e9SGong Qianyu #endif 234166ef1e9SGong Qianyu 23502b5d2edSShaohui Xie /* 23602b5d2edSShaohui Xie * QIXIS Definitions 23702b5d2edSShaohui Xie */ 23802b5d2edSShaohui Xie #define CONFIG_FSL_QIXIS 23902b5d2edSShaohui Xie 24002b5d2edSShaohui Xie #ifdef CONFIG_FSL_QIXIS 24102b5d2edSShaohui Xie #define QIXIS_BASE 0x7fb00000 24202b5d2edSShaohui Xie #define QIXIS_BASE_PHYS QIXIS_BASE 24302b5d2edSShaohui Xie #define CONFIG_SYS_I2C_FPGA_ADDR 0x66 24402b5d2edSShaohui Xie #define QIXIS_LBMAP_SWITCH 6 24502b5d2edSShaohui Xie #define QIXIS_LBMAP_MASK 0x0f 24602b5d2edSShaohui Xie #define QIXIS_LBMAP_SHIFT 0 24702b5d2edSShaohui Xie #define QIXIS_LBMAP_DFLTBANK 0x00 24802b5d2edSShaohui Xie #define QIXIS_LBMAP_ALTBANK 0x04 249ee2a4eeeSGong Qianyu #define QIXIS_LBMAP_NAND 0x09 250ee2a4eeeSGong Qianyu #define QIXIS_LBMAP_SD 0x00 251166ef1e9SGong Qianyu #define QIXIS_LBMAP_SD_QSPI 0xff 252b0f20cafSQianyu Gong #define QIXIS_LBMAP_QSPI 0xff 253ee2a4eeeSGong Qianyu #define QIXIS_RCW_SRC_NAND 0x106 254ee2a4eeeSGong Qianyu #define QIXIS_RCW_SRC_SD 0x040 255b0f20cafSQianyu Gong #define QIXIS_RCW_SRC_QSPI 0x045 256a4b7d68cSGong Qianyu #define QIXIS_RST_CTL_RESET 0x41 25702b5d2edSShaohui Xie #define QIXIS_RCFG_CTL_RECONFIG_IDLE 0x20 25802b5d2edSShaohui Xie #define QIXIS_RCFG_CTL_RECONFIG_START 0x21 25902b5d2edSShaohui Xie #define QIXIS_RCFG_CTL_WATCHDOG_ENBLE 0x08 26002b5d2edSShaohui Xie 26102b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_CSPR_EXT (0x0) 26202b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_CSPR (CSPR_PHYS_ADDR(QIXIS_BASE_PHYS) | \ 26302b5d2edSShaohui Xie CSPR_PORT_SIZE_8 | \ 26402b5d2edSShaohui Xie CSPR_MSEL_GPCM | \ 26502b5d2edSShaohui Xie CSPR_V) 26602b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_AMASK IFC_AMASK(64 * 1024) 26702b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_CSOR (CSOR_NOR_ADM_SHIFT(4) | \ 26802b5d2edSShaohui Xie CSOR_NOR_NOR_MODE_AVD_NOR | \ 26902b5d2edSShaohui Xie CSOR_NOR_TRHZ_80) 27002b5d2edSShaohui Xie 27102b5d2edSShaohui Xie /* 27202b5d2edSShaohui Xie * QIXIS Timing parameters for IFC GPCM 27302b5d2edSShaohui Xie */ 27402b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_FTIM0 (FTIM0_GPCM_TACSE(0xc) | \ 27502b5d2edSShaohui Xie FTIM0_GPCM_TEADC(0x20) | \ 27602b5d2edSShaohui Xie FTIM0_GPCM_TEAHC(0x10)) 27702b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_FTIM1 (FTIM1_GPCM_TACO(0x50) | \ 27802b5d2edSShaohui Xie FTIM1_GPCM_TRAD(0x1f)) 27902b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_FTIM2 (FTIM2_GPCM_TCS(0x8) | \ 28002b5d2edSShaohui Xie FTIM2_GPCM_TCH(0x8) | \ 28102b5d2edSShaohui Xie FTIM2_GPCM_TWP(0xf0)) 28202b5d2edSShaohui Xie #define CONFIG_SYS_FPGA_FTIM3 0x0 28302b5d2edSShaohui Xie #endif 28402b5d2edSShaohui Xie 28502b5d2edSShaohui Xie #ifdef CONFIG_NAND_BOOT 28602b5d2edSShaohui Xie #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NAND_CSPR_EXT 28702b5d2edSShaohui Xie #define CONFIG_SYS_CSPR0 CONFIG_SYS_NAND_CSPR 28802b5d2edSShaohui Xie #define CONFIG_SYS_AMASK0 CONFIG_SYS_NAND_AMASK 28902b5d2edSShaohui Xie #define CONFIG_SYS_CSOR0 CONFIG_SYS_NAND_CSOR 29002b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NAND_FTIM0 29102b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NAND_FTIM1 29202b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NAND_FTIM2 29302b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NAND_FTIM3 29402b5d2edSShaohui Xie #define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_NOR0_CSPR_EXT 29502b5d2edSShaohui Xie #define CONFIG_SYS_CSPR1 CONFIG_SYS_NOR0_CSPR 29602b5d2edSShaohui Xie #define CONFIG_SYS_AMASK1 CONFIG_SYS_NOR_AMASK 29702b5d2edSShaohui Xie #define CONFIG_SYS_CSOR1 CONFIG_SYS_NOR_CSOR 29802b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_NOR_FTIM0 29902b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_NOR_FTIM1 30002b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_NOR_FTIM2 30102b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_NOR_FTIM3 30202b5d2edSShaohui Xie #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NOR1_CSPR_EXT 30302b5d2edSShaohui Xie #define CONFIG_SYS_CSPR2 CONFIG_SYS_NOR1_CSPR 30402b5d2edSShaohui Xie #define CONFIG_SYS_AMASK2 CONFIG_SYS_NOR_AMASK 30502b5d2edSShaohui Xie #define CONFIG_SYS_CSOR2 CONFIG_SYS_NOR_CSOR 30602b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NOR_FTIM0 30702b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NOR_FTIM1 30802b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NOR_FTIM2 30902b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NOR_FTIM3 31002b5d2edSShaohui Xie #define CONFIG_SYS_CSPR3_EXT CONFIG_SYS_FPGA_CSPR_EXT 31102b5d2edSShaohui Xie #define CONFIG_SYS_CSPR3 CONFIG_SYS_FPGA_CSPR 31202b5d2edSShaohui Xie #define CONFIG_SYS_AMASK3 CONFIG_SYS_FPGA_AMASK 31302b5d2edSShaohui Xie #define CONFIG_SYS_CSOR3 CONFIG_SYS_FPGA_CSOR 31402b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM0 CONFIG_SYS_FPGA_FTIM0 31502b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM1 CONFIG_SYS_FPGA_FTIM1 31602b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM2 CONFIG_SYS_FPGA_FTIM2 31702b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM3 CONFIG_SYS_FPGA_FTIM3 31802b5d2edSShaohui Xie #else 31902b5d2edSShaohui Xie #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT 32002b5d2edSShaohui Xie #define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR 32102b5d2edSShaohui Xie #define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK 32202b5d2edSShaohui Xie #define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR 32302b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0 32402b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1 32502b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2 32602b5d2edSShaohui Xie #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3 32702b5d2edSShaohui Xie #define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_NOR1_CSPR_EXT 32802b5d2edSShaohui Xie #define CONFIG_SYS_CSPR1 CONFIG_SYS_NOR1_CSPR 32902b5d2edSShaohui Xie #define CONFIG_SYS_AMASK1 CONFIG_SYS_NOR_AMASK 33002b5d2edSShaohui Xie #define CONFIG_SYS_CSOR1 CONFIG_SYS_NOR_CSOR 33102b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_NOR_FTIM0 33202b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_NOR_FTIM1 33302b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_NOR_FTIM2 33402b5d2edSShaohui Xie #define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_NOR_FTIM3 33502b5d2edSShaohui Xie #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NAND_CSPR_EXT 33602b5d2edSShaohui Xie #define CONFIG_SYS_CSPR2 CONFIG_SYS_NAND_CSPR 33702b5d2edSShaohui Xie #define CONFIG_SYS_AMASK2 CONFIG_SYS_NAND_AMASK 33802b5d2edSShaohui Xie #define CONFIG_SYS_CSOR2 CONFIG_SYS_NAND_CSOR 33902b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NAND_FTIM0 34002b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NAND_FTIM1 34102b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NAND_FTIM2 34202b5d2edSShaohui Xie #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NAND_FTIM3 34302b5d2edSShaohui Xie #define CONFIG_SYS_CSPR3_EXT CONFIG_SYS_FPGA_CSPR_EXT 34402b5d2edSShaohui Xie #define CONFIG_SYS_CSPR3 CONFIG_SYS_FPGA_CSPR 34502b5d2edSShaohui Xie #define CONFIG_SYS_AMASK3 CONFIG_SYS_FPGA_AMASK 34602b5d2edSShaohui Xie #define CONFIG_SYS_CSOR3 CONFIG_SYS_FPGA_CSOR 34702b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM0 CONFIG_SYS_FPGA_FTIM0 34802b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM1 CONFIG_SYS_FPGA_FTIM1 34902b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM2 CONFIG_SYS_FPGA_FTIM2 35002b5d2edSShaohui Xie #define CONFIG_SYS_CS3_FTIM3 CONFIG_SYS_FPGA_FTIM3 35102b5d2edSShaohui Xie #endif 35202b5d2edSShaohui Xie 35302b5d2edSShaohui Xie /* 35402b5d2edSShaohui Xie * I2C bus multiplexer 35502b5d2edSShaohui Xie */ 35602b5d2edSShaohui Xie #define I2C_MUX_PCA_ADDR_PRI 0x77 35702b5d2edSShaohui Xie #define I2C_MUX_PCA_ADDR_SEC 0x76 /* Secondary multiplexer */ 35802b5d2edSShaohui Xie #define I2C_RETIMER_ADDR 0x18 35902b5d2edSShaohui Xie #define I2C_MUX_CH_DEFAULT 0x8 36002b5d2edSShaohui Xie #define I2C_MUX_CH_CH7301 0xC 36102b5d2edSShaohui Xie #define I2C_MUX_CH5 0xD 36202b5d2edSShaohui Xie #define I2C_MUX_CH7 0xF 36302b5d2edSShaohui Xie 36402b5d2edSShaohui Xie #define I2C_MUX_CH_VOL_MONITOR 0xa 36502b5d2edSShaohui Xie 36602b5d2edSShaohui Xie /* Voltage monitor on channel 2*/ 36702b5d2edSShaohui Xie #define I2C_VOL_MONITOR_ADDR 0x40 36802b5d2edSShaohui Xie #define I2C_VOL_MONITOR_BUS_V_OFFSET 0x2 36902b5d2edSShaohui Xie #define I2C_VOL_MONITOR_BUS_V_OVF 0x1 37002b5d2edSShaohui Xie #define I2C_VOL_MONITOR_BUS_V_SHIFT 3 37102b5d2edSShaohui Xie 37202b5d2edSShaohui Xie #define CONFIG_VID_FLS_ENV "ls1043aqds_vdd_mv" 37302b5d2edSShaohui Xie #ifndef CONFIG_SPL_BUILD 37402b5d2edSShaohui Xie #define CONFIG_VID 37502b5d2edSShaohui Xie #endif 37602b5d2edSShaohui Xie #define CONFIG_VOL_MONITOR_IR36021_SET 37702b5d2edSShaohui Xie #define CONFIG_VOL_MONITOR_INA220 37802b5d2edSShaohui Xie /* The lowest and highest voltage allowed for LS1043AQDS */ 37902b5d2edSShaohui Xie #define VDD_MV_MIN 819 38002b5d2edSShaohui Xie #define VDD_MV_MAX 1212 38102b5d2edSShaohui Xie 382166ef1e9SGong Qianyu /* QSPI device */ 383b0f20cafSQianyu Gong #if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_SD_BOOT_QSPI) 384166ef1e9SGong Qianyu #define CONFIG_FSL_QSPI 385166ef1e9SGong Qianyu #ifdef CONFIG_FSL_QSPI 386166ef1e9SGong Qianyu #define CONFIG_SPI_FLASH_SPANSION 387166ef1e9SGong Qianyu #define FSL_QSPI_FLASH_SIZE (1 << 24) 388166ef1e9SGong Qianyu #define FSL_QSPI_FLASH_NUM 2 389166ef1e9SGong Qianyu #endif 390166ef1e9SGong Qianyu #endif 391166ef1e9SGong Qianyu 3925a7c40beSQianyu Gong /* USB */ 3935a7c40beSQianyu Gong #define CONFIG_HAS_FSL_XHCI_USB 3945a7c40beSQianyu Gong #ifdef CONFIG_HAS_FSL_XHCI_USB 3955a7c40beSQianyu Gong #define CONFIG_USB_XHCI 3965a7c40beSQianyu Gong #define CONFIG_USB_XHCI_FSL 3975a7c40beSQianyu Gong #define CONFIG_USB_XHCI_DWC3 3985a7c40beSQianyu Gong #define CONFIG_USB_MAX_CONTROLLER_COUNT 3 3995a7c40beSQianyu Gong #define CONFIG_SYS_USB_XHCI_MAX_ROOT_PORTS 2 4005a7c40beSQianyu Gong #define CONFIG_CMD_USB 4015a7c40beSQianyu Gong #define CONFIG_USB_STORAGE 4025a7c40beSQianyu Gong #define CONFIG_CMD_EXT2 4035a7c40beSQianyu Gong #endif 4045a7c40beSQianyu Gong 40502b5d2edSShaohui Xie /* 40602b5d2edSShaohui Xie * Miscellaneous configurable options 40702b5d2edSShaohui Xie */ 40802b5d2edSShaohui Xie #define CONFIG_MISC_INIT_R 40902b5d2edSShaohui Xie #define CONFIG_SYS_LONGHELP /* undef to save memory */ 41002b5d2edSShaohui Xie #define CONFIG_SYS_HUSH_PARSER /* use "hush" command parser */ 41102b5d2edSShaohui Xie #define CONFIG_SYS_PROMPT_HUSH_PS2 "> " 41202b5d2edSShaohui Xie #define CONFIG_SYS_PROMPT "=> " 41302b5d2edSShaohui Xie #define CONFIG_AUTO_COMPLETE 41402b5d2edSShaohui Xie #define CONFIG_SYS_PBSIZE \ 41502b5d2edSShaohui Xie (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16) 41602b5d2edSShaohui Xie #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE 41702b5d2edSShaohui Xie 41802b5d2edSShaohui Xie #define CONFIG_CMD_GREPENV 41902b5d2edSShaohui Xie #define CONFIG_CMD_MEMINFO 42002b5d2edSShaohui Xie #define CONFIG_CMD_MEMTEST 42102b5d2edSShaohui Xie #define CONFIG_SYS_MEMTEST_START 0x80000000 42202b5d2edSShaohui Xie #define CONFIG_SYS_MEMTEST_END 0x9fffffff 42302b5d2edSShaohui Xie 42402b5d2edSShaohui Xie #define CONFIG_SYS_HZ 1000 42502b5d2edSShaohui Xie 42602b5d2edSShaohui Xie /* 42702b5d2edSShaohui Xie * Stack sizes 42802b5d2edSShaohui Xie * The stack sizes are set up in start.S using the settings below 42902b5d2edSShaohui Xie */ 43002b5d2edSShaohui Xie #define CONFIG_STACKSIZE (30 * 1024) 43102b5d2edSShaohui Xie 43202b5d2edSShaohui Xie #define CONFIG_SYS_INIT_SP_OFFSET \ 43302b5d2edSShaohui Xie (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE) 43402b5d2edSShaohui Xie 43502b5d2edSShaohui Xie #ifdef CONFIG_SPL_BUILD 43602b5d2edSShaohui Xie #define CONFIG_SYS_MONITOR_BASE CONFIG_SPL_TEXT_BASE 43702b5d2edSShaohui Xie #else 43802b5d2edSShaohui Xie #define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE /* start of monitor */ 43902b5d2edSShaohui Xie #endif 44002b5d2edSShaohui Xie 44102b5d2edSShaohui Xie /* 44202b5d2edSShaohui Xie * Environment 44302b5d2edSShaohui Xie */ 44402b5d2edSShaohui Xie #define CONFIG_ENV_OVERWRITE 44502b5d2edSShaohui Xie 44602b5d2edSShaohui Xie #ifdef CONFIG_NAND_BOOT 44702b5d2edSShaohui Xie #define CONFIG_ENV_IS_IN_NAND 44802b5d2edSShaohui Xie #define CONFIG_ENV_SIZE 0x2000 44902b5d2edSShaohui Xie #define CONFIG_ENV_OFFSET (10 * CONFIG_SYS_NAND_BLOCK_SIZE) 45002b5d2edSShaohui Xie #elif defined(CONFIG_SD_BOOT) 45102b5d2edSShaohui Xie #define CONFIG_ENV_OFFSET (1024 * 1024) 45202b5d2edSShaohui Xie #define CONFIG_ENV_IS_IN_MMC 45302b5d2edSShaohui Xie #define CONFIG_SYS_MMC_ENV_DEV 0 45402b5d2edSShaohui Xie #define CONFIG_ENV_SIZE 0x2000 455b0f20cafSQianyu Gong #elif defined(CONFIG_QSPI_BOOT) 456b0f20cafSQianyu Gong #define CONFIG_ENV_IS_IN_SPI_FLASH 457b0f20cafSQianyu Gong #define CONFIG_ENV_SIZE 0x2000 /* 8KB */ 458b0f20cafSQianyu Gong #define CONFIG_ENV_OFFSET 0x100000 /* 1MB */ 459b0f20cafSQianyu Gong #define CONFIG_ENV_SECT_SIZE 0x10000 46002b5d2edSShaohui Xie #else 46102b5d2edSShaohui Xie #define CONFIG_ENV_IS_IN_FLASH 46202b5d2edSShaohui Xie #define CONFIG_ENV_ADDR (CONFIG_SYS_FLASH_BASE + 0x200000) 46302b5d2edSShaohui Xie #define CONFIG_ENV_SECT_SIZE 0x20000 46402b5d2edSShaohui Xie #define CONFIG_ENV_SIZE 0x20000 46502b5d2edSShaohui Xie #endif 46602b5d2edSShaohui Xie 46702b5d2edSShaohui Xie #define CONFIG_CMD_BOOTZ 46802b5d2edSShaohui Xie #define CONFIG_CMD_MII 46902b5d2edSShaohui Xie #define CONFIG_CMDLINE_TAG 47002b5d2edSShaohui Xie 471ef6c55a2SAneesh Bansal #include <asm/fsl_secure_boot.h> 472ef6c55a2SAneesh Bansal 47302b5d2edSShaohui Xie #endif /* __LS1043AQDS_H__ */ 474