mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 06:21:47 +02:00 
			
		
		
		
	FSP spec 1.1 adds one more member to the struct common_buf to determine the memory size that can be reserved by FSP below "top of low usable memory" for bootloader usage. This new member uses the reserved space so that it is still compatible with previous FSP spec 1.0. A new HOB (FSP_HOB_RESOURCE_OWNER_BOOTLOADER_TOLUM_GUID) is also published when common_buf.tolum_size is valid and non zero. Signed-off-by: Bin Meng <bmeng.cn@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			69 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2013, Intel Corporation
 | |
|  * Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier:	Intel
 | |
|  */
 | |
| 
 | |
| #ifndef __FSP_API_H__
 | |
| #define __FSP_API_H__
 | |
| 
 | |
| #include <linux/linkage.h>
 | |
| 
 | |
| /*
 | |
|  * FSP common configuration structure.
 | |
|  * This needs to be included in the platform-specific struct fsp_config_data.
 | |
|  */
 | |
| struct fsp_cfg_common {
 | |
| 	struct fsp_header	*fsp_hdr;
 | |
| 	u32			stack_top;
 | |
| 	u32			boot_mode;
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * FspInit continuation function prototype.
 | |
|  * Control will be returned to this callback function after FspInit API call.
 | |
|  */
 | |
| typedef void (*fsp_continuation_f)(u32 status, void *hob_list);
 | |
| 
 | |
| struct fsp_init_params {
 | |
| 	/* Non-volatile storage buffer pointer */
 | |
| 	void			*nvs_buf;
 | |
| 	/* Runtime buffer pointer */
 | |
| 	void			*rt_buf;
 | |
| 	/* Continuation function address */
 | |
| 	fsp_continuation_f	continuation;
 | |
| };
 | |
| 
 | |
| struct common_buf {
 | |
| 	/*
 | |
| 	 * Stack top pointer used by the bootloader. The new stack frame will be
 | |
| 	 * set up at this location after FspInit API call.
 | |
| 	 */
 | |
| 	u32	stack_top;
 | |
| 	u32	boot_mode;	/* Current system boot mode */
 | |
| 	void	*upd_data;	/* User platform configuraiton data region */
 | |
| 	u32	tolum_size;	/* Top of low usable memory size (FSP 1.1) */
 | |
| 	u32	reserved[6];	/* Reserved */
 | |
| };
 | |
| 
 | |
| enum fsp_phase {
 | |
| 	/* Notification code for post PCI enuermation */
 | |
| 	INIT_PHASE_PCI	= 0x20,
 | |
| 	/* Notification code before transfering control to the payload */
 | |
| 	INIT_PHASE_BOOT	= 0x40
 | |
| };
 | |
| 
 | |
| struct fsp_notify_params {
 | |
| 	/* Notification phase used for NotifyPhase API */
 | |
| 	enum fsp_phase	phase;
 | |
| };
 | |
| 
 | |
| /* FspInit API function prototype */
 | |
| typedef asmlinkage u32 (*fsp_init_f)(struct fsp_init_params *params);
 | |
| 
 | |
| /* FspNotify API function prototype */
 | |
| typedef asmlinkage u32 (*fsp_notify_f)(struct fsp_notify_params *params);
 | |
| 
 | |
| #endif
 |