/* 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 */ #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