diff options
author | Aaron Durbin <adurbin@chromium.org> | 2015-04-06 16:12:58 -0500 |
---|---|---|
committer | Aaron Durbin <adurbin@google.com> | 2015-04-07 23:02:32 +0200 |
commit | b0d8f5e9cdab5c53cb8438175517ad171e9e5ddb (patch) | |
tree | 4e0903c2078bffec21ed433114c04e8e46ce0e78 /src/lib/hardwaremain.c | |
parent | 8c5e4d93db845fc1942438d54eedbdefcfd2bbf9 (diff) | |
download | coreboot-b0d8f5e9cdab5c53cb8438175517ad171e9e5ddb.tar.gz coreboot-b0d8f5e9cdab5c53cb8438175517ad171e9e5ddb.tar.bz2 coreboot-b0d8f5e9cdab5c53cb8438175517ad171e9e5ddb.zip |
hardwaremain: explicitly call cbmem_initialize() early
Over the course of time there have been some implicit assumptions
about cbmem being available for find() or add() operations. However,
the cbmem area was never fully recovered until entering the state
machine: BS_ON_ENTRY into BS_PRE_DEVICE. Correct this assumption
by explicitly calling cbmem_initialize() in the EARLY_CBMEM_INIT
case.
This, however, doesn't fix timestamp_init() showing an error about
not being able to allocate the timestamp table.
Change-Id: Ib93fcc932e202ebd37822f07a278ea9694fe965c
Signed-off-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-on: http://review.coreboot.org/9327
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'src/lib/hardwaremain.c')
-rw-r--r-- | src/lib/hardwaremain.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/lib/hardwaremain.c b/src/lib/hardwaremain.c index 83bc7be522f6..5f06ca762a17 100644 --- a/src/lib/hardwaremain.c +++ b/src/lib/hardwaremain.c @@ -26,6 +26,7 @@ #include <bootstate.h> #include <console/console.h> #include <console/post_codes.h> +#include <cbmem.h> #include <version.h> #include <device/device.h> #include <device/pci.h> @@ -433,6 +434,14 @@ static void boot_state_schedule_static_entries(void) void main(void) { + /* + * CBMEM needs to be recovered in the EARLY_CBMEM_INIT case because + * timestamps, APCI, etc rely on the cbmem infrastructure being + * around. Explicitly recover it. + */ + if (IS_ENABLED(CONFIG_EARLY_CBMEM_INIT)) + cbmem_initialize(); + /* Record current time, try to locate timestamps in CBMEM. */ timestamp_init(timestamp_get()); |