summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/Kconfig6
-rw-r--r--src/lib/imd_cbmem.c8
2 files changed, 12 insertions, 2 deletions
diff --git a/src/Kconfig b/src/Kconfig
index 7c1415e62d..1cc0bfaea9 100644
--- a/src/Kconfig
+++ b/src/Kconfig
@@ -209,6 +209,12 @@ config NO_XIP_EARLY_STAGES
config EARLY_CBMEM_INIT
def_bool !LATE_CBMEM_INIT
+config EARLY_CBMEM_LIST
+ bool
+ default n
+ help
+ Enable display of CBMEM during romstage and postcar.
+
config COLLECT_TIMESTAMPS
bool "Create a table of timestamps collected during boot"
default n
diff --git a/src/lib/imd_cbmem.c b/src/lib/imd_cbmem.c
index a0780719fe..3e3e2b0637 100644
--- a/src/lib/imd_cbmem.c
+++ b/src/lib/imd_cbmem.c
@@ -279,7 +279,8 @@ void cbmem_add_bootmem(void)
bootmem_add_range(base, size, LB_MEM_TABLE);
}
-#if ENV_RAMSTAGE
+#if ENV_RAMSTAGE || (IS_ENABLED(CONFIG_EARLY_CBMEM_LIST) \
+ && (ENV_POSTCAR || ENV_ROMSTAGE))
/*
* -fdata-sections doesn't work so well on read only strings. They all
* get put in the same section even though those strings may never be
@@ -288,8 +289,11 @@ void cbmem_add_bootmem(void)
void cbmem_list(void)
{
static const struct imd_lookup lookup[] = { CBMEM_ID_TO_NAME_TABLE };
+ struct imd *imd;
+ struct imd imd_backing;
- imd_print_entries(cbmem_get_imd(), lookup, ARRAY_SIZE(lookup));
+ imd = imd_init_backing_with_recover(&imd_backing);
+ imd_print_entries(imd, lookup, ARRAY_SIZE(lookup));
}
#endif