mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-11-04 02:11:25 +01:00 
			
		
		
		
	We expect VPL and SPL to load using VBE. Add a record of this so we can check it in U-Boot proper. Signed-off-by: Simon Glass <sjg@chromium.org>
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0+ */
 | 
						|
/*
 | 
						|
 * Verified Boot for Embedded (VBE) support
 | 
						|
 * See doc/develop/vbe.rst
 | 
						|
 *
 | 
						|
 * Copyright 2022 Google LLC
 | 
						|
 * Written by Simon Glass <sjg@chromium.org>
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef __VBE_H
 | 
						|
#define __VBE_H
 | 
						|
 | 
						|
/**
 | 
						|
 * enum vbe_phase_t - current phase of VBE
 | 
						|
 *
 | 
						|
 * VBE operates in two distinct phases. In VPL it has to choose which firmware
 | 
						|
 * to run (SPL, U-Boot, OP-TEE, etc.). It then carries on running until it gets
 | 
						|
 * to U-Boot, where it decides which OS to run
 | 
						|
 *
 | 
						|
 * @VBE_PHASE_FIRMWARE: Selecting the firmware to run
 | 
						|
 * @VBE_PHASE_OS: Selecting the Operating System to run
 | 
						|
 */
 | 
						|
enum vbe_phase_t {
 | 
						|
	VBE_PHASE_FIRMWARE,
 | 
						|
	VBE_PHASE_OS,
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * struct vbe_handoff - information about VBE progress
 | 
						|
 *
 | 
						|
 * @phases: Indicates which phases used the VBE bootmeth (1 << PHASE_...)
 | 
						|
 */
 | 
						|
struct vbe_handoff {
 | 
						|
	u8 phases;
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * vbe_phase() - get current VBE phase
 | 
						|
 *
 | 
						|
 * Returns: Current VBE phase
 | 
						|
 */
 | 
						|
static inline enum vbe_phase_t vbe_phase(void)
 | 
						|
{
 | 
						|
	if (IS_ENABLED(CONFIG_SPL_BUILD))
 | 
						|
		return VBE_PHASE_FIRMWARE;
 | 
						|
 | 
						|
	return VBE_PHASE_OS;
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * vbe_list() - List the VBE bootmeths
 | 
						|
 *
 | 
						|
 * This shows a list of the VBE bootmeth devices
 | 
						|
 *
 | 
						|
 * @return 0 (always)
 | 
						|
 */
 | 
						|
int vbe_list(void);
 | 
						|
 | 
						|
/**
 | 
						|
 * vbe_find_by_any() - Find a VBE bootmeth by name or sequence
 | 
						|
 *
 | 
						|
 * @name: name (e.g. "vbe-simple"), or sequence ("2") to find
 | 
						|
 * @devp: returns the device found, on success
 | 
						|
 * Return: 0 if OK, -ve on error
 | 
						|
 */
 | 
						|
int vbe_find_by_any(const char *name, struct udevice **devp);
 | 
						|
 | 
						|
/**
 | 
						|
 * vbe_find_first_device() - Find the first VBE bootmeth
 | 
						|
 *
 | 
						|
 * @devp: Returns first available VBE bootmeth, or NULL if none
 | 
						|
 * Returns: 0 (always)
 | 
						|
 */
 | 
						|
int vbe_find_first_device(struct udevice **devp);
 | 
						|
 | 
						|
/**
 | 
						|
 * vbe_find_next_device() - Find the next available VBE bootmeth
 | 
						|
 *
 | 
						|
 * @devp: Previous device to start from. Returns next available VBE bootmeth,
 | 
						|
 * or NULL if none
 | 
						|
 * Returns: 0 (always)
 | 
						|
 */
 | 
						|
int vbe_find_next_device(struct udevice **devp);
 | 
						|
 | 
						|
#endif
 |