mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 05:50:17 +00:00 
			
		
		
		
	Add support for version 2 of the FWU metadata structure. The top level structure is kept separate through a config symbol. Most of the fields, primarily used for providing information on updatable images are common across the two versions. Also change a few existing structure members used for image identification to reflect the fact that these are GUIDs, and not UUIDs. Signed-off-by: Sughosh Ganu <sughosh.ganu@linaro.org> Tested-by: Michal Simek <michal.simek@amd.com>
		
			
				
	
	
		
			128 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0-or-later */
 | 
						|
/*
 | 
						|
 * Copyright (c) 2022, Linaro Limited
 | 
						|
 */
 | 
						|
 | 
						|
#if !defined _FWU_MDATA_H_
 | 
						|
#define _FWU_MDATA_H_
 | 
						|
 | 
						|
#include <linux/compiler_attributes.h>
 | 
						|
#include <efi.h>
 | 
						|
 | 
						|
/**
 | 
						|
 * struct fwu_image_bank_info - firmware image information
 | 
						|
 * @image_guid: Guid value of the image in this bank
 | 
						|
 * @accepted: Acceptance status of the image
 | 
						|
 * @reserved: Reserved
 | 
						|
 *
 | 
						|
 * The structure contains image specific fields which are
 | 
						|
 * used to identify the image and to specify the image's
 | 
						|
 * acceptance status
 | 
						|
 */
 | 
						|
struct fwu_image_bank_info {
 | 
						|
	efi_guid_t  image_guid;
 | 
						|
	uint32_t accepted;
 | 
						|
	uint32_t reserved;
 | 
						|
} __packed;
 | 
						|
 | 
						|
/**
 | 
						|
 * struct fwu_image_entry - information for a particular type of image
 | 
						|
 * @image_type_guid: Guid value for identifying the image type
 | 
						|
 * @location_guid: Guid of the storage volume where the image is located
 | 
						|
 * @img_bank_info: Array containing properties of images
 | 
						|
 *
 | 
						|
 * This structure contains information on various types of updatable
 | 
						|
 * firmware images. Each image type then contains an array of image
 | 
						|
 * information per bank.
 | 
						|
 */
 | 
						|
struct fwu_image_entry {
 | 
						|
	efi_guid_t image_type_guid;
 | 
						|
	efi_guid_t location_guid;
 | 
						|
	struct fwu_image_bank_info img_bank_info[CONFIG_FWU_NUM_BANKS];
 | 
						|
} __packed;
 | 
						|
 | 
						|
/**
 | 
						|
 * struct fwu_fw_store_desc - FWU updatable image information
 | 
						|
 * @num_banks: Number of firmware banks
 | 
						|
 * @num_images: Number of images per bank
 | 
						|
 * @img_entry_size: The size of the img_entry array
 | 
						|
 * @bank_info_entry_size: The size of the img_bank_info array
 | 
						|
 * @img_entry: Array of image entries each giving information on a image
 | 
						|
 *
 | 
						|
 * This image descriptor structure contains information on the number of
 | 
						|
 * updatable banks and images per bank. It also gives the total sizes of
 | 
						|
 * the fwu_image_entry and fwu_image_bank_info arrays. This structure is
 | 
						|
 * only present in version 2 of the metadata structure.
 | 
						|
 */
 | 
						|
struct fwu_fw_store_desc {
 | 
						|
	uint8_t  num_banks;
 | 
						|
	uint8_t  reserved;
 | 
						|
	uint16_t num_images;
 | 
						|
	uint16_t img_entry_size;
 | 
						|
	uint16_t bank_info_entry_size;
 | 
						|
 | 
						|
	struct fwu_image_entry img_entry[CONFIG_FWU_NUM_IMAGES_PER_BANK];
 | 
						|
} __packed;
 | 
						|
 | 
						|
#if defined(CONFIG_FWU_MDATA_V1)
 | 
						|
/**
 | 
						|
 * struct fwu_mdata - FWU metadata structure for multi-bank updates
 | 
						|
 * @crc32: crc32 value for the FWU metadata
 | 
						|
 * @version: FWU metadata version
 | 
						|
 * @active_index: Index of the bank currently used for booting images
 | 
						|
 * @previous_active_inde: Index of the bank used before the current bank
 | 
						|
 *                        being used for booting
 | 
						|
 * @img_entry: Array of information on various firmware images that can
 | 
						|
 *             be updated
 | 
						|
 *
 | 
						|
 * This structure is used to store all the needed information for performing
 | 
						|
 * multi bank updates on the platform. This contains info on the bank being
 | 
						|
 * used to boot along with the information needed for identification of
 | 
						|
 * individual images
 | 
						|
 */
 | 
						|
struct fwu_mdata {
 | 
						|
	uint32_t crc32;
 | 
						|
	uint32_t version;
 | 
						|
	uint32_t active_index;
 | 
						|
	uint32_t previous_active_index;
 | 
						|
 | 
						|
	struct fwu_image_entry img_entry[CONFIG_FWU_NUM_IMAGES_PER_BANK];
 | 
						|
} __packed;
 | 
						|
 | 
						|
#else /* CONFIG_FWU_MDATA_V1 */
 | 
						|
/**
 | 
						|
 * struct fwu_mdata - FWU metadata structure for multi-bank updates
 | 
						|
 * @crc32: crc32 value for the FWU metadata
 | 
						|
 * @version: FWU metadata version
 | 
						|
 * @active_index: Index of the bank currently used for booting images
 | 
						|
 * @previous_active_inde: Index of the bank used before the current bank
 | 
						|
 *                        being used for booting
 | 
						|
 * @metadata_size: Size of the entire metadata structure, including the
 | 
						|
 *                 image descriptors
 | 
						|
 * @desc_offset: The offset from the start of this structure where the
 | 
						|
 *               image descriptor structure starts. 0 if absent
 | 
						|
 * @bank_state: State of each bank, valid, invalid or accepted
 | 
						|
 * @fw_desc: The structure describing the FWU updatable images
 | 
						|
 *
 | 
						|
 * This is the top level structure used to store all information for performing
 | 
						|
 * multi bank updates on the platform. This contains info on the bank being
 | 
						|
 * used to boot along with the information on state of individual banks.
 | 
						|
 */
 | 
						|
struct fwu_mdata {
 | 
						|
	uint32_t crc32;
 | 
						|
	uint32_t version;
 | 
						|
	uint32_t active_index;
 | 
						|
	uint32_t previous_active_index;
 | 
						|
	uint32_t metadata_size;
 | 
						|
	uint16_t desc_offset;
 | 
						|
	uint16_t reserved1;
 | 
						|
	uint8_t  bank_state[4];
 | 
						|
	uint32_t reserved2;
 | 
						|
 | 
						|
	// struct fwu_fw_store_desc fw_desc;
 | 
						|
} __packed;
 | 
						|
 | 
						|
#endif /* CONFIG_FWU_MDATA_V1 */
 | 
						|
 | 
						|
#endif /* _FWU_MDATA_H_ */
 |