[coreboot-gerrit] Patch set updated for coreboot: cbmem: Always maintain backing store struct in a global on non-x86

Julius Werner (jwerner@chromium.org) gerrit at coreboot.org
Fri Aug 26 22:01:46 CEST 2016


Julius Werner (jwerner at chromium.org) just uploaded a new patch set to gerrit, which you can find at https://review.coreboot.org/16273

-gerrit

commit 136a14b075db3694564ebf4d9609cff9cd370cdf
Author: Julius Werner <jwerner at chromium.org>
Date:   Fri Aug 19 16:20:40 2016 -0700

    cbmem: Always maintain backing store struct in a global on non-x86
    
    The current CBMEM code contains an optimization that maintains the
    structure with information about the CBMEM backing store in a global
    variable, so that we don't have to recover it from cbmem_top() again
    every single time we access CBMEM. However, due to the problems with
    using globals in x86 romstage, this optimization has only been enabled
    in ramstage.
    
    However, all non-x86 platforms are SRAM-based (at least for now) and
    can use globals perfectly fine in earlier stages. Therefore, this patch
    extends the optimization on those platforms to all stages. This also
    allows us to remove the requirement that cbmem_top() needs to return
    NULL before its backing store has been initialized from those boards,
    since the CBMEM code can now keep track of whether it has been
    initialized by itself.
    
    Change-Id: Ia6c1db00ae01dee485d5e96e4315cb399dc63696
    Signed-off-by: Julius Werner <jwerner at chromium.org>
---
 src/include/cbmem.h |  5 ++---
 src/lib/imd_cbmem.c | 16 ++++++++++------
 2 files changed, 12 insertions(+), 9 deletions(-)

diff --git a/src/include/cbmem.h b/src/include/cbmem.h
index 5b75db0..6a41ec7 100644
--- a/src/include/cbmem.h
+++ b/src/include/cbmem.h
@@ -67,9 +67,8 @@ void cbmem_initialize_empty_id_size(u32 id, u64 size);
 /* Return the top address for dynamic cbmem. The address returned needs to
  * be consistent across romstage and ramstage, and it is required to be
  * below 4GiB.
- * Board or chipset should return NULL if any interface that might rely on cbmem
- * (e.g. cbfs, vboot) is used before the cbmem backing store has been
- * initialized. */
+ * x86 boards or chipsets must return NULL before the cbmem backing store has
+ * been initialized. */
 void *cbmem_top(void);
 
 /* Add a cbmem entry of a given size and id. These return NULL on failure. The
diff --git a/src/lib/imd_cbmem.c b/src/lib/imd_cbmem.c
index 3e3e2b0..c31b59b 100644
--- a/src/lib/imd_cbmem.c
+++ b/src/lib/imd_cbmem.c
@@ -26,10 +26,17 @@
 #include <arch/acpi.h>
 #endif
 
+/* We need special handling on x86 before ramstage because we cannot use global
+ * variables (we're executing in-place from flash so we don't have a writable
+ * data segment, and we cannot use CAR_GLOBAL here since that mechanism itself
+ * is dependent on CBMEM). Therefore, we have to always try to partially recover
+ * CBMEM from cbmem_top() whenever we try to access it. In other environments
+ * we're not so constrained and just keep the backing imd struct in a global. */
+#define CAN_USE_GLOBALS (!IS_ENABLED(CONFIG_ARCH_X86) || ENV_RAMSTAGE)
+
 static inline struct imd *cbmem_get_imd(void)
 {
-	/* Only supply a backing store for imd in ramstage. */
-	if (ENV_RAMSTAGE) {
+	if (CAN_USE_GLOBALS) {
 		static struct imd imd_cbmem;
 		return &imd_cbmem;
 	}
@@ -77,11 +84,8 @@ static struct imd *imd_init_backing_with_recover(struct imd *backing)
 	struct imd *imd;
 
 	imd = imd_init_backing(backing);
-	if (!ENV_RAMSTAGE) {
+	if (!CAN_USE_GLOBALS) {
 		imd_handle_init(imd, cbmem_top());
-
-		/* Need to partially recover all the time outside of ramstage
-		 * because there's object storage outside of the stack. */
 		imd_handle_init_partial_recovery(imd);
 	}
 



More information about the coreboot-gerrit mailing list