144937214SPrabhakar Kushwaha /* 289a168f7SPriyanka Jain * Copyright 2017 NXP 344937214SPrabhakar Kushwaha * Copyright 2015 Freescale Semiconductor 444937214SPrabhakar Kushwaha * 544937214SPrabhakar Kushwaha * SPDX-License-Identifier: GPL-2.0+ 644937214SPrabhakar Kushwaha */ 744937214SPrabhakar Kushwaha 844937214SPrabhakar Kushwaha #ifndef __LS2_RDB_H 944937214SPrabhakar Kushwaha #define __LS2_RDB_H 1044937214SPrabhakar Kushwaha 1144937214SPrabhakar Kushwaha #include "ls2080a_common.h" 1244937214SPrabhakar Kushwaha 1344937214SPrabhakar Kushwaha #undef CONFIG_CONS_INDEX 1444937214SPrabhakar Kushwaha #define CONFIG_CONS_INDEX 2 1544937214SPrabhakar Kushwaha 1689a168f7SPriyanka Jain #ifdef CONFIG_FSL_QSPI 173049a583SPriyanka Jain #ifdef CONFIG_TARGET_LS2081ARDB 183049a583SPriyanka Jain #define CONFIG_QIXIS_I2C_ACCESS 193049a583SPriyanka Jain #endif 2089a168f7SPriyanka Jain #define CONFIG_SYS_I2C_EARLY_INIT 2189a168f7SPriyanka Jain #define CONFIG_DISPLAY_BOARDINFO_LATE 2289a168f7SPriyanka Jain #endif 2389a168f7SPriyanka Jain 24ed2530d0SRai Harninder #define I2C_MUX_CH_VOL_MONITOR 0xa 25ed2530d0SRai Harninder #define I2C_VOL_MONITOR_ADDR 0x38 26ed2530d0SRai Harninder #define CONFIG_VOL_MONITOR_IR36021_READ 27ed2530d0SRai Harninder #define CONFIG_VOL_MONITOR_IR36021_SET 28ed2530d0SRai Harninder 29ed2530d0SRai Harninder #define CONFIG_VID_FLS_ENV "ls2080ardb_vdd_mv" 30ed2530d0SRai Harninder #ifndef CONFIG_SPL_BUILD 31ed2530d0SRai Harninder #define CONFIG_VID 32ed2530d0SRai Harninder #endif 33ed2530d0SRai Harninder /* step the IR regulator in 5mV increments */ 34ed2530d0SRai Harninder #define IR_VDD_STEP_DOWN 5 35ed2530d0SRai Harninder #define IR_VDD_STEP_UP 5 36ed2530d0SRai Harninder /* The lowest and highest voltage allowed for LS2080ARDB */ 37ed2530d0SRai Harninder #define VDD_MV_MIN 819 38ed2530d0SRai Harninder #define VDD_MV_MAX 1212 39ed2530d0SRai Harninder 4044937214SPrabhakar Kushwaha #ifndef __ASSEMBLY__ 4144937214SPrabhakar Kushwaha unsigned long get_board_sys_clk(void); 4244937214SPrabhakar Kushwaha #endif 4344937214SPrabhakar Kushwaha 4444937214SPrabhakar Kushwaha #define CONFIG_SYS_CLK_FREQ get_board_sys_clk() 4544937214SPrabhakar Kushwaha #define CONFIG_DDR_CLK_FREQ 133333333 4644937214SPrabhakar Kushwaha #define COUNTER_FREQUENCY_REAL (CONFIG_SYS_CLK_FREQ/4) 4744937214SPrabhakar Kushwaha 4844937214SPrabhakar Kushwaha #define CONFIG_DDR_SPD 4944937214SPrabhakar Kushwaha #define CONFIG_DDR_ECC 5044937214SPrabhakar Kushwaha #define CONFIG_ECC_INIT_VIA_DDRCONTROLLER 5144937214SPrabhakar Kushwaha #define CONFIG_MEM_INIT_VALUE 0xdeadbeef 5244937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS1 0x51 5344937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS2 0x52 5444937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS3 0x53 5544937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS4 0x54 5644937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS5 0x55 5744937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS6 0x56 /* dummy address */ 5844937214SPrabhakar Kushwaha #define SPD_EEPROM_ADDRESS SPD_EEPROM_ADDRESS1 5944937214SPrabhakar Kushwaha #define CONFIG_SYS_SPD_BUS_NUM 0 /* SPD on I2C bus 0 */ 6044937214SPrabhakar Kushwaha #define CONFIG_DIMM_SLOTS_PER_CTLR 2 6144937214SPrabhakar Kushwaha #define CONFIG_CHIP_SELECTS_PER_CTRL 4 6244937214SPrabhakar Kushwaha #ifdef CONFIG_SYS_FSL_HAS_DP_DDR 6344937214SPrabhakar Kushwaha #define CONFIG_DP_DDR_DIMM_SLOTS_PER_CTLR 1 6444937214SPrabhakar Kushwaha #endif 6544937214SPrabhakar Kushwaha #define CONFIG_FSL_DDR_BIST /* enable built-in memory test */ 6644937214SPrabhakar Kushwaha 67989c5f0aSTang Yuantian /* SATA */ 68989c5f0aSTang Yuantian #define CONFIG_LIBATA 69989c5f0aSTang Yuantian #define CONFIG_SCSI_AHCI 70989c5f0aSTang Yuantian #define CONFIG_SCSI_AHCI_PLAT 71989c5f0aSTang Yuantian 72989c5f0aSTang Yuantian #define CONFIG_SYS_SATA1 AHCI_BASE_ADDR1 73989c5f0aSTang Yuantian #define CONFIG_SYS_SATA2 AHCI_BASE_ADDR2 74989c5f0aSTang Yuantian 75989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_SCSI_ID 1 76989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_LUN 1 77989c5f0aSTang Yuantian #define CONFIG_SYS_SCSI_MAX_DEVICE (CONFIG_SYS_SCSI_MAX_SCSI_ID * \ 78989c5f0aSTang Yuantian CONFIG_SYS_SCSI_MAX_LUN) 79989c5f0aSTang Yuantian 8089a168f7SPriyanka Jain #ifndef CONFIG_FSL_QSPI 8144937214SPrabhakar Kushwaha /* undefined CONFIG_FSL_DDR_SYNC_REFRESH for simulator */ 8244937214SPrabhakar Kushwaha 8344937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR0_CSPR_EXT (0x0) 8444937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_AMASK IFC_AMASK(128*1024*1024) 8544937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_AMASK_EARLY IFC_AMASK(64*1024*1024) 8644937214SPrabhakar Kushwaha 8744937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR0_CSPR \ 8844937214SPrabhakar Kushwaha (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | \ 8944937214SPrabhakar Kushwaha CSPR_PORT_SIZE_16 | \ 9044937214SPrabhakar Kushwaha CSPR_MSEL_NOR | \ 9144937214SPrabhakar Kushwaha CSPR_V) 9244937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR0_CSPR_EARLY \ 9344937214SPrabhakar Kushwaha (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS_EARLY) | \ 9444937214SPrabhakar Kushwaha CSPR_PORT_SIZE_16 | \ 9544937214SPrabhakar Kushwaha CSPR_MSEL_NOR | \ 9644937214SPrabhakar Kushwaha CSPR_V) 9744937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_CSOR CSOR_NOR_ADM_SHIFT(12) 9844937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_FTIM0 (FTIM0_NOR_TACSE(0x4) | \ 9944937214SPrabhakar Kushwaha FTIM0_NOR_TEADC(0x5) | \ 10044937214SPrabhakar Kushwaha FTIM0_NOR_TEAHC(0x5)) 10144937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_FTIM1 (FTIM1_NOR_TACO(0x35) | \ 10244937214SPrabhakar Kushwaha FTIM1_NOR_TRAD_NOR(0x1a) |\ 10344937214SPrabhakar Kushwaha FTIM1_NOR_TSEQRAD_NOR(0x13)) 10444937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_FTIM2 (FTIM2_NOR_TCS(0x4) | \ 10544937214SPrabhakar Kushwaha FTIM2_NOR_TCH(0x4) | \ 10644937214SPrabhakar Kushwaha FTIM2_NOR_TWPH(0x0E) | \ 10744937214SPrabhakar Kushwaha FTIM2_NOR_TWP(0x1c)) 10844937214SPrabhakar Kushwaha #define CONFIG_SYS_NOR_FTIM3 0x04000000 10944937214SPrabhakar Kushwaha #define CONFIG_SYS_IFC_CCR 0x01000000 11044937214SPrabhakar Kushwaha 111e856bdcfSMasahiro Yamada #ifdef CONFIG_MTD_NOR_FLASH 11244937214SPrabhakar Kushwaha #define CONFIG_FLASH_CFI_DRIVER 11344937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_CFI 11444937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 11544937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_QUIET_TEST 11644937214SPrabhakar Kushwaha #define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */ 11744937214SPrabhakar Kushwaha 11844937214SPrabhakar Kushwaha #define CONFIG_SYS_MAX_FLASH_BANKS 1 /* number of banks */ 11944937214SPrabhakar Kushwaha #define CONFIG_SYS_MAX_FLASH_SECT 1024 /* sectors per device */ 12044937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_ERASE_TOUT 60000 /* Flash Erase Timeout (ms) */ 12144937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout (ms) */ 12244937214SPrabhakar Kushwaha 12344937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_EMPTY_INFO 12444937214SPrabhakar Kushwaha #define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_FLASH_BASE,\ 12544937214SPrabhakar Kushwaha CONFIG_SYS_FLASH_BASE + 0x40000000} 12644937214SPrabhakar Kushwaha #endif 12744937214SPrabhakar Kushwaha 12844937214SPrabhakar Kushwaha #define CONFIG_NAND_FSL_IFC 12944937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_MAX_ECCPOS 256 13044937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_MAX_OOBFREE 2 13144937214SPrabhakar Kushwaha 13244937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_CSPR_EXT (0x0) 13344937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_CSPR (CSPR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \ 13444937214SPrabhakar Kushwaha | CSPR_PORT_SIZE_8 /* Port Size = 8 bit */ \ 13544937214SPrabhakar Kushwaha | CSPR_MSEL_NAND /* MSEL = NAND */ \ 13644937214SPrabhakar Kushwaha | CSPR_V) 13744937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_AMASK IFC_AMASK(64 * 1024) 13844937214SPrabhakar Kushwaha 13944937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_CSOR (CSOR_NAND_ECC_ENC_EN /* ECC on encode */ \ 14044937214SPrabhakar Kushwaha | CSOR_NAND_ECC_DEC_EN /* ECC on decode */ \ 14144937214SPrabhakar Kushwaha | CSOR_NAND_ECC_MODE_4 /* 4-bit ECC */ \ 14244937214SPrabhakar Kushwaha | CSOR_NAND_RAL_3 /* RAL = 3Byes */ \ 14344937214SPrabhakar Kushwaha | CSOR_NAND_PGS_4K /* Page Size = 4K */ \ 14444937214SPrabhakar Kushwaha | CSOR_NAND_SPRZ_224 /* Spare size = 224 */ \ 14544937214SPrabhakar Kushwaha | CSOR_NAND_PB(128)) /* Pages Per Block 128*/ 14644937214SPrabhakar Kushwaha 14744937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_ONFI_DETECTION 14844937214SPrabhakar Kushwaha 14944937214SPrabhakar Kushwaha /* ONFI NAND Flash mode0 Timing Params */ 15044937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_FTIM0 (FTIM0_NAND_TCCST(0x0e) | \ 15144937214SPrabhakar Kushwaha FTIM0_NAND_TWP(0x30) | \ 15244937214SPrabhakar Kushwaha FTIM0_NAND_TWCHT(0x0e) | \ 15344937214SPrabhakar Kushwaha FTIM0_NAND_TWH(0x14)) 15444937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_FTIM1 (FTIM1_NAND_TADLE(0x64) | \ 15544937214SPrabhakar Kushwaha FTIM1_NAND_TWBE(0xab) | \ 15644937214SPrabhakar Kushwaha FTIM1_NAND_TRR(0x1c) | \ 15744937214SPrabhakar Kushwaha FTIM1_NAND_TRP(0x30)) 15844937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_FTIM2 (FTIM2_NAND_TRAD(0x1e) | \ 15944937214SPrabhakar Kushwaha FTIM2_NAND_TREH(0x14) | \ 16044937214SPrabhakar Kushwaha FTIM2_NAND_TWHRE(0x3c)) 16144937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_FTIM3 0x0 16244937214SPrabhakar Kushwaha 16344937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE } 16444937214SPrabhakar Kushwaha #define CONFIG_SYS_MAX_NAND_DEVICE 1 16544937214SPrabhakar Kushwaha #define CONFIG_MTD_NAND_VERIFY_WRITE 16644937214SPrabhakar Kushwaha #define CONFIG_CMD_NAND 16744937214SPrabhakar Kushwaha 16844937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_BLOCK_SIZE (512 * 1024) 16944937214SPrabhakar Kushwaha #define CONFIG_FSL_QIXIS /* use common QIXIS code */ 17044937214SPrabhakar Kushwaha #define QIXIS_LBMAP_SWITCH 0x06 17144937214SPrabhakar Kushwaha #define QIXIS_LBMAP_MASK 0x0f 17244937214SPrabhakar Kushwaha #define QIXIS_LBMAP_SHIFT 0 17344937214SPrabhakar Kushwaha #define QIXIS_LBMAP_DFLTBANK 0x00 17444937214SPrabhakar Kushwaha #define QIXIS_LBMAP_ALTBANK 0x04 17544937214SPrabhakar Kushwaha #define QIXIS_LBMAP_NAND 0x09 17644937214SPrabhakar Kushwaha #define QIXIS_RST_CTL_RESET 0x31 17744937214SPrabhakar Kushwaha #define QIXIS_RST_CTL_RESET_EN 0x30 17844937214SPrabhakar Kushwaha #define QIXIS_RCFG_CTL_RECONFIG_IDLE 0x20 17944937214SPrabhakar Kushwaha #define QIXIS_RCFG_CTL_RECONFIG_START 0x21 18044937214SPrabhakar Kushwaha #define QIXIS_RCFG_CTL_WATCHDOG_ENBLE 0x08 18144937214SPrabhakar Kushwaha #define QIXIS_RCW_SRC_NAND 0x119 18244937214SPrabhakar Kushwaha #define QIXIS_RST_FORCE_MEM 0x01 18344937214SPrabhakar Kushwaha 18444937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR3_EXT (0x0) 18544937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR3 (CSPR_PHYS_ADDR(QIXIS_BASE_PHYS_EARLY) \ 18644937214SPrabhakar Kushwaha | CSPR_PORT_SIZE_8 \ 18744937214SPrabhakar Kushwaha | CSPR_MSEL_GPCM \ 18844937214SPrabhakar Kushwaha | CSPR_V) 18944937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR3_FINAL (CSPR_PHYS_ADDR(QIXIS_BASE_PHYS) \ 19044937214SPrabhakar Kushwaha | CSPR_PORT_SIZE_8 \ 19144937214SPrabhakar Kushwaha | CSPR_MSEL_GPCM \ 19244937214SPrabhakar Kushwaha | CSPR_V) 19344937214SPrabhakar Kushwaha 19444937214SPrabhakar Kushwaha #define CONFIG_SYS_AMASK3 IFC_AMASK(64*1024) 19544937214SPrabhakar Kushwaha #define CONFIG_SYS_CSOR3 CSOR_GPCM_ADM_SHIFT(12) 19644937214SPrabhakar Kushwaha /* QIXIS Timing parameters for IFC CS3 */ 19744937214SPrabhakar Kushwaha #define CONFIG_SYS_CS3_FTIM0 (FTIM0_GPCM_TACSE(0x0e) | \ 19844937214SPrabhakar Kushwaha FTIM0_GPCM_TEADC(0x0e) | \ 19944937214SPrabhakar Kushwaha FTIM0_GPCM_TEAHC(0x0e)) 20044937214SPrabhakar Kushwaha #define CONFIG_SYS_CS3_FTIM1 (FTIM1_GPCM_TACO(0xff) | \ 20144937214SPrabhakar Kushwaha FTIM1_GPCM_TRAD(0x3f)) 20244937214SPrabhakar Kushwaha #define CONFIG_SYS_CS3_FTIM2 (FTIM2_GPCM_TCS(0xf) | \ 20344937214SPrabhakar Kushwaha FTIM2_GPCM_TCH(0xf) | \ 20444937214SPrabhakar Kushwaha FTIM2_GPCM_TWP(0x3E)) 20544937214SPrabhakar Kushwaha #define CONFIG_SYS_CS3_FTIM3 0x0 20644937214SPrabhakar Kushwaha 20744937214SPrabhakar Kushwaha #if defined(CONFIG_SPL) && defined(CONFIG_NAND) 20844937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NOR0_CSPR_EXT 20944937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR2 CONFIG_SYS_NOR0_CSPR_EARLY 21044937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR2_FINAL CONFIG_SYS_NOR0_CSPR 21144937214SPrabhakar Kushwaha #define CONFIG_SYS_AMASK2 CONFIG_SYS_NOR_AMASK 21244937214SPrabhakar Kushwaha #define CONFIG_SYS_CSOR2 CONFIG_SYS_NOR_CSOR 21344937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NOR_FTIM0 21444937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NOR_FTIM1 21544937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NOR_FTIM2 21644937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NOR_FTIM3 21744937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NAND_CSPR_EXT 21844937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR0 CONFIG_SYS_NAND_CSPR 21944937214SPrabhakar Kushwaha #define CONFIG_SYS_AMASK0 CONFIG_SYS_NAND_AMASK 22044937214SPrabhakar Kushwaha #define CONFIG_SYS_CSOR0 CONFIG_SYS_NAND_CSOR 22144937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NAND_FTIM0 22244937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NAND_FTIM1 22344937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NAND_FTIM2 22444937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NAND_FTIM3 22544937214SPrabhakar Kushwaha 22644937214SPrabhakar Kushwaha #define CONFIG_ENV_OFFSET (2048 * 1024) 22744937214SPrabhakar Kushwaha #define CONFIG_ENV_SECT_SIZE 0x20000 22844937214SPrabhakar Kushwaha #define CONFIG_ENV_SIZE 0x2000 22944937214SPrabhakar Kushwaha #define CONFIG_SPL_PAD_TO 0x80000 23044937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_U_BOOT_OFFS (1024 * 1024) 23144937214SPrabhakar Kushwaha #define CONFIG_SYS_NAND_U_BOOT_SIZE (512 * 1024) 23244937214SPrabhakar Kushwaha #else 23344937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT 23444937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR_EARLY 23544937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR0_FINAL CONFIG_SYS_NOR0_CSPR 23644937214SPrabhakar Kushwaha #define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK 23744937214SPrabhakar Kushwaha #define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR 23844937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0 23944937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1 24044937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2 24144937214SPrabhakar Kushwaha #define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3 24244937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_NAND_CSPR_EXT 24344937214SPrabhakar Kushwaha #define CONFIG_SYS_CSPR2 CONFIG_SYS_NAND_CSPR 24444937214SPrabhakar Kushwaha #define CONFIG_SYS_AMASK2 CONFIG_SYS_NAND_AMASK 24544937214SPrabhakar Kushwaha #define CONFIG_SYS_CSOR2 CONFIG_SYS_NAND_CSOR 24644937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM0 CONFIG_SYS_NAND_FTIM0 24744937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM1 CONFIG_SYS_NAND_FTIM1 24844937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM2 CONFIG_SYS_NAND_FTIM2 24944937214SPrabhakar Kushwaha #define CONFIG_SYS_CS2_FTIM3 CONFIG_SYS_NAND_FTIM3 25044937214SPrabhakar Kushwaha 251f5bf23d8SSantan Kumar #define CONFIG_ENV_ADDR (CONFIG_SYS_FLASH_BASE + 0x300000) 25244937214SPrabhakar Kushwaha #define CONFIG_ENV_SECT_SIZE 0x20000 25344937214SPrabhakar Kushwaha #define CONFIG_ENV_SIZE 0x2000 25444937214SPrabhakar Kushwaha #endif 25544937214SPrabhakar Kushwaha 25644937214SPrabhakar Kushwaha /* Debug Server firmware */ 25744937214SPrabhakar Kushwaha #define CONFIG_SYS_DEBUG_SERVER_FW_IN_NOR 25844937214SPrabhakar Kushwaha #define CONFIG_SYS_DEBUG_SERVER_FW_ADDR 0x580D00000ULL 25989a168f7SPriyanka Jain #endif 26044937214SPrabhakar Kushwaha #define CONFIG_SYS_LS_MC_BOOT_TIMEOUT_MS 5000 26144937214SPrabhakar Kushwaha 2623049a583SPriyanka Jain #ifdef CONFIG_TARGET_LS2081ARDB 2633049a583SPriyanka Jain #define CONFIG_FSL_QIXIS /* use common QIXIS code */ 2643049a583SPriyanka Jain #define QIXIS_QMAP_MASK 0x07 2653049a583SPriyanka Jain #define QIXIS_QMAP_SHIFT 5 2663049a583SPriyanka Jain #define QIXIS_LBMAP_DFLTBANK 0x00 2673049a583SPriyanka Jain #define QIXIS_LBMAP_QSPI 0x00 2683049a583SPriyanka Jain #define QIXIS_RCW_SRC_QSPI 0x62 2693049a583SPriyanka Jain #define QIXIS_LBMAP_ALTBANK 0x20 2703049a583SPriyanka Jain #define QIXIS_RST_CTL_RESET 0x31 2713049a583SPriyanka Jain #define QIXIS_RCFG_CTL_RECONFIG_IDLE 0x20 2723049a583SPriyanka Jain #define QIXIS_RCFG_CTL_RECONFIG_START 0x21 2733049a583SPriyanka Jain #define QIXIS_RCFG_CTL_WATCHDOG_ENBLE 0x08 2743049a583SPriyanka Jain #define QIXIS_LBMAP_MASK 0x0f 2753049a583SPriyanka Jain #define QIXIS_RST_CTL_RESET_EN 0x30 2763049a583SPriyanka Jain #endif 2773049a583SPriyanka Jain 27844937214SPrabhakar Kushwaha /* 27944937214SPrabhakar Kushwaha * I2C 28044937214SPrabhakar Kushwaha */ 2813049a583SPriyanka Jain #ifdef CONFIG_TARGET_LS2081ARDB 2823049a583SPriyanka Jain #define CONFIG_SYS_I2C_FPGA_ADDR 0x66 2833049a583SPriyanka Jain #endif 28444937214SPrabhakar Kushwaha #define I2C_MUX_PCA_ADDR 0x75 28544937214SPrabhakar Kushwaha #define I2C_MUX_PCA_ADDR_PRI 0x75 /* Primary Mux*/ 28644937214SPrabhakar Kushwaha 28744937214SPrabhakar Kushwaha /* I2C bus multiplexer */ 28844937214SPrabhakar Kushwaha #define I2C_MUX_CH_DEFAULT 0x8 28944937214SPrabhakar Kushwaha 29044937214SPrabhakar Kushwaha /* SPI */ 29189a168f7SPriyanka Jain #if defined(CONFIG_FSL_QSPI) || defined(CONFIG_FSL_DSPI) 29244937214SPrabhakar Kushwaha #define CONFIG_SPI_FLASH 29389a168f7SPriyanka Jain #ifdef CONFIG_FSL_QSPI 29421640db5SYuan Yao #define CONFIG_SPI_FLASH_STMICRO 29544937214SPrabhakar Kushwaha #endif 29689a168f7SPriyanka Jain #ifdef CONFIG_FSL_QSPI 2973049a583SPriyanka Jain #ifdef CONFIG_TARGET_LS2081ARDB 2983049a583SPriyanka Jain #define CONFIG_SPI_FLASH_STMICRO 2993049a583SPriyanka Jain #else 30089a168f7SPriyanka Jain #define CONFIG_SPI_FLASH_SPANSION 3013049a583SPriyanka Jain #endif 30289a168f7SPriyanka Jain #define FSL_QSPI_FLASH_SIZE SZ_64M /* 64MB */ 30389a168f7SPriyanka Jain #define FSL_QSPI_FLASH_NUM 2 30489a168f7SPriyanka Jain #endif 30589a168f7SPriyanka Jain #endif 30644937214SPrabhakar Kushwaha 30744937214SPrabhakar Kushwaha /* 30844937214SPrabhakar Kushwaha * RTC configuration 30944937214SPrabhakar Kushwaha */ 31044937214SPrabhakar Kushwaha #define RTC 3113049a583SPriyanka Jain #ifdef CONFIG_TARGET_LS2081ARDB 3123049a583SPriyanka Jain #define CONFIG_RTC_PCF8563 1 3133049a583SPriyanka Jain #define CONFIG_SYS_I2C_RTC_ADDR 0x51 3143049a583SPriyanka Jain #else 31544937214SPrabhakar Kushwaha #define CONFIG_RTC_DS3231 1 31644937214SPrabhakar Kushwaha #define CONFIG_SYS_I2C_RTC_ADDR 0x68 3173049a583SPriyanka Jain #endif 31844937214SPrabhakar Kushwaha 31944937214SPrabhakar Kushwaha /* EEPROM */ 32044937214SPrabhakar Kushwaha #define CONFIG_ID_EEPROM 32144937214SPrabhakar Kushwaha #define CONFIG_SYS_I2C_EEPROM_NXID 32244937214SPrabhakar Kushwaha #define CONFIG_SYS_EEPROM_BUS_NUM 0 32344937214SPrabhakar Kushwaha #define CONFIG_SYS_I2C_EEPROM_ADDR 0x57 32444937214SPrabhakar Kushwaha #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1 32544937214SPrabhakar Kushwaha #define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 3 32644937214SPrabhakar Kushwaha #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 5 32744937214SPrabhakar Kushwaha 32844937214SPrabhakar Kushwaha #define CONFIG_FSL_MEMAC 32944937214SPrabhakar Kushwaha 33044937214SPrabhakar Kushwaha #ifdef CONFIG_PCI 33144937214SPrabhakar Kushwaha #define CONFIG_PCI_SCAN_SHOW 33244937214SPrabhakar Kushwaha #define CONFIG_CMD_PCI 33344937214SPrabhakar Kushwaha #endif 33444937214SPrabhakar Kushwaha 33544937214SPrabhakar Kushwaha /* MMC */ 33644937214SPrabhakar Kushwaha #ifdef CONFIG_MMC 33744937214SPrabhakar Kushwaha #define CONFIG_FSL_ESDHC 33844937214SPrabhakar Kushwaha #define CONFIG_SYS_FSL_MMC_HAS_CAPBLT_VS33 33944937214SPrabhakar Kushwaha #endif 34044937214SPrabhakar Kushwaha 34144937214SPrabhakar Kushwaha #define CONFIG_MISC_INIT_R 34244937214SPrabhakar Kushwaha 34344937214SPrabhakar Kushwaha /* 34444937214SPrabhakar Kushwaha * USB 34544937214SPrabhakar Kushwaha */ 34644937214SPrabhakar Kushwaha #define CONFIG_HAS_FSL_XHCI_USB 34744937214SPrabhakar Kushwaha #define CONFIG_USB_XHCI_FSL 34844937214SPrabhakar Kushwaha #define CONFIG_USB_MAX_CONTROLLER_COUNT 2 34944937214SPrabhakar Kushwaha #define CONFIG_SYS_USB_XHCI_MAX_ROOT_PORTS 2 35044937214SPrabhakar Kushwaha 351b99ebaf9SAlexander Graf #undef CONFIG_CMDLINE_EDITING 352b99ebaf9SAlexander Graf #include <config_distro_defaults.h> 353b99ebaf9SAlexander Graf 354b99ebaf9SAlexander Graf #define BOOT_TARGET_DEVICES(func) \ 355b99ebaf9SAlexander Graf func(USB, usb, 0) \ 356b99ebaf9SAlexander Graf func(MMC, mmc, 0) \ 357b99ebaf9SAlexander Graf func(SCSI, scsi, 0) \ 358b99ebaf9SAlexander Graf func(DHCP, dhcp, na) 359b99ebaf9SAlexander Graf #include <config_distro_bootcmd.h> 360b99ebaf9SAlexander Graf 36144937214SPrabhakar Kushwaha /* Initial environment variables */ 36244937214SPrabhakar Kushwaha #undef CONFIG_EXTRA_ENV_SETTINGS 3639ed44787SUdit Agarwal #ifdef CONFIG_SECURE_BOOT 3649ed44787SUdit Agarwal #define CONFIG_EXTRA_ENV_SETTINGS \ 3659ed44787SUdit Agarwal "hwconfig=fsl_ddr:bank_intlv=auto\0" \ 3669ed44787SUdit Agarwal "scriptaddr=0x80800000\0" \ 3679ed44787SUdit Agarwal "kernel_addr_r=0x81000000\0" \ 3689ed44787SUdit Agarwal "pxefile_addr_r=0x81000000\0" \ 3699ed44787SUdit Agarwal "fdt_addr_r=0x88000000\0" \ 3709ed44787SUdit Agarwal "ramdisk_addr_r=0x89000000\0" \ 3719ed44787SUdit Agarwal "loadaddr=0x80100000\0" \ 3729ed44787SUdit Agarwal "kernel_addr=0x100000\0" \ 3739ed44787SUdit Agarwal "ramdisk_addr=0x800000\0" \ 3749ed44787SUdit Agarwal "ramdisk_size=0x2000000\0" \ 3759ed44787SUdit Agarwal "fdt_high=0xa0000000\0" \ 3769ed44787SUdit Agarwal "initrd_high=0xffffffffffffffff\0" \ 3777676074aSUdit Agarwal "kernel_start=0x581000000\0" \ 3789ed44787SUdit Agarwal "kernel_load=0xa0000000\0" \ 3799ed44787SUdit Agarwal "kernel_size=0x2800000\0" \ 3806d7b9e78SSantan Kumar "mcmemsize=0x40000000\0" \ 3819ed44787SUdit Agarwal "fdtfile=fsl-ls2080a-rdb.dtb\0" \ 3827676074aSUdit Agarwal "mcinitcmd=esbc_validate 0x580700000;" \ 3837676074aSUdit Agarwal "esbc_validate 0x580740000;" \ 3847676074aSUdit Agarwal "fsl_mc start mc 0x580a00000" \ 3857676074aSUdit Agarwal " 0x580e00000 \0" \ 3869ed44787SUdit Agarwal BOOTENV 3879ed44787SUdit Agarwal #else 38889a168f7SPriyanka Jain #define CONFIG_EXTRA_ENV_SETTINGS \ 38989a168f7SPriyanka Jain "hwconfig=fsl_ddr:bank_intlv=auto\0" \ 39044937214SPrabhakar Kushwaha "ramdisk_addr=0x800000\0" \ 39144937214SPrabhakar Kushwaha "ramdisk_size=0x2000000\0" \ 39244937214SPrabhakar Kushwaha "fdt_high=0xa0000000\0" \ 39344937214SPrabhakar Kushwaha "initrd_high=0xffffffffffffffff\0" \ 394*0a09d20bSZhang Ying-22455 "fdt_addr=0x64f00000\0" \ 395*0a09d20bSZhang Ying-22455 "kernel_addr=0x65000000\0" \ 396*0a09d20bSZhang Ying-22455 "scriptaddr=0x80000000\0" \ 397*0a09d20bSZhang Ying-22455 "fdtheader_addr_r=0x80100000\0" \ 398*0a09d20bSZhang Ying-22455 "kernelheader_addr_r=0x80200000\0" \ 399*0a09d20bSZhang Ying-22455 "kernel_addr_r=0x81000000\0" \ 400*0a09d20bSZhang Ying-22455 "fdt_addr_r=0x90000000\0" \ 401*0a09d20bSZhang Ying-22455 "load_addr=0xa0000000\0" \ 40216ed8560SPrabhakar Kushwaha "kernel_size=0x2800000\0" \ 403*0a09d20bSZhang Ying-22455 "console=ttyAMA0,38400n8\0" \ 404*0a09d20bSZhang Ying-22455 BOOTENV \ 405*0a09d20bSZhang Ying-22455 "boot_scripts=ls2088ardb_boot.scr\0" \ 406*0a09d20bSZhang Ying-22455 "scan_dev_for_boot_part=" \ 407*0a09d20bSZhang Ying-22455 "part list ${devtype} ${devnum} devplist; " \ 408*0a09d20bSZhang Ying-22455 "env exists devplist || setenv devplist 1; " \ 409*0a09d20bSZhang Ying-22455 "for distro_bootpart in ${devplist}; do " \ 410*0a09d20bSZhang Ying-22455 "if fstype ${devtype} " \ 411*0a09d20bSZhang Ying-22455 "${devnum}:${distro_bootpart} " \ 412*0a09d20bSZhang Ying-22455 "bootfstype; then " \ 413*0a09d20bSZhang Ying-22455 "run scan_dev_for_boot; " \ 414*0a09d20bSZhang Ying-22455 "fi; " \ 415*0a09d20bSZhang Ying-22455 "done\0" \ 416*0a09d20bSZhang Ying-22455 "installer=load mmc 0:2 $load_addr " \ 417*0a09d20bSZhang Ying-22455 "/flex_installer_arm64.itb; " \ 418*0a09d20bSZhang Ying-22455 "bootm $load_addr#ls2088ardb\0" \ 419*0a09d20bSZhang Ying-22455 "qspi_bootcmd=echo Trying load from qspi..;" \ 420*0a09d20bSZhang Ying-22455 "sf probe && sf read $load_addr " \ 421*0a09d20bSZhang Ying-22455 "$kernel_addr $kernel_size &&" \ 422*0a09d20bSZhang Ying-22455 " bootm $load_addr#$board\0" \ 423*0a09d20bSZhang Ying-22455 "nor_bootcmd=echo Trying load from nor..;" \ 424*0a09d20bSZhang Ying-22455 "cp.b $kernel_addr $load_addr " \ 425*0a09d20bSZhang Ying-22455 "$kernel_size && bootm $load_addr#$board\0" 42689a168f7SPriyanka Jain #endif 4279ed44787SUdit Agarwal 428*0a09d20bSZhang Ying-22455 #undef CONFIG_BOOTCOMMAND 429*0a09d20bSZhang Ying-22455 #ifdef CONFIG_QSPI_BOOT 430*0a09d20bSZhang Ying-22455 /* Try to boot an on-QSPI kernel first, then do normal distro boot */ 431*0a09d20bSZhang Ying-22455 #define CONFIG_BOOTCOMMAND \ 432*0a09d20bSZhang Ying-22455 "fsl_mc start mc 0x20a00000 0x20e00000 &&" \ 433*0a09d20bSZhang Ying-22455 " fsl_mc lazyapply dpl 0x20d00000;" \ 434*0a09d20bSZhang Ying-22455 "run distro_bootcmd;run qspi_bootcmd" 435*0a09d20bSZhang Ying-22455 #else 436*0a09d20bSZhang Ying-22455 /* Try to boot an on-NOR kernel first, then do normal distro boot */ 437*0a09d20bSZhang Ying-22455 #define CONFIG_BOOTCOMMAND \ 438*0a09d20bSZhang Ying-22455 "fsl_mc start mc 0x580a00000 0x580e00000 &&" \ 439*0a09d20bSZhang Ying-22455 " fsl_mc lazyapply dpl 0x580d00000;" \ 440*0a09d20bSZhang Ying-22455 "run distro_bootcmd;run nor_bootcmd" 441*0a09d20bSZhang Ying-22455 #endif 44244937214SPrabhakar Kushwaha 44344937214SPrabhakar Kushwaha #undef CONFIG_BOOTARGS 44444937214SPrabhakar Kushwaha #define CONFIG_BOOTARGS "console=ttyS1,115200 root=/dev/ram0 " \ 445b22b1dc6SPratiyush Mohan Srivastava "earlycon=uart8250,mmio,0x21c0600 " \ 44644937214SPrabhakar Kushwaha "ramdisk_size=0x2000000 default_hugepagesz=2m" \ 4479e71bb9cSAshish Kumar " hugepagesz=2m hugepages=256" 44844937214SPrabhakar Kushwaha 44944937214SPrabhakar Kushwaha /* MAC/PHY configuration */ 45044937214SPrabhakar Kushwaha #ifdef CONFIG_FSL_MC_ENET 45144937214SPrabhakar Kushwaha #define CONFIG_PHYLIB_10G 45244937214SPrabhakar Kushwaha #define CONFIG_PHY_AQUANTIA 45344937214SPrabhakar Kushwaha #define CONFIG_PHY_CORTINA 45444937214SPrabhakar Kushwaha #define CONFIG_PHYLIB 45544937214SPrabhakar Kushwaha #define CONFIG_SYS_CORTINA_FW_IN_NOR 45689a168f7SPriyanka Jain #ifdef CONFIG_QSPI_BOOT 45789a168f7SPriyanka Jain #define CONFIG_CORTINA_FW_ADDR 0x20980000 45889a168f7SPriyanka Jain #else 459f5bf23d8SSantan Kumar #define CONFIG_CORTINA_FW_ADDR 0x580980000 46089a168f7SPriyanka Jain #endif 46144937214SPrabhakar Kushwaha #define CONFIG_CORTINA_FW_LENGTH 0x40000 46244937214SPrabhakar Kushwaha 46344937214SPrabhakar Kushwaha #define CORTINA_PHY_ADDR1 0x10 46444937214SPrabhakar Kushwaha #define CORTINA_PHY_ADDR2 0x11 46544937214SPrabhakar Kushwaha #define CORTINA_PHY_ADDR3 0x12 46644937214SPrabhakar Kushwaha #define CORTINA_PHY_ADDR4 0x13 46744937214SPrabhakar Kushwaha #define AQ_PHY_ADDR1 0x00 46844937214SPrabhakar Kushwaha #define AQ_PHY_ADDR2 0x01 46944937214SPrabhakar Kushwaha #define AQ_PHY_ADDR3 0x02 47044937214SPrabhakar Kushwaha #define AQ_PHY_ADDR4 0x03 471abc7d0f7SShaohui Xie #define AQR405_IRQ_MASK 0x36 47244937214SPrabhakar Kushwaha 47344937214SPrabhakar Kushwaha #define CONFIG_MII 4747ad9cc96SPrabhakar Kushwaha #define CONFIG_ETHPRIME "DPMAC1@xgmii" 47544937214SPrabhakar Kushwaha #define CONFIG_PHY_GIGE 47644937214SPrabhakar Kushwaha #define CONFIG_PHY_AQUANTIA 47744937214SPrabhakar Kushwaha #endif 47844937214SPrabhakar Kushwaha 479fcfdb6d5SSaksham Jain #include <asm/fsl_secure_boot.h> 480fcfdb6d5SSaksham Jain 48144937214SPrabhakar Kushwaha #endif /* __LS2_RDB_H */ 482