From: Simon Glass <sjg@chromium.org>
Date: Fri, 21 Oct 2022 00:23:09 +0000 (-0600)
Subject: vbe: Support selecting operations by SPL phase
X-Git-Tag: v2025.01-rc5-pxa1908~1227^2~11
X-Git-Url: http://git.dujemihanovic.xyz/img/html/static/gitweb.css?a=commitdiff_plain;h=70b26e4356f9153d2d8195748a0e146c35b0c42e;p=u-boot.git

vbe: Support selecting operations by SPL phase

VBE supports booting firmware during the SPL phases, i.e. so that VPL can
start SPL and SPL can start U-Boot.

It also supports booting an OS, when in U-Boot.

As a first step towards these features, add functions to indicate the
current VBE phase. The firmware selection is done in VPL and the OS
selection is done in U-Boot proper.

Signed-off-by: Simon Glass <sjg@chromium.org>
---

diff --git a/include/vbe.h b/include/vbe.h
index b83f6f0c51..ece2697b5d 100644
--- a/include/vbe.h
+++ b/include/vbe.h
@@ -10,6 +10,34 @@
 #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,
+};
+
+/**
+ * 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
  *