mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-24 22:11:26 +02:00 
			
		
		
		
	When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			279 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			279 lines
		
	
	
		
			7.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: Intel */
 | |
| /*
 | |
|  * Copyright (C) 2013, Intel Corporation
 | |
|  * Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com>
 | |
|  */
 | |
| 
 | |
| #ifndef __FSP_HOB_H__
 | |
| #define __FSP_HOB_H__
 | |
| 
 | |
| #include <efi.h>
 | |
| 
 | |
| /* Type of HOB Header */
 | |
| #define HOB_TYPE_MEM_ALLOC	0x0002
 | |
| #define HOB_TYPE_RES_DESC	0x0003
 | |
| #define HOB_TYPE_GUID_EXT	0x0004
 | |
| #define HOB_TYPE_UNUSED		0xFFFE
 | |
| #define HOB_TYPE_EOH		0xFFFF
 | |
| 
 | |
| /*
 | |
|  * Describes the format and size of the data inside the HOB.
 | |
|  * All HOBs must contain this generic HOB header.
 | |
|  */
 | |
| struct hob_header {
 | |
| 	u16	type;		/* HOB type */
 | |
| 	u16	len;		/* HOB length */
 | |
| 	u32	reserved;	/* always zero */
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Describes all memory ranges used during the HOB producer phase that
 | |
|  * exist outside the HOB list. This HOB type describes how memory is used,
 | |
|  * not the physical attributes of memory.
 | |
|  */
 | |
| struct hob_mem_alloc {
 | |
| 	struct hob_header	hdr;
 | |
| 	/*
 | |
| 	 * A GUID that defines the memory allocation region's type and purpose,
 | |
| 	 * as well as other fields within the memory allocation HOB. This GUID
 | |
| 	 * is used to define the additional data within the HOB that may be
 | |
| 	 * present for the memory allocation HOB. Type efi_guid is defined in
 | |
| 	 * InstallProtocolInterface() in the UEFI 2.0 specification.
 | |
| 	 */
 | |
| 	struct efi_guid		name;
 | |
| 	/*
 | |
| 	 * The base address of memory allocated by this HOB.
 | |
| 	 * Type phys_addr_t is defined in AllocatePages() in the UEFI 2.0
 | |
| 	 * specification.
 | |
| 	 */
 | |
| 	phys_addr_t		mem_base;
 | |
| 	/* The length in bytes of memory allocated by this HOB */
 | |
| 	phys_size_t		mem_len;
 | |
| 	/*
 | |
| 	 * Defines the type of memory allocated by this HOB.
 | |
| 	 * The memory type definition follows the EFI_MEMORY_TYPE definition.
 | |
| 	 * Type EFI_MEMORY_TYPE is defined in AllocatePages() in the UEFI 2.0
 | |
| 	 * specification.
 | |
| 	 */
 | |
| 	enum efi_mem_type	mem_type;
 | |
| 	/* padding */
 | |
| 	u8			reserved[4];
 | |
| };
 | |
| 
 | |
| /* Value of ResourceType in HOB_RES_DESC */
 | |
| #define RES_SYS_MEM		0x00000000
 | |
| #define RES_MMAP_IO		0x00000001
 | |
| #define RES_IO			0x00000002
 | |
| #define RES_FW_DEVICE		0x00000003
 | |
| #define RES_MMAP_IO_PORT	0x00000004
 | |
| #define RES_MEM_RESERVED	0x00000005
 | |
| #define RES_IO_RESERVED		0x00000006
 | |
| #define RES_MAX_MEM_TYPE	0x00000007
 | |
| 
 | |
| /*
 | |
|  * These types can be ORed together as needed.
 | |
|  *
 | |
|  * The first three enumerations describe settings
 | |
|  * The rest of the settings describe capabilities
 | |
|  */
 | |
| #define RES_ATTR_PRESENT			0x00000001
 | |
| #define RES_ATTR_INITIALIZED			0x00000002
 | |
| #define RES_ATTR_TESTED				0x00000004
 | |
| #define RES_ATTR_SINGLE_BIT_ECC			0x00000008
 | |
| #define RES_ATTR_MULTIPLE_BIT_ECC		0x00000010
 | |
| #define RES_ATTR_ECC_RESERVED_1			0x00000020
 | |
| #define RES_ATTR_ECC_RESERVED_2			0x00000040
 | |
| #define RES_ATTR_READ_PROTECTED			0x00000080
 | |
| #define RES_ATTR_WRITE_PROTECTED		0x00000100
 | |
| #define RES_ATTR_EXECUTION_PROTECTED		0x00000200
 | |
| #define RES_ATTR_UNCACHEABLE			0x00000400
 | |
| #define RES_ATTR_WRITE_COMBINEABLE		0x00000800
 | |
| #define RES_ATTR_WRITE_THROUGH_CACHEABLE	0x00001000
 | |
| #define RES_ATTR_WRITE_BACK_CACHEABLE		0x00002000
 | |
| #define RES_ATTR_16_BIT_IO			0x00004000
 | |
| #define RES_ATTR_32_BIT_IO			0x00008000
 | |
| #define RES_ATTR_64_BIT_IO			0x00010000
 | |
| #define RES_ATTR_UNCACHED_EXPORTED		0x00020000
 | |
| 
 | |
| /*
 | |
|  * Describes the resource properties of all fixed, nonrelocatable resource
 | |
|  * ranges found on the processor host bus during the HOB producer phase.
 | |
|  */
 | |
| struct hob_res_desc {
 | |
| 	struct hob_header	hdr;
 | |
| 	/*
 | |
| 	 * A GUID representing the owner of the resource. This GUID is
 | |
| 	 * used by HOB consumer phase components to correlate device
 | |
| 	 * ownership of a resource.
 | |
| 	 */
 | |
| 	struct efi_guid		owner;
 | |
| 	u32			type;
 | |
| 	u32			attr;
 | |
| 	/* The physical start address of the resource region */
 | |
| 	phys_addr_t		phys_start;
 | |
| 	/* The number of bytes of the resource region */
 | |
| 	phys_size_t		len;
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Allows writers of executable content in the HOB producer phase to
 | |
|  * maintain and manage HOBs with specific GUID.
 | |
|  */
 | |
| struct hob_guid {
 | |
| 	struct hob_header	hdr;
 | |
| 	/* A GUID that defines the contents of this HOB */
 | |
| 	struct efi_guid		name;
 | |
| 	/* GUID specific data goes here */
 | |
| };
 | |
| 
 | |
| enum pixel_format {
 | |
| 	pixel_rgbx_8bpc,	/* RGB 8 bit per color */
 | |
| 	pixel_bgrx_8bpc,	/* BGR 8 bit per color */
 | |
| 	pixel_bitmask,
 | |
| };
 | |
| 
 | |
| struct __packed hob_graphics_info {
 | |
| 	phys_addr_t fb_base;	/* framebuffer base address */
 | |
| 	u32 fb_size;		/* framebuffer size */
 | |
| 	u32 version;
 | |
| 	u32 width;
 | |
| 	u32 height;
 | |
| 	enum pixel_format pixel_format;
 | |
| 	u32 red_mask;
 | |
| 	u32 green_mask;
 | |
| 	u32 blue_mask;
 | |
| 	u32 reserved_mask;
 | |
| 	u32 pixels_per_scanline;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * get_next_hob() - return a pointer to the next HOB in the HOB list
 | |
|  *
 | |
|  * This macro returns a pointer to HOB that follows the HOB specified by hob
 | |
|  * in the HOB List.
 | |
|  *
 | |
|  * @hdr:    A pointer to a HOB.
 | |
|  *
 | |
|  * @return: A pointer to the next HOB in the HOB list.
 | |
|  */
 | |
| static inline const struct hob_header *get_next_hob(const struct hob_header *hdr)
 | |
| {
 | |
| 	return (const struct hob_header *)((uintptr_t)hdr + hdr->len);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * end_of_hob() - determine if a HOB is the last HOB in the HOB list
 | |
|  *
 | |
|  * This macro determine if the HOB specified by hob is the last HOB in the
 | |
|  * HOB list.  If hob is last HOB in the HOB list, then true is returned.
 | |
|  * Otherwise, false is returned.
 | |
|  *
 | |
|  * @hdr:          A pointer to a HOB.
 | |
|  *
 | |
|  * @retval true:  The HOB specified by hdr is the last HOB in the HOB list.
 | |
|  * @retval false: The HOB specified by hdr is not the last HOB in the HOB list.
 | |
|  */
 | |
| static inline bool end_of_hob(const struct hob_header *hdr)
 | |
| {
 | |
| 	return hdr->type == HOB_TYPE_EOH;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * get_guid_hob_data() - return a pointer to data buffer from a HOB of
 | |
|  *                       type HOB_TYPE_GUID_EXT
 | |
|  *
 | |
|  * This macro returns a pointer to the data buffer in a HOB specified by hob.
 | |
|  * hob is assumed to be a HOB of type HOB_TYPE_GUID_EXT.
 | |
|  *
 | |
|  * @hdr:    A pointer to a HOB.
 | |
|  *
 | |
|  * @return: A pointer to the data buffer in a HOB.
 | |
|  */
 | |
| static inline void *get_guid_hob_data(const struct hob_header *hdr)
 | |
| {
 | |
| 	return (void *)((uintptr_t)hdr + sizeof(struct hob_guid));
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * get_guid_hob_data_size() - return the size of the data buffer from a HOB
 | |
|  *                            of type HOB_TYPE_GUID_EXT
 | |
|  *
 | |
|  * This macro returns the size, in bytes, of the data buffer in a HOB
 | |
|  * specified by hob. hob is assumed to be a HOB of type HOB_TYPE_GUID_EXT.
 | |
|  *
 | |
|  * @hdr:    A pointer to a HOB.
 | |
|  *
 | |
|  * @return: The size of the data buffer.
 | |
|  */
 | |
| static inline u16 get_guid_hob_data_size(const struct hob_header *hdr)
 | |
| {
 | |
| 	return hdr->len - sizeof(struct hob_guid);
 | |
| }
 | |
| 
 | |
| /* FSP specific GUID HOB definitions */
 | |
| #define FSP_GUID_DATA1		0x912740be
 | |
| #define FSP_GUID_DATA2		0x2284
 | |
| #define FSP_GUID_DATA3		0x4734
 | |
| #define FSP_GUID_DATA4_0	0xb9
 | |
| #define FSP_GUID_DATA4_1	0x71
 | |
| #define FSP_GUID_DATA4_2	0x84
 | |
| #define FSP_GUID_DATA4_3	0xb0
 | |
| #define FSP_GUID_DATA4_4	0x27
 | |
| #define FSP_GUID_DATA4_5	0x35
 | |
| #define FSP_GUID_DATA4_6	0x3f
 | |
| #define FSP_GUID_DATA4_7	0x0c
 | |
| 
 | |
| #define FSP_HEADER_GUID \
 | |
| 	{ \
 | |
| 	FSP_GUID_DATA1, FSP_GUID_DATA2, FSP_GUID_DATA3, \
 | |
| 	{ FSP_GUID_DATA4_0, FSP_GUID_DATA4_1, FSP_GUID_DATA4_2, \
 | |
| 	  FSP_GUID_DATA4_3, FSP_GUID_DATA4_4, FSP_GUID_DATA4_5, \
 | |
| 	  FSP_GUID_DATA4_6, FSP_GUID_DATA4_7 } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_NON_VOLATILE_STORAGE_HOB_GUID \
 | |
| 	{ \
 | |
| 	0x721acf02, 0x4d77, 0x4c2a, \
 | |
| 	{ 0xb3, 0xdc, 0x27, 0xb, 0x7b, 0xa9, 0xe4, 0xb0 } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_BOOTLOADER_TEMP_MEM_HOB_GUID \
 | |
| 	{ \
 | |
| 	0xbbcff46c, 0xc8d3, 0x4113, \
 | |
| 	{ 0x89, 0x85, 0xb9, 0xd4, 0xf3, 0xb3, 0xf6, 0x4e } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_HOB_RESOURCE_OWNER_FSP_GUID \
 | |
| 	{ \
 | |
| 	0x69a79759, 0x1373, 0x4367, \
 | |
| 	{ 0xa6, 0xc4, 0xc7, 0xf5, 0x9e, 0xfd, 0x98, 0x6e } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_HOB_RESOURCE_OWNER_TSEG_GUID \
 | |
| 	{ \
 | |
| 	0xd038747c, 0xd00c, 0x4980, \
 | |
| 	{ 0xb3, 0x19, 0x49, 0x01, 0x99, 0xa4, 0x7d, 0x55 } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_HOB_RESOURCE_OWNER_GRAPHICS_GUID \
 | |
| 	{ \
 | |
| 	0x9c7c3aa7, 0x5332, 0x4917, \
 | |
| 	{ 0x82, 0xb9, 0x56, 0xa5, 0xf3, 0xe6, 0x2a, 0x07 } \
 | |
| 	}
 | |
| 
 | |
| /* The following GUIDs are newly introduced in FSP spec 1.1 */
 | |
| 
 | |
| #define FSP_HOB_RESOURCE_OWNER_BOOTLOADER_TOLUM_GUID \
 | |
| 	{ \
 | |
| 	0x73ff4f56, 0xaa8e, 0x4451, \
 | |
| 	{ 0xb3, 0x16, 0x36, 0x35, 0x36, 0x67, 0xad, 0x44 } \
 | |
| 	}
 | |
| 
 | |
| #define FSP_GRAPHICS_INFO_HOB_GUID \
 | |
| 	{ \
 | |
| 	0x39f62cce, 0x6825, 0x4669, \
 | |
| 	{ 0xbb, 0x56, 0x54, 0x1a, 0xba, 0x75, 0x3a, 0x07 } \
 | |
| 	}
 | |
| 
 | |
| #endif
 |