summaryrefslogtreecommitdiffstats
path: root/src/lib/bootblock.c
diff options
context:
space:
mode:
authorAlexandru Gagniuc <alexandrux.gagniuc@intel.com>2016-05-16 16:17:39 -0700
committerAaron Durbin <adurbin@chromium.org>2016-05-19 18:26:42 +0200
commitff196b62274abd55c62083efe89f43085c1143d3 (patch)
tree2e1d4a0a8aa3abc60d12881c8077c7442ce3d769 /src/lib/bootblock.c
parent63e7b5b8a7dc69d1546ccd0d2ee4fcce8a2cc67d (diff)
downloadcoreboot-ff196b62274abd55c62083efe89f43085c1143d3.tar.gz
coreboot-ff196b62274abd55c62083efe89f43085c1143d3.tar.bz2
coreboot-ff196b62274abd55c62083efe89f43085c1143d3.zip
lib/bootblock: Provide mechanism to pass in an early timestamp
This is useful, for example, in the bootblock, when a timestamp is available which predates the call to main() in lib/bootblock.c Change-Id: I17bb0add9f2d8721504b2e534dd6904d1201989c Signed-off-by: Alexandru Gagniuc <alexandrux.gagniuc@intel.com> Reviewed-on: https://review.coreboot.org/14862 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@chromium.org> Reviewed-by: Julius Werner <jwerner@chromium.org>
Diffstat (limited to 'src/lib/bootblock.c')
-rw-r--r--src/lib/bootblock.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/lib/bootblock.c b/src/lib/bootblock.c
index 658eea45c99d..f16cb44df62e 100644
--- a/src/lib/bootblock.c
+++ b/src/lib/bootblock.c
@@ -29,13 +29,11 @@ __attribute__((weak)) void bootblock_soc_early_init(void) { /* do nothing */ }
__attribute__((weak)) void bootblock_soc_init(void) { /* do nothing */ }
__attribute__((weak)) void bootblock_mainboard_init(void) { /* do nothing */ }
-void main(void)
+void bootblock_main_with_timestamp(uint64_t base_timestamp)
{
- init_timer();
-
/* Initialize timestamps if we have TIMESTAMP region in memlayout.ld. */
if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS) && _timestamp_size > 0)
- timestamp_init(timestamp_get());
+ timestamp_init(base_timestamp);
bootblock_soc_early_init();
bootblock_mainboard_early_init();
@@ -50,3 +48,15 @@ void main(void)
run_romstage();
}
+
+void main(void)
+{
+ uint64_t base_timestamp = 0;
+
+ init_timer();
+
+ if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS))
+ base_timestamp = timestamp_get();
+
+ bootblock_main_with_timestamp(base_timestamp);
+}