xref: /rk3399_rockchip-uboot/include/spl.h (revision 205b4f33cfe58268df7d433f2da515fe660afd9c)
147f7bcaeSTom Rini /*
247f7bcaeSTom Rini  * (C) Copyright 2012
347f7bcaeSTom Rini  * Texas Instruments, <www.ti.com>
447f7bcaeSTom Rini  *
51a459660SWolfgang 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 
14773b5940SDan Murphy 
1547f7bcaeSTom Rini /* Boot type */
1647f7bcaeSTom Rini #define MMCSD_MODE_UNDEFINED	0
1747f7bcaeSTom Rini #define MMCSD_MODE_RAW		1
18*205b4f33SGuillaume GARDET #define MMCSD_MODE_FS		2
197dbe63bcSTom Rini #define MMCSD_MODE_EMMCBOOT	3
2047f7bcaeSTom Rini 
2147f7bcaeSTom Rini struct spl_image_info {
2247f7bcaeSTom Rini 	const char *name;
2347f7bcaeSTom Rini 	u8 os;
2447f7bcaeSTom Rini 	u32 load_addr;
2547f7bcaeSTom Rini 	u32 entry_point;
2647f7bcaeSTom Rini 	u32 size;
27022b4975SStefan Roese 	u32 flags;
2847f7bcaeSTom Rini };
2947f7bcaeSTom Rini 
30022b4975SStefan Roese #define SPL_COPY_PAYLOAD_ONLY	1
31022b4975SStefan Roese 
3247f7bcaeSTom Rini extern struct spl_image_info spl_image;
3347f7bcaeSTom Rini 
3447f7bcaeSTom Rini /* SPL common functions */
3547f7bcaeSTom Rini void preloader_console_init(void);
3647f7bcaeSTom Rini u32 spl_boot_device(void);
3747f7bcaeSTom Rini u32 spl_boot_mode(void);
3847f7bcaeSTom Rini void spl_parse_image_header(const struct image_header *header);
3947f7bcaeSTom Rini void spl_board_prepare_for_linux(void);
406507f133STom Rini void __noreturn jump_to_image_linux(void *arg);
4147f7bcaeSTom Rini int spl_start_uboot(void);
4247f7bcaeSTom Rini void spl_display_print(void);
4347f7bcaeSTom Rini 
4447f7bcaeSTom Rini /* NAND SPL functions */
4547f7bcaeSTom Rini void spl_nand_load_image(void);
4647f7bcaeSTom Rini 
476000992eSEnric Balletbo i Serra /* OneNAND SPL functions */
486000992eSEnric Balletbo i Serra void spl_onenand_load_image(void);
496000992eSEnric Balletbo i Serra 
5033d34646SStefan Roese /* NOR SPL functions */
5133d34646SStefan Roese void spl_nor_load_image(void);
5233d34646SStefan Roese 
5347f7bcaeSTom Rini /* MMC SPL functions */
5447f7bcaeSTom Rini void spl_mmc_load_image(void);
5547f7bcaeSTom Rini 
5647f7bcaeSTom Rini /* YMODEM SPL functions */
5747f7bcaeSTom Rini void spl_ymodem_load_image(void);
5847f7bcaeSTom Rini 
5947f7bcaeSTom Rini /* SPI SPL functions */
60a4cc1c48STom Rini void spl_spi_load_image(void);
6147f7bcaeSTom Rini 
627ac2fe2dSIlya Yanok /* Ethernet SPL functions */
637ac2fe2dSIlya Yanok void spl_net_load_image(const char *device);
647ac2fe2dSIlya Yanok 
658cffe5bdSDan Murphy /* USB SPL functions */
668cffe5bdSDan Murphy void spl_usb_load_image(void);
678cffe5bdSDan Murphy 
68fff40a7eSDan Murphy /* SATA SPL functions */
69fff40a7eSDan Murphy void spl_sata_load_image(void);
70fff40a7eSDan Murphy 
71773b5940SDan Murphy /* SPL FAT image functions */
72773b5940SDan Murphy int spl_load_image_fat(block_dev_desc_t *block_dev, int partition, const char *filename);
73773b5940SDan Murphy int spl_load_image_fat_os(block_dev_desc_t *block_dev, int partition);
74773b5940SDan Murphy 
75ce048224SJeroen Hofstee void __noreturn jump_to_image_no_args(struct spl_image_info *spl_image);
76ce048224SJeroen Hofstee 
7747f7bcaeSTom Rini #ifdef CONFIG_SPL_BOARD_INIT
7847f7bcaeSTom Rini void spl_board_init(void);
7947f7bcaeSTom Rini #endif
8047f7bcaeSTom Rini #endif
81