There are too many "FIT" in firmware land. In order to reduce possible confusion of CBFS_TYPE_FIT with the Intel Firmware Interface Table, this patch renames it to CBFS_TYPE_FIT_PAYLOAD (including the cbfstool argument, so calling scripts will now need to replace `-t fit` with `-t fit_payload`). Signed-off-by: Julius Werner <jwerner@chromium.org> Change-Id: I826cefce54ade06c6612c8a7bb53e02092e7b11a Reviewed-on: https://review.coreboot.org/c/coreboot/+/64735 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com>
		
			
				
	
	
		
			137 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			137 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0-only or BSD-3-Clause */
 | 
						|
 | 
						|
#ifndef _CBFS_H_
 | 
						|
#define _CBFS_H_
 | 
						|
 | 
						|
#include "coreboot_tables.h"
 | 
						|
 | 
						|
typedef uint64_t u64;
 | 
						|
typedef uint32_t u32;
 | 
						|
typedef uint16_t u16;
 | 
						|
typedef uint8_t u8;
 | 
						|
 | 
						|
/** These are standard values for the known compression
 | 
						|
    algorithms that coreboot knows about for stages and
 | 
						|
    payloads.  Of course, other CBFS users can use whatever
 | 
						|
    values they want, as long as they understand them. */
 | 
						|
 | 
						|
#define CBFS_COMPRESS_NONE  0
 | 
						|
#define CBFS_COMPRESS_LZMA  1
 | 
						|
#define CBFS_COMPRESS_LZ4   2
 | 
						|
 | 
						|
/** These are standard component types for well known
 | 
						|
    components (i.e - those that coreboot needs to consume.
 | 
						|
    Users are welcome to use any other value for their
 | 
						|
    components */
 | 
						|
 | 
						|
#define CBFS_TYPE_STAGE		0x10
 | 
						|
#define CBFS_TYPE_SELF		0x20
 | 
						|
#define CBFS_TYPE_FIT_PAYLOAD	0x21
 | 
						|
#define CBFS_TYPE_OPTIONROM	0x30
 | 
						|
#define CBFS_TYPE_BOOTSPLASH	0x40
 | 
						|
#define CBFS_TYPE_RAW		0x50
 | 
						|
#define CBFS_TYPE_VSA		0x51
 | 
						|
#define CBFS_TYPE_MBI		0x52
 | 
						|
#define CBFS_TYPE_MICROCODE	0x53
 | 
						|
#define CBFS_COMPONENT_CMOS_DEFAULT 0xaa
 | 
						|
#define CBFS_COMPONENT_CMOS_LAYOUT 0x01aa
 | 
						|
 | 
						|
 | 
						|
/** this is the master cbfs header - it need to be
 | 
						|
    located somewhere in the bootblock.  Where it
 | 
						|
    actually lives is up to coreboot. A pointer to
 | 
						|
    this header will live at 0xFFFFFFFc, so we can
 | 
						|
    easily find it. */
 | 
						|
 | 
						|
#define CBFS_HEADER_MAGIC  0x4F524243
 | 
						|
#define CBFS_HEADPTR_ADDR 0xFFFFFFFc
 | 
						|
#define CBFS_HEADER_VERSION1 0x31313131
 | 
						|
 | 
						|
struct cbfs_header {
 | 
						|
	u32 magic;
 | 
						|
        u32 version;
 | 
						|
        u32 romsize;
 | 
						|
        u32 bootblocksize;
 | 
						|
	u32 align;
 | 
						|
	u32 offset;
 | 
						|
	u32 pad[2];
 | 
						|
} __attribute__((packed));
 | 
						|
 | 
						|
/** This is a component header - every entry in the CBFS
 | 
						|
    will have this header.
 | 
						|
 | 
						|
    This is how the component is arranged in the ROM:
 | 
						|
 | 
						|
    --------------   <- 0
 | 
						|
    component header
 | 
						|
    --------------   <- sizeof(struct component)
 | 
						|
    component name
 | 
						|
    --------------   <- offset
 | 
						|
    data
 | 
						|
    ...
 | 
						|
    --------------   <- offset + len
 | 
						|
*/
 | 
						|
 | 
						|
#define CBFS_FILE_MAGIC "LARCHIVE"
 | 
						|
 | 
						|
struct cbfs_file {
 | 
						|
	char magic[8];
 | 
						|
	u32 len;
 | 
						|
	u32 type;
 | 
						|
	u32 checksum;
 | 
						|
	u32 offset;
 | 
						|
} __attribute__((packed));
 | 
						|
 | 
						|
/*** Component sub-headers ***/
 | 
						|
 | 
						|
/* Following are component sub-headers for the "standard"
 | 
						|
   component types */
 | 
						|
 | 
						|
/** This is the sub-header for stage components.  Stages are
 | 
						|
    loaded by coreboot during the normal boot process */
 | 
						|
 | 
						|
struct cbfs_stage {
 | 
						|
	u32 compression;  /** Compression type */
 | 
						|
	u64 entry;  /** entry point */
 | 
						|
	u64 load;   /** Where to load in memory */
 | 
						|
	u32 len;          /** length of data to load */
 | 
						|
	u32 memlen;	   /** total length of object in memory */
 | 
						|
} __attribute__((packed));
 | 
						|
 | 
						|
/** this is the sub-header for payload components.  Payloads
 | 
						|
    are loaded by coreboot at the end of the boot process */
 | 
						|
 | 
						|
struct cbfs_payload_segment {
 | 
						|
	u32 type;
 | 
						|
	u32 compression;
 | 
						|
	u32 offset;
 | 
						|
	u64 load_addr;
 | 
						|
	u32 len;
 | 
						|
	u32 mem_len;
 | 
						|
} __attribute__((packed));
 | 
						|
 | 
						|
struct cbfs_payload {
 | 
						|
	struct cbfs_payload_segment segments;
 | 
						|
};
 | 
						|
 | 
						|
#define PAYLOAD_SEGMENT_CODE   0x45444F43
 | 
						|
#define PAYLOAD_SEGMENT_DATA   0x41544144
 | 
						|
#define PAYLOAD_SEGMENT_BSS    0x20535342
 | 
						|
#define PAYLOAD_SEGMENT_PARAMS 0x41524150
 | 
						|
#define PAYLOAD_SEGMENT_ENTRY  0x52544E45
 | 
						|
 | 
						|
struct cbfs_optionrom {
 | 
						|
	u32 compression;
 | 
						|
	u32 len;
 | 
						|
} __attribute__((packed));
 | 
						|
 | 
						|
#define CBFS_NAME(_c) (((char *) (_c)) + sizeof(struct cbfs_file))
 | 
						|
#define CBFS_SUBHEADER(_p) ( (void *) ((((u8 *) (_p)) + ntohl((_p)->offset))) )
 | 
						|
 | 
						|
void * cbfs_get_file(const char *name);
 | 
						|
struct cbfs_file *cbfs_find(const char *name);
 | 
						|
void *cbfs_find_file(const char *name, unsigned int type, unsigned int *len);
 | 
						|
 | 
						|
void open_cbfs(const char *filename);
 | 
						|
#endif
 |