blob: ae452075ac0d29c6bbcdff4bf6d05fc14980e091 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Ashish Kumar77697762017-08-31 16:12:55 +05302/*
Yangbo Lu34f39ce2021-06-03 10:51:19 +08003 * Copyright 2017, 2020-2021 NXP
Ashish Kumar77697762017-08-31 16:12:55 +05304 */
5
6#ifndef __LS1088A_QDS_H
7#define __LS1088A_QDS_H
8
9#include "ls1088a_common.h"
10
Ashish Kumar91fded62017-11-06 13:18:44 +053011#if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_SD_BOOT_QSPI)
Ashish Kumar77697762017-08-31 16:12:55 +053012#define SYS_NO_FLASH
Ashish Kumar77697762017-08-31 16:12:55 +053013#endif
14
Tom Rini2f8a6db2021-12-14 13:36:40 -050015#define COUNTER_FREQUENCY_REAL (get_board_sys_clk()/4)
Ashish Kumar77697762017-08-31 16:12:55 +053016
Ashish Kumar77697762017-08-31 16:12:55 +053017#define CONFIG_MEM_INIT_VALUE 0xdeadbeef
18#define SPD_EEPROM_ADDRESS 0x51
Ashish Kumar77697762017-08-31 16:12:55 +053019
20
21/*
22 * IFC Definitions
23 */
24#if !defined(CONFIG_QSPI_BOOT) && !defined(CONFIG_SD_BOOT_QSPI)
25#define CONFIG_SYS_NOR0_CSPR_EXT (0x0)
26#define CONFIG_SYS_NOR_AMASK IFC_AMASK(128*1024*1024)
27#define CONFIG_SYS_NOR_AMASK_EARLY IFC_AMASK(64*1024*1024)
28
29#define CONFIG_SYS_NOR0_CSPR \
30 (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS) | \
31 CSPR_PORT_SIZE_16 | \
32 CSPR_MSEL_NOR | \
33 CSPR_V)
34#define CONFIG_SYS_NOR0_CSPR_EARLY \
35 (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE_PHYS_EARLY) | \
36 CSPR_PORT_SIZE_16 | \
37 CSPR_MSEL_NOR | \
38 CSPR_V)
39#define CONFIG_SYS_NOR1_CSPR \
40 (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH1_BASE_PHYS) | \
41 CSPR_PORT_SIZE_16 | \
42 CSPR_MSEL_NOR | \
43 CSPR_V)
44#define CONFIG_SYS_NOR1_CSPR_EARLY \
45 (CSPR_PHYS_ADDR(CONFIG_SYS_FLASH1_BASE_PHYS_EARLY) | \
46 CSPR_PORT_SIZE_16 | \
47 CSPR_MSEL_NOR | \
48 CSPR_V)
49#define CONFIG_SYS_NOR_CSOR CSOR_NOR_ADM_SHIFT(12)
50#define CONFIG_SYS_NOR_FTIM0 (FTIM0_NOR_TACSE(0x4) | \
51 FTIM0_NOR_TEADC(0x5) | \
Ashish Kumarc1c597e2018-02-19 14:16:58 +053052 FTIM0_NOR_TAVDS(0x6) | \
Ashish Kumar77697762017-08-31 16:12:55 +053053 FTIM0_NOR_TEAHC(0x5))
54#define CONFIG_SYS_NOR_FTIM1 (FTIM1_NOR_TACO(0x35) | \
Ashish Kumarc1c597e2018-02-19 14:16:58 +053055 FTIM1_NOR_TRAD_NOR(0x1a) | \
Ashish Kumar77697762017-08-31 16:12:55 +053056 FTIM1_NOR_TSEQRAD_NOR(0x13))
Ashish Kumarc1c597e2018-02-19 14:16:58 +053057#define CONFIG_SYS_NOR_FTIM2 (FTIM2_NOR_TCS(0x8) | \
58 FTIM2_NOR_TCH(0x8) | \
59 FTIM2_NOR_TWPH(0xe) | \
Ashish Kumar77697762017-08-31 16:12:55 +053060 FTIM2_NOR_TWP(0x1c))
61#define CONFIG_SYS_NOR_FTIM3 0x04000000
62#define CONFIG_SYS_IFC_CCR 0x01000000
63
64#ifndef SYS_NO_FLASH
Ashish Kumar77697762017-08-31 16:12:55 +053065#define CONFIG_FLASH_SHOW_PROGRESS 45 /* count down from 45/5: 9..1 */
66
Ashish Kumar77697762017-08-31 16:12:55 +053067#define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_FLASH_BASE,\
68 CONFIG_SYS_FLASH_BASE + 0x40000000}
69#endif
70#endif
71
Tom Rini4e590942022-11-12 17:36:51 -050072#define CFG_SYS_NAND_CSPR_EXT (0x0)
73#define CFG_SYS_NAND_CSPR (CSPR_PHYS_ADDR(CFG_SYS_NAND_BASE_PHYS) \
Ashish Kumar77697762017-08-31 16:12:55 +053074 | CSPR_PORT_SIZE_8 /* Port Size = 8 bit */ \
75 | CSPR_MSEL_NAND /* MSEL = NAND */ \
76 | CSPR_V)
Tom Rini4e590942022-11-12 17:36:51 -050077#define CFG_SYS_NAND_AMASK IFC_AMASK(64 * 1024)
Ashish Kumar77697762017-08-31 16:12:55 +053078
Tom Rini4e590942022-11-12 17:36:51 -050079#define CFG_SYS_NAND_CSOR (CSOR_NAND_ECC_ENC_EN /* ECC on encode */ \
Ashish Kumar77697762017-08-31 16:12:55 +053080 | CSOR_NAND_ECC_DEC_EN /* ECC on decode */ \
81 | CSOR_NAND_ECC_MODE_4 /* 4-bit ECC */ \
82 | CSOR_NAND_RAL_3 /* RAL = 3Byes */ \
83 | CSOR_NAND_PGS_2K /* Page Size = 2K */ \
84 | CSOR_NAND_SPRZ_64/* Spare size = 64 */ \
85 | CSOR_NAND_PB(64)) /*Pages Per Block = 64*/
86
Ashish Kumar77697762017-08-31 16:12:55 +053087/* ONFI NAND Flash mode0 Timing Params */
Tom Rini4e590942022-11-12 17:36:51 -050088#define CFG_SYS_NAND_FTIM0 (FTIM0_NAND_TCCST(0x07) | \
Ashish Kumar77697762017-08-31 16:12:55 +053089 FTIM0_NAND_TWP(0x18) | \
90 FTIM0_NAND_TWCHT(0x07) | \
91 FTIM0_NAND_TWH(0x0a))
Tom Rini4e590942022-11-12 17:36:51 -050092#define CFG_SYS_NAND_FTIM1 (FTIM1_NAND_TADLE(0x32) | \
Ashish Kumar77697762017-08-31 16:12:55 +053093 FTIM1_NAND_TWBE(0x39) | \
94 FTIM1_NAND_TRR(0x0e) | \
95 FTIM1_NAND_TRP(0x18))
Tom Rini4e590942022-11-12 17:36:51 -050096#define CFG_SYS_NAND_FTIM2 (FTIM2_NAND_TRAD(0x0f) | \
Ashish Kumar77697762017-08-31 16:12:55 +053097 FTIM2_NAND_TREH(0x0a) | \
98 FTIM2_NAND_TWHRE(0x1e))
Tom Rini4e590942022-11-12 17:36:51 -050099#define CFG_SYS_NAND_FTIM3 0x0
Ashish Kumar77697762017-08-31 16:12:55 +0530100
Tom Rini4e590942022-11-12 17:36:51 -0500101#define CFG_SYS_NAND_BASE_LIST { CFG_SYS_NAND_BASE }
Ashish Kumar77697762017-08-31 16:12:55 +0530102#define CONFIG_MTD_NAND_VERIFY_WRITE
Ashish Kumar77697762017-08-31 16:12:55 +0530103
Ashish Kumar77697762017-08-31 16:12:55 +0530104#define CONFIG_SYS_I2C_FPGA_ADDR 0x66
105#define QIXIS_LBMAP_SWITCH 6
106#define QIXIS_QMAP_MASK 0xe0
107#define QIXIS_QMAP_SHIFT 5
108#define QIXIS_LBMAP_MASK 0x0f
109#define QIXIS_LBMAP_SHIFT 0
110#define QIXIS_LBMAP_DFLTBANK 0x0e
111#define QIXIS_LBMAP_ALTBANK 0x2e
112#define QIXIS_LBMAP_SD 0x00
Ashish Kumar6c8945e2018-01-17 12:16:37 +0530113#define QIXIS_LBMAP_EMMC 0x00
114#define QIXIS_LBMAP_IFC 0x00
Ashish Kumar77697762017-08-31 16:12:55 +0530115#define QIXIS_LBMAP_SD_QSPI 0x0e
116#define QIXIS_LBMAP_QSPI 0x0e
Ashish Kumar6c8945e2018-01-17 12:16:37 +0530117#define QIXIS_RCW_SRC_IFC 0x25
Ashish Kumar77697762017-08-31 16:12:55 +0530118#define QIXIS_RCW_SRC_SD 0x40
Ashish Kumar6c8945e2018-01-17 12:16:37 +0530119#define QIXIS_RCW_SRC_EMMC 0x41
Ashish Kumar77697762017-08-31 16:12:55 +0530120#define QIXIS_RCW_SRC_QSPI 0x62
121#define QIXIS_RST_CTL_RESET 0x41
122#define QIXIS_RCFG_CTL_RECONFIG_IDLE 0x20
123#define QIXIS_RCFG_CTL_RECONFIG_START 0x21
124#define QIXIS_RCFG_CTL_WATCHDOG_ENBLE 0x08
125#define QIXIS_RST_FORCE_MEM 0x01
126#define QIXIS_STAT_PRES1 0xb
127#define QIXIS_SDID_MASK 0x07
128#define QIXIS_ESDHC_NO_ADAPTER 0x7
129
130#define CONFIG_SYS_FPGA_CSPR_EXT (0x0)
131#define CONFIG_SYS_FPGA_CSPR (CSPR_PHYS_ADDR(QIXIS_BASE_PHYS_EARLY) \
132 | CSPR_PORT_SIZE_8 \
133 | CSPR_MSEL_GPCM \
134 | CSPR_V)
135#define SYS_FPGA_CSPR_FINAL (CSPR_PHYS_ADDR(QIXIS_BASE_PHYS) \
136 | CSPR_PORT_SIZE_8 \
137 | CSPR_MSEL_GPCM \
138 | CSPR_V)
139
Ashish Kumarb555e292018-02-19 14:14:09 +0530140#define SYS_FPGA_AMASK IFC_AMASK(64 * 1024)
Ashish Kumar91fded62017-11-06 13:18:44 +0530141#if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_SD_BOOT_QSPI)
Ashish Kumar77697762017-08-31 16:12:55 +0530142#define CONFIG_SYS_FPGA_CSOR CSOR_GPCM_ADM_SHIFT(0)
143#else
144#define CONFIG_SYS_FPGA_CSOR CSOR_GPCM_ADM_SHIFT(12)
145#endif
146/* QIXIS Timing parameters*/
147#define SYS_FPGA_CS_FTIM0 (FTIM0_GPCM_TACSE(0x0e) | \
148 FTIM0_GPCM_TEADC(0x0e) | \
149 FTIM0_GPCM_TEAHC(0x0e))
150#define SYS_FPGA_CS_FTIM1 (FTIM1_GPCM_TACO(0xff) | \
151 FTIM1_GPCM_TRAD(0x3f))
152#define SYS_FPGA_CS_FTIM2 (FTIM2_GPCM_TCS(0xf) | \
153 FTIM2_GPCM_TCH(0xf) | \
154 FTIM2_GPCM_TWP(0x3E))
155#define SYS_FPGA_CS_FTIM3 0x0
156
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000157#ifdef CONFIG_TFABOOT
158#define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT
159#define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR_EARLY
160#define CONFIG_SYS_CSPR0_FINAL CONFIG_SYS_NOR0_CSPR
161#define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK
162#define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR
163#define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0
164#define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1
165#define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2
166#define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3
167#define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_NOR0_CSPR_EXT
168#define CONFIG_SYS_CSPR1 CONFIG_SYS_NOR1_CSPR_EARLY
169#define CONFIG_SYS_CSPR1_FINAL CONFIG_SYS_NOR1_CSPR
170#define CONFIG_SYS_AMASK1 CONFIG_SYS_NOR_AMASK_EARLY
171#define CONFIG_SYS_AMASK1_FINAL CONFIG_SYS_NOR_AMASK
172#define CONFIG_SYS_CSOR1 CONFIG_SYS_NOR_CSOR
173#define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_NOR_FTIM0
174#define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_NOR_FTIM1
175#define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_NOR_FTIM2
176#define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_NOR_FTIM3
Tom Rini4e590942022-11-12 17:36:51 -0500177#define CONFIG_SYS_CSPR2_EXT CFG_SYS_NAND_CSPR_EXT
178#define CONFIG_SYS_CSPR2 CFG_SYS_NAND_CSPR
179#define CONFIG_SYS_AMASK2 CFG_SYS_NAND_AMASK
180#define CONFIG_SYS_CSOR2 CFG_SYS_NAND_CSOR
181#define CONFIG_SYS_CS2_FTIM0 CFG_SYS_NAND_FTIM0
182#define CONFIG_SYS_CS2_FTIM1 CFG_SYS_NAND_FTIM1
183#define CONFIG_SYS_CS2_FTIM2 CFG_SYS_NAND_FTIM2
184#define CONFIG_SYS_CS2_FTIM3 CFG_SYS_NAND_FTIM3
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000185#define CONFIG_SYS_CSPR3_EXT CONFIG_SYS_FPGA_CSPR_EXT
186#define CONFIG_SYS_CSPR3 CONFIG_SYS_FPGA_CSPR
187#define CONFIG_SYS_CSPR3_FINAL SYS_FPGA_CSPR_FINAL
188#define CONFIG_SYS_AMASK3 SYS_FPGA_AMASK
189#define CONFIG_SYS_CSOR3 CONFIG_SYS_FPGA_CSOR
190#define CONFIG_SYS_CS3_FTIM0 SYS_FPGA_CS_FTIM0
191#define CONFIG_SYS_CS3_FTIM1 SYS_FPGA_CS_FTIM1
192#define CONFIG_SYS_CS3_FTIM2 SYS_FPGA_CS_FTIM2
193#define CONFIG_SYS_CS3_FTIM3 SYS_FPGA_CS_FTIM3
194#else
Ashish Kumar77697762017-08-31 16:12:55 +0530195#if defined(CONFIG_QSPI_BOOT) || defined(CONFIG_SD_BOOT_QSPI)
Tom Rini4e590942022-11-12 17:36:51 -0500196#define CONFIG_SYS_CSPR0_EXT CFG_SYS_NAND_CSPR_EXT
197#define CONFIG_SYS_CSPR0 CFG_SYS_NAND_CSPR
198#define CONFIG_SYS_AMASK0 CFG_SYS_NAND_AMASK
199#define CONFIG_SYS_CSOR0 CFG_SYS_NAND_CSOR
200#define CONFIG_SYS_CS0_FTIM0 CFG_SYS_NAND_FTIM0
201#define CONFIG_SYS_CS0_FTIM1 CFG_SYS_NAND_FTIM1
202#define CONFIG_SYS_CS0_FTIM2 CFG_SYS_NAND_FTIM2
203#define CONFIG_SYS_CS0_FTIM3 CFG_SYS_NAND_FTIM3
Ashish Kumar77697762017-08-31 16:12:55 +0530204#define CONFIG_SYS_CSPR2_EXT CONFIG_SYS_FPGA_CSPR_EXT
205#define CONFIG_SYS_CSPR2 CONFIG_SYS_FPGA_CSPR
206#define CONFIG_SYS_CSPR2_FINAL SYS_FPGA_CSPR_FINAL
Ashish Kumarb555e292018-02-19 14:14:09 +0530207#define CONFIG_SYS_AMASK2 SYS_FPGA_AMASK
Ashish Kumar77697762017-08-31 16:12:55 +0530208#define CONFIG_SYS_CSOR2 CONFIG_SYS_FPGA_CSOR
209#define CONFIG_SYS_CS2_FTIM0 SYS_FPGA_CS_FTIM0
210#define CONFIG_SYS_CS2_FTIM1 SYS_FPGA_CS_FTIM1
211#define CONFIG_SYS_CS2_FTIM2 SYS_FPGA_CS_FTIM2
212#define CONFIG_SYS_CS2_FTIM3 SYS_FPGA_CS_FTIM3
213#else
214#define CONFIG_SYS_CSPR0_EXT CONFIG_SYS_NOR0_CSPR_EXT
215#define CONFIG_SYS_CSPR0 CONFIG_SYS_NOR0_CSPR_EARLY
216#define CONFIG_SYS_CSPR0_FINAL CONFIG_SYS_NOR0_CSPR
217#define CONFIG_SYS_AMASK0 CONFIG_SYS_NOR_AMASK
218#define CONFIG_SYS_CSOR0 CONFIG_SYS_NOR_CSOR
219#define CONFIG_SYS_CS0_FTIM0 CONFIG_SYS_NOR_FTIM0
220#define CONFIG_SYS_CS0_FTIM1 CONFIG_SYS_NOR_FTIM1
221#define CONFIG_SYS_CS0_FTIM2 CONFIG_SYS_NOR_FTIM2
222#define CONFIG_SYS_CS0_FTIM3 CONFIG_SYS_NOR_FTIM3
223#define CONFIG_SYS_CSPR1_EXT CONFIG_SYS_NOR0_CSPR_EXT
224#define CONFIG_SYS_CSPR1 CONFIG_SYS_NOR1_CSPR_EARLY
225#define CONFIG_SYS_CSPR1_FINAL CONFIG_SYS_NOR1_CSPR
226#define CONFIG_SYS_AMASK1 CONFIG_SYS_NOR_AMASK_EARLY
227#define CONFIG_SYS_AMASK1_FINAL CONFIG_SYS_NOR_AMASK
228#define CONFIG_SYS_CSOR1 CONFIG_SYS_NOR_CSOR
229#define CONFIG_SYS_CS1_FTIM0 CONFIG_SYS_NOR_FTIM0
230#define CONFIG_SYS_CS1_FTIM1 CONFIG_SYS_NOR_FTIM1
231#define CONFIG_SYS_CS1_FTIM2 CONFIG_SYS_NOR_FTIM2
232#define CONFIG_SYS_CS1_FTIM3 CONFIG_SYS_NOR_FTIM3
Tom Rini4e590942022-11-12 17:36:51 -0500233#define CONFIG_SYS_CSPR2_EXT CFG_SYS_NAND_CSPR_EXT
234#define CONFIG_SYS_CSPR2 CFG_SYS_NAND_CSPR
235#define CONFIG_SYS_AMASK2 CFG_SYS_NAND_AMASK
236#define CONFIG_SYS_CSOR2 CFG_SYS_NAND_CSOR
237#define CONFIG_SYS_CS2_FTIM0 CFG_SYS_NAND_FTIM0
238#define CONFIG_SYS_CS2_FTIM1 CFG_SYS_NAND_FTIM1
239#define CONFIG_SYS_CS2_FTIM2 CFG_SYS_NAND_FTIM2
240#define CONFIG_SYS_CS2_FTIM3 CFG_SYS_NAND_FTIM3
Ashish Kumar77697762017-08-31 16:12:55 +0530241#define CONFIG_SYS_CSPR3_EXT CONFIG_SYS_FPGA_CSPR_EXT
242#define CONFIG_SYS_CSPR3 CONFIG_SYS_FPGA_CSPR
Ashish Kumarb555e292018-02-19 14:14:09 +0530243#define CONFIG_SYS_CSPR3_FINAL SYS_FPGA_CSPR_FINAL
244#define CONFIG_SYS_AMASK3 SYS_FPGA_AMASK
Ashish Kumar77697762017-08-31 16:12:55 +0530245#define CONFIG_SYS_CSOR3 CONFIG_SYS_FPGA_CSOR
Ashish Kumarb555e292018-02-19 14:14:09 +0530246#define CONFIG_SYS_CS3_FTIM0 SYS_FPGA_CS_FTIM0
247#define CONFIG_SYS_CS3_FTIM1 SYS_FPGA_CS_FTIM1
248#define CONFIG_SYS_CS3_FTIM2 SYS_FPGA_CS_FTIM2
249#define CONFIG_SYS_CS3_FTIM3 SYS_FPGA_CS_FTIM3
Ashish Kumar77697762017-08-31 16:12:55 +0530250#endif
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000251#endif
Ashish Kumar77697762017-08-31 16:12:55 +0530252
253#define CONFIG_SYS_LS_MC_BOOT_TIMEOUT_MS 5000
254
255/*
256 * I2C bus multiplexer
257 */
258#define I2C_MUX_PCA_ADDR_PRI 0x77
259#define I2C_MUX_PCA_ADDR_SEC 0x76 /* Secondary multiplexer */
260#define I2C_RETIMER_ADDR 0x18
261#define I2C_RETIMER_ADDR2 0x19
262#define I2C_MUX_CH_DEFAULT 0x8
263#define I2C_MUX_CH5 0xD
264
Rajesh Bhagat23a12cb2018-01-17 16:13:05 +0530265#define I2C_MUX_CH_VOL_MONITOR 0xA
266
267/* Voltage monitor on channel 2*/
268#define I2C_VOL_MONITOR_ADDR 0x63
269#define I2C_VOL_MONITOR_BUS_V_OFFSET 0x2
270#define I2C_VOL_MONITOR_BUS_V_OVF 0x1
271#define I2C_VOL_MONITOR_BUS_V_SHIFT 3
Rajesh Bhagatef0789b2018-01-17 16:13:09 +0530272#define I2C_SVDD_MONITOR_ADDR 0x4F
273
Rajesh Bhagatef0789b2018-01-17 16:13:09 +0530274/* The lowest and highest voltage allowed for LS1088AQDS */
275#define VDD_MV_MIN 819
276#define VDD_MV_MAX 1212
277
Rajesh Bhagat23a12cb2018-01-17 16:13:05 +0530278#define PWM_CHANNEL0 0x0
279
Ashish Kumar77697762017-08-31 16:12:55 +0530280/*
281* RTC configuration
282*/
283#define RTC
Ashish Kumar77697762017-08-31 16:12:55 +0530284#define CONFIG_SYS_I2C_RTC_ADDR 0x51 /* Channel 3*/
Ashish Kumar77697762017-08-31 16:12:55 +0530285
Ashish Kumar77697762017-08-31 16:12:55 +0530286#ifdef CONFIG_FSL_DSPI
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000287#if !defined(CONFIG_TFABOOT) && \
288 !defined(CONFIG_QSPI_BOOT) && !defined(CONFIG_SD_BOOT_QSPI)
Ashish Kumar77697762017-08-31 16:12:55 +0530289#endif
290#endif
291
Biwen Li166e40b2020-12-10 11:02:47 +0800292#define COMMON_ENV \
293 "kernelheader_addr_r=0x80200000\0" \
294 "fdtheader_addr_r=0x80100000\0" \
295 "kernel_addr_r=0x81000000\0" \
296 "fdt_addr_r=0x90000000\0" \
297 "load_addr=0xa0000000\0"
298
Ashish Kumar77697762017-08-31 16:12:55 +0530299/* Initial environment variables */
Udit Agarwal5536c3c2019-11-07 16:11:32 +0000300#ifdef CONFIG_NXP_ESBC
Udit Agarwal30c41d22017-11-22 09:01:26 +0530301#undef CONFIG_EXTRA_ENV_SETTINGS
302#define CONFIG_EXTRA_ENV_SETTINGS \
Biwen Li166e40b2020-12-10 11:02:47 +0800303 COMMON_ENV \
Udit Agarwal30c41d22017-11-22 09:01:26 +0530304 "hwconfig=fsl_ddr:bank_intlv=auto\0" \
305 "loadaddr=0x90100000\0" \
306 "kernel_addr=0x100000\0" \
307 "ramdisk_addr=0x800000\0" \
308 "ramdisk_size=0x2000000\0" \
309 "fdt_high=0xa0000000\0" \
310 "initrd_high=0xffffffffffffffff\0" \
311 "kernel_start=0x1000000\0" \
312 "kernel_load=0xa0000000\0" \
313 "kernel_size=0x2800000\0" \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530314 "mcinitcmd=sf probe 0:0;sf read 0xa0a00000 0xa00000 0x200000;" \
Priyanka Singh4238e372020-01-22 10:32:34 +0000315 "sf read 0xa0640000 0x640000 0x4000; esbc_validate 0xa0640000;" \
Udit Agarwal30c41d22017-11-22 09:01:26 +0530316 "sf read 0xa0e00000 0xe00000 0x100000;" \
Priyanka Singh4238e372020-01-22 10:32:34 +0000317 "sf read 0xa0680000 0x680000 0x4000;esbc_validate 0xa0680000;" \
Udit Agarwal30c41d22017-11-22 09:01:26 +0530318 "fsl_mc start mc 0xa0a00000 0xa0e00000\0" \
319 "mcmemsize=0x70000000 \0"
Udit Agarwal5536c3c2019-11-07 16:11:32 +0000320#else /* if !(CONFIG_NXP_ESBC) */
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000321#ifdef CONFIG_TFABOOT
322#define QSPI_MC_INIT_CMD \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530323 "sf probe 0:0;sf read 0x80a00000 0xA00000 0x200000;" \
324 "sf read 0x80e00000 0xE00000 0x100000;" \
325 "fsl_mc start mc 0x80a00000 0x80e00000\0"
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000326#define SD_MC_INIT_CMD \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530327 "mmcinfo;mmc read 0x80a00000 0x5000 0x1000;" \
328 "mmc read 0x80e00000 0x7000 0x800;" \
329 "fsl_mc start mc 0x80a00000 0x80e00000\0"
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000330#define IFC_MC_INIT_CMD \
331 "fsl_mc start mc 0x580A00000 0x580E00000\0"
332
333#undef CONFIG_EXTRA_ENV_SETTINGS
334#define CONFIG_EXTRA_ENV_SETTINGS \
Biwen Li166e40b2020-12-10 11:02:47 +0800335 COMMON_ENV \
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000336 "hwconfig=fsl_ddr:bank_intlv=auto\0" \
337 "loadaddr=0x90100000\0" \
338 "kernel_addr=0x100000\0" \
339 "kernel_addr_sd=0x800\0" \
340 "ramdisk_addr=0x800000\0" \
341 "ramdisk_size=0x2000000\0" \
342 "fdt_high=0xa0000000\0" \
343 "initrd_high=0xffffffffffffffff\0" \
344 "kernel_start=0x1000000\0" \
345 "kernel_start_sd=0x8000\0" \
346 "kernel_load=0xa0000000\0" \
347 "kernel_size=0x2800000\0" \
348 "kernel_size_sd=0x14000\0" \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530349 "mcinitcmd=sf probe 0:0;sf read 0x80a00000 0xA00000 0x200000;" \
350 "sf read 0x80e00000 0xE00000 0x100000;" \
351 "fsl_mc start mc 0x80a00000 0x80e00000\0" \
Biwen Li472dfe52020-03-19 19:38:42 +0800352 "mcmemsize=0x70000000 \0" \
353 "BOARD=ls1088aqds\0" \
354 "scriptaddr=0x80000000\0" \
355 "scripthdraddr=0x80080000\0" \
356 BOOTENV \
357 "boot_scripts=ls1088aqds_boot.scr\0" \
358 "boot_script_hdr=hdr_ls1088aqds_bs.out\0" \
359 "scan_dev_for_boot_part=" \
360 "part list ${devtype} ${devnum} devplist; " \
361 "env exists devplist || setenv devplist 1; " \
362 "for distro_bootpart in ${devplist}; do " \
363 "if fstype ${devtype} " \
364 "${devnum}:${distro_bootpart} " \
365 "bootfstype; then " \
366 "run scan_dev_for_boot; " \
367 "fi; " \
368 "done\0" \
369 "boot_a_script=" \
370 "load ${devtype} ${devnum}:${distro_bootpart} " \
371 "${scriptaddr} ${prefix}${script}; " \
372 "env exists secureboot && load ${devtype} " \
373 "${devnum}:${distro_bootpart} " \
374 "${scripthdraddr} ${prefix}${boot_script_hdr}; "\
375 "env exists secureboot " \
376 "&& esbc_validate ${scripthdraddr};" \
377 "source ${scriptaddr}\0" \
378 "qspi_bootcmd=echo Trying load from qspi..; " \
379 "sf probe 0:0; " \
380 "sf read 0x80001000 0xd00000 0x100000; " \
381 "fsl_mc lazyapply dpl 0x80001000 && " \
382 "sf read $kernel_load $kernel_start " \
383 "$kernel_size && bootm $kernel_load#$BOARD\0" \
384 "sd_bootcmd=echo Trying load from sd card..; " \
385 "mmcinfo;mmc read 0x80001000 0x6800 0x800; "\
386 "fsl_mc lazyapply dpl 0x80001000 && " \
387 "mmc read $kernel_load $kernel_start_sd " \
388 "$kernel_size_sd && bootm $kernel_load#$BOARD\0" \
389 "nor_bootcmd=echo Trying load from nor..; " \
390 "fsl_mc lazyapply dpl 0x580d00000 && " \
391 "cp.b $kernel_start $kernel_load " \
392 "$kernel_size && bootm $kernel_load#$BOARD\0"
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000393#else
Ashish Kumar77697762017-08-31 16:12:55 +0530394#if defined(CONFIG_QSPI_BOOT)
395#undef CONFIG_EXTRA_ENV_SETTINGS
396#define CONFIG_EXTRA_ENV_SETTINGS \
Biwen Li166e40b2020-12-10 11:02:47 +0800397 COMMON_ENV \
Ashish Kumar77697762017-08-31 16:12:55 +0530398 "hwconfig=fsl_ddr:bank_intlv=auto\0" \
399 "loadaddr=0x90100000\0" \
400 "kernel_addr=0x100000\0" \
401 "ramdisk_addr=0x800000\0" \
402 "ramdisk_size=0x2000000\0" \
403 "fdt_high=0xa0000000\0" \
404 "initrd_high=0xffffffffffffffff\0" \
405 "kernel_start=0x1000000\0" \
406 "kernel_load=0xa0000000\0" \
407 "kernel_size=0x2800000\0" \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530408 "mcinitcmd=sf probe 0:0;sf read 0x80a00000 0xA00000 0x200000;" \
409 "sf read 0x80e00000 0xE00000 0x100000;" \
410 "fsl_mc start mc 0x80a00000 0x80e00000\0" \
Ashish Kumar77697762017-08-31 16:12:55 +0530411 "mcmemsize=0x70000000 \0"
Ashish Kumar91fded62017-11-06 13:18:44 +0530412#elif defined(CONFIG_SD_BOOT)
413#undef CONFIG_EXTRA_ENV_SETTINGS
414#define CONFIG_EXTRA_ENV_SETTINGS \
Biwen Li166e40b2020-12-10 11:02:47 +0800415 COMMON_ENV \
Ashish Kumar91fded62017-11-06 13:18:44 +0530416 "hwconfig=fsl_ddr:bank_intlv=auto\0" \
417 "loadaddr=0x90100000\0" \
418 "kernel_addr=0x800\0" \
419 "ramdisk_addr=0x800000\0" \
420 "ramdisk_size=0x2000000\0" \
421 "fdt_high=0xa0000000\0" \
422 "initrd_high=0xffffffffffffffff\0" \
423 "kernel_start=0x8000\0" \
424 "kernel_load=0xa0000000\0" \
425 "kernel_size=0x14000\0" \
Priyanka Jain50ddea62021-07-19 14:51:24 +0530426 "mcinitcmd=mmcinfo;mmc read 0x80a00000 0x5000 0x1000;" \
427 "mmc read 0x80e00000 0x7000 0x800;" \
428 "fsl_mc start mc 0x80a00000 0x80e00000\0" \
Ashish Kumar91fded62017-11-06 13:18:44 +0530429 "mcmemsize=0x70000000 \0"
Ashish Kumar77697762017-08-31 16:12:55 +0530430#else /* NOR BOOT */
431#undef CONFIG_EXTRA_ENV_SETTINGS
432#define CONFIG_EXTRA_ENV_SETTINGS \
Biwen Li166e40b2020-12-10 11:02:47 +0800433 COMMON_ENV \
Ashish Kumar77697762017-08-31 16:12:55 +0530434 "hwconfig=fsl_ddr:bank_intlv=auto\0" \
435 "loadaddr=0x90100000\0" \
436 "kernel_addr=0x100000\0" \
437 "ramdisk_addr=0x800000\0" \
438 "ramdisk_size=0x2000000\0" \
439 "fdt_high=0xa0000000\0" \
440 "initrd_high=0xffffffffffffffff\0" \
441 "kernel_start=0x1000000\0" \
442 "kernel_load=0xa0000000\0" \
443 "kernel_size=0x2800000\0" \
444 "mcinitcmd=fsl_mc start mc 0x580A00000 0x580E00000\0" \
445 "mcmemsize=0x70000000 \0"
446#endif
Pankit Garg1a12b4a2018-12-27 04:37:57 +0000447#endif /* CONFIG_TFABOOT */
Udit Agarwal5536c3c2019-11-07 16:11:32 +0000448#endif /* CONFIG_NXP_ESBC */
Ashish Kumar77697762017-08-31 16:12:55 +0530449
Biwen Li472dfe52020-03-19 19:38:42 +0800450#ifdef CONFIG_TFABOOT
451#define QSPI_NOR_BOOTCOMMAND "run distro_bootcmd; run qspi_bootcmd; " \
452 "env exists secureboot && esbc_halt;;"
453#define IFC_NOR_BOOTCOMMAND "run distro_bootcmd; run nor_bootcmd; " \
454 "env exists secureboot && esbc_halt;;"
455#define SD_BOOTCOMMAND "run distro_bootcmd; run sd_bootcmd; " \
456 "env exists secureboot && esbc_halt;;"
457#endif
458
Ashish Kumar77697762017-08-31 16:12:55 +0530459#ifdef CONFIG_FSL_MC_ENET
Ashish Kumar77697762017-08-31 16:12:55 +0530460#define RGMII_PHY1_ADDR 0x1
461#define RGMII_PHY2_ADDR 0x2
462#define SGMII_CARD_PORT1_PHY_ADDR 0x1C
463#define SGMII_CARD_PORT2_PHY_ADDR 0x1d
464#define SGMII_CARD_PORT3_PHY_ADDR 0x1E
465#define SGMII_CARD_PORT4_PHY_ADDR 0x1F
466
467#define XQSGMII_CARD_PHY1_PORT0_ADDR 0x0
468#define XQSGMII_CARD_PHY1_PORT1_ADDR 0x1
469#define XQSGMII_CARD_PHY1_PORT2_ADDR 0x2
470#define XQSGMII_CARD_PHY1_PORT3_ADDR 0x3
471#define XQSGMII_CARD_PHY2_PORT0_ADDR 0x4
472#define XQSGMII_CARD_PHY2_PORT1_ADDR 0x5
473#define XQSGMII_CARD_PHY2_PORT2_ADDR 0x6
474#define XQSGMII_CARD_PHY2_PORT3_ADDR 0x7
475#define XQSGMII_CARD_PHY3_PORT0_ADDR 0x8
476#define XQSGMII_CARD_PHY3_PORT1_ADDR 0x9
477#define XQSGMII_CARD_PHY3_PORT2_ADDR 0xa
478#define XQSGMII_CARD_PHY3_PORT3_ADDR 0xb
479#define XQSGMII_CARD_PHY4_PORT0_ADDR 0xc
480#define XQSGMII_CARD_PHY4_PORT1_ADDR 0xd
481#define XQSGMII_CARD_PHY4_PORT2_ADDR 0xe
482#define XQSGMII_CARD_PHY4_PORT3_ADDR 0xf
483
Ashish Kumar77697762017-08-31 16:12:55 +0530484#endif
485
Ashish Kumar77697762017-08-31 16:12:55 +0530486#define BOOT_TARGET_DEVICES(func) \
487 func(USB, usb, 0) \
488 func(MMC, mmc, 0) \
489 func(SCSI, scsi, 0) \
490 func(DHCP, dhcp, na)
491#include <config_distro_bootcmd.h>
492
493#include <asm/fsl_secure_boot.h>
494
495#endif /* __LS1088A_QDS_H */