mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 17:48:26 +00:00 
			
		
		
		
	Sughosh Ganu <sughosh.ganu@linaro.org> says: The following patch series adds support for version 2 of the FWU metadata. The version 2 metadata structure is defined in the latest revision of the FWU specification [1]. The earlier versions of these patches were migrating to a version 2 only support in U-Boot, similar to TF-A. However, based on feedback from ST [2], this series has been updated to support both versions. A platform would still be needed to enable one of the two versions of metadata through a config symbol. TF-A has code which reads the FWU metadata and boots the platform from the active partition. TF-A has decided to migrate the FWU code to a version 2 only support. These changes have been merged in upstream TF-A. These changes have been tested on the ST DK2 board, which uses the GPT based partitioning scheme. Both V1 and V2 metadata versions have been tested on the DK2 board. These changes need to be tested on platforms with MTD partitioned storage devices.
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-or-later
 | |
| /*
 | |
|  * Copyright (c) 2022, Linaro Limited
 | |
|  */
 | |
| 
 | |
| #define LOG_CATEGORY UCLASS_FWU_MDATA
 | |
| 
 | |
| #include <dm.h>
 | |
| #include <efi_loader.h>
 | |
| #include <fwu.h>
 | |
| #include <fwu_mdata.h>
 | |
| #include <log.h>
 | |
| 
 | |
| #include <linux/errno.h>
 | |
| #include <linux/types.h>
 | |
| 
 | |
| /**
 | |
|  * fwu_read_mdata() - Wrapper around fwu_mdata_ops.read_mdata()
 | |
|  *
 | |
|  * Return: 0 if OK, -ve on error
 | |
|  */
 | |
| int fwu_read_mdata(struct udevice *dev, struct fwu_mdata *mdata, bool primary,
 | |
| 		   uint32_t size)
 | |
| {
 | |
| 	const struct fwu_mdata_ops *ops = device_get_ops(dev);
 | |
| 
 | |
| 	if (!ops->read_mdata) {
 | |
| 		log_debug("read_mdata() method not defined\n");
 | |
| 		return -ENOSYS;
 | |
| 	}
 | |
| 
 | |
| 	return ops->read_mdata(dev, mdata, primary, size);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * fwu_write_mdata() - Wrapper around fwu_mdata_ops.write_mdata()
 | |
|  *
 | |
|  * Return: 0 if OK, -ve on error
 | |
|  */
 | |
| int fwu_write_mdata(struct udevice *dev, struct fwu_mdata *mdata, bool primary,
 | |
| 		    uint32_t size)
 | |
| {
 | |
| 	const struct fwu_mdata_ops *ops = device_get_ops(dev);
 | |
| 
 | |
| 	if (!ops->write_mdata) {
 | |
| 		log_debug("write_mdata() method not defined\n");
 | |
| 		return -ENOSYS;
 | |
| 	}
 | |
| 
 | |
| 	return ops->write_mdata(dev, mdata, primary, size);
 | |
| }
 | |
| 
 | |
| UCLASS_DRIVER(fwu_mdata) = {
 | |
| 	.id		= UCLASS_FWU_MDATA,
 | |
| 	.name		= "fwu-mdata",
 | |
| };
 |