diff options
Diffstat (limited to 'board/freescale')
| -rw-r--r-- | board/freescale/ls1021aqds/MAINTAINERS | 1 | ||||
| -rw-r--r-- | board/freescale/ls1021aqds/ddr.c | 5 | ||||
| -rw-r--r-- | board/freescale/ls1021aqds/ls1021aqds.c | 39 | ||||
| -rw-r--r-- | board/freescale/ls1021aqds/ls102xa_pbi.cfg | 12 | ||||
| -rw-r--r-- | board/freescale/ls1021aqds/ls102xa_rcw_sd.cfg | 14 | 
5 files changed, 70 insertions, 1 deletions
| diff --git a/board/freescale/ls1021aqds/MAINTAINERS b/board/freescale/ls1021aqds/MAINTAINERS index e30e94471b1..962176b5339 100644 --- a/board/freescale/ls1021aqds/MAINTAINERS +++ b/board/freescale/ls1021aqds/MAINTAINERS @@ -6,3 +6,4 @@ F:	include/configs/ls1021aqds.h  F:	configs/ls1021aqds_nor_defconfig  F:	configs/ls1021aqds_ddr4_nor_defconfig  F:	configs/ls1021aqds_nor_SECURE_BOOT_defconfig +F:	configs/ls1021aqds_sdcard_defconfig diff --git a/board/freescale/ls1021aqds/ddr.c b/board/freescale/ls1021aqds/ddr.c index 5898e337443..a539ff97913 100644 --- a/board/freescale/ls1021aqds/ddr.c +++ b/board/freescale/ls1021aqds/ddr.c @@ -153,9 +153,12 @@ phys_size_t initdram(int board_type)  {  	phys_size_t dram_size; +#if defined(CONFIG_SPL_BUILD) || !defined(CONFIG_SPL)  	puts("Initializing DDR....using SPD\n");  	dram_size = fsl_ddr_sdram(); - +#else +	dram_size =  fsl_ddr_sdram_size(); +#endif  	return dram_size;  } diff --git a/board/freescale/ls1021aqds/ls1021aqds.c b/board/freescale/ls1021aqds/ls1021aqds.c index bf22fced9c4..9eab42d6c7e 100644 --- a/board/freescale/ls1021aqds/ls1021aqds.c +++ b/board/freescale/ls1021aqds/ls1021aqds.c @@ -15,6 +15,7 @@  #include <fsl_esdhc.h>  #include <fsl_ifc.h>  #include <fsl_sec.h> +#include <spl.h>  #include "../common/qixis.h"  #include "ls1021aqds_qixis.h" @@ -34,10 +35,17 @@ enum {  int checkboard(void)  {  	char buf[64]; +#if !defined(CONFIG_SD_BOOT) && !defined(CONFIG_QSPI_BOOT)  	u8 sw; +#endif  	puts("Board: LS1021AQDS\n"); +#ifdef CONFIG_SD_BOOT +	puts("SD\n"); +#elif CONFIG_QSPI_BOOT +	puts("QSPI\n"); +#else  	sw = QIXIS_READ(brdcfg[0]);  	sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT; @@ -51,6 +59,7 @@ int checkboard(void)  		printf("IFCCard\n");  	else  		printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH); +#endif  	printf("Sys ID:0x%02x, Sys Ver: 0x%02x\n",  	       QIXIS_READ(id), QIXIS_READ(arch)); @@ -165,6 +174,36 @@ int board_early_init_f(void)  	return 0;  } +#ifdef CONFIG_SPL_BUILD +void board_init_f(ulong dummy) +{ +	struct ccsr_cci400 *cci = (struct ccsr_cci400 *)CONFIG_SYS_CCI400_ADDR; + +	/* Set global data pointer */ +	gd = &gdata; + +	/* Clear the BSS */ +	memset(__bss_start, 0, __bss_end - __bss_start); + +#ifdef CONFIG_FSL_IFC +	init_early_memctl_regs(); +#endif + +	get_clocks(); + +	preloader_console_init(); + +#ifdef CONFIG_SPL_I2C_SUPPORT +	i2c_init_all(); +#endif +	out_le32(&cci->ctrl_ord, CCI400_CTRLORD_TERM_BARRIER); + +	dram_init(); + +	board_init_r(NULL, 0); +} +#endif +  int config_board_mux(int ctrl_type)  {  	u8 reg12; diff --git a/board/freescale/ls1021aqds/ls102xa_pbi.cfg b/board/freescale/ls1021aqds/ls102xa_pbi.cfg new file mode 100644 index 00000000000..f1a1b63ab77 --- /dev/null +++ b/board/freescale/ls1021aqds/ls102xa_pbi.cfg @@ -0,0 +1,12 @@ +#PBI commands + +09570200 ffffffff +09570158 00000300 +8940007c 21f47300 + +#Configure Scratch register +09ee0200 10000000 +#Configure alternate space +09570158 00001000 +#Flush PBL data +096100c0 000FFFFF diff --git a/board/freescale/ls1021aqds/ls102xa_rcw_sd.cfg b/board/freescale/ls1021aqds/ls102xa_rcw_sd.cfg new file mode 100644 index 00000000000..9d99bd862dd --- /dev/null +++ b/board/freescale/ls1021aqds/ls102xa_rcw_sd.cfg @@ -0,0 +1,14 @@ +#PBL preamble and RCW header +aa55aa55 01ee0100 + +#enable IFC, disable QSPI and DSPI +0608000a 00000000 00000000 00000000 +60000000 00407900 60040a00 21046000 +00000000 00000000 00000000 00038000 +00000000 001b7200 00000000 00000000 + +#disable IFC, enable QSPI and DSPI +#0608000a 00000000 00000000 00000000 +#60000000 00407900 60040a00 21046000 +#00000000 00000000 00000000 00038000 +#20024800 001b7200 00000000 00000000 | 
