xref: /rk3399_rockchip-uboot/include/spl.h (revision 1a4596601fd395f3afb8f82f3f840c5e00bdd57a)
147f7bcaeSTom Rini /*
247f7bcaeSTom Rini  * (C) Copyright 2012
347f7bcaeSTom Rini  * Texas Instruments, <www.ti.com>
447f7bcaeSTom Rini  *
5*1a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
647f7bcaeSTom Rini  */
747f7bcaeSTom Rini #ifndef	_SPL_H_
847f7bcaeSTom Rini #define	_SPL_H_
947f7bcaeSTom Rini 
1047f7bcaeSTom Rini /* Platform-specific defines */
116507f133STom Rini #include <linux/compiler.h>
1247f7bcaeSTom Rini #include <asm/spl.h>
1347f7bcaeSTom Rini 
1447f7bcaeSTom Rini /* Boot type */
1547f7bcaeSTom Rini #define MMCSD_MODE_UNDEFINED	0
1647f7bcaeSTom Rini #define MMCSD_MODE_RAW		1
1747f7bcaeSTom Rini #define MMCSD_MODE_FAT		2
1847f7bcaeSTom Rini 
1947f7bcaeSTom Rini struct spl_image_info {
2047f7bcaeSTom Rini 	const char *name;
2147f7bcaeSTom Rini 	u8 os;
2247f7bcaeSTom Rini 	u32 load_addr;
2347f7bcaeSTom Rini 	u32 entry_point;
2447f7bcaeSTom Rini 	u32 size;
25022b4975SStefan Roese 	u32 flags;
2647f7bcaeSTom Rini };
2747f7bcaeSTom Rini 
28022b4975SStefan Roese #define SPL_COPY_PAYLOAD_ONLY	1
29022b4975SStefan Roese 
3047f7bcaeSTom Rini extern struct spl_image_info spl_image;
3147f7bcaeSTom Rini 
3247f7bcaeSTom Rini /* SPL common functions */
3347f7bcaeSTom Rini void preloader_console_init(void);
3447f7bcaeSTom Rini u32 spl_boot_device(void);
3547f7bcaeSTom Rini u32 spl_boot_mode(void);
3647f7bcaeSTom Rini void spl_parse_image_header(const struct image_header *header);
3747f7bcaeSTom Rini void spl_board_prepare_for_linux(void);
386507f133STom Rini void __noreturn jump_to_image_linux(void *arg);
3947f7bcaeSTom Rini int spl_start_uboot(void);
4047f7bcaeSTom Rini void spl_display_print(void);
4147f7bcaeSTom Rini 
4247f7bcaeSTom Rini /* NAND SPL functions */
4347f7bcaeSTom Rini void spl_nand_load_image(void);
4447f7bcaeSTom Rini 
456000992eSEnric Balletbo i Serra /* OneNAND SPL functions */
466000992eSEnric Balletbo i Serra void spl_onenand_load_image(void);
476000992eSEnric Balletbo i Serra 
4833d34646SStefan Roese /* NOR SPL functions */
4933d34646SStefan Roese void spl_nor_load_image(void);
5033d34646SStefan Roese 
5147f7bcaeSTom Rini /* MMC SPL functions */
5247f7bcaeSTom Rini void spl_mmc_load_image(void);
5347f7bcaeSTom Rini 
5447f7bcaeSTom Rini /* YMODEM SPL functions */
5547f7bcaeSTom Rini void spl_ymodem_load_image(void);
5647f7bcaeSTom Rini 
5747f7bcaeSTom Rini /* SPI SPL functions */
58a4cc1c48STom Rini void spl_spi_load_image(void);
5947f7bcaeSTom Rini 
607ac2fe2dSIlya Yanok /* Ethernet SPL functions */
617ac2fe2dSIlya Yanok void spl_net_load_image(const char *device);
627ac2fe2dSIlya Yanok 
6347f7bcaeSTom Rini #ifdef CONFIG_SPL_BOARD_INIT
6447f7bcaeSTom Rini void spl_board_init(void);
6547f7bcaeSTom Rini #endif
6647f7bcaeSTom Rini #endif
67