console,monotonic_timer: Avoid calls from APs

The code in cpu/x86/lapic/apic_timer.c for timer_monotonic_get()
is not SMP safe as LAPIC timers do not run as synchronised as TSCs.

The times reported for console for boot_states does not accumulate
from APs now. Also remove console time tracking from ENV_SMM.

Change-Id: I1ea2c1e7172f8ab3692b42dee3f669c5942d864a
Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/37398
Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Kyösti Mälkki 2019-12-01 08:38:11 +02:00 committed by Patrick Georgi
parent 934ae21b52
commit 05fe16c4f3

View file

@ -25,20 +25,20 @@
DECLARE_SPIN_LOCK(console_lock) DECLARE_SPIN_LOCK(console_lock)
#define TRACK_CONSOLE_TIME (CONFIG(HAVE_MONOTONIC_TIMER)) #define TRACK_CONSOLE_TIME (!ENV_SMM && CONFIG(HAVE_MONOTONIC_TIMER))
static struct mono_time mt_start, mt_stop; static struct mono_time mt_start, mt_stop;
static long console_usecs; static long console_usecs;
static void console_time_run(void) static void console_time_run(void)
{ {
if (TRACK_CONSOLE_TIME) if (TRACK_CONSOLE_TIME && boot_cpu())
timer_monotonic_get(&mt_start); timer_monotonic_get(&mt_start);
} }
static void console_time_stop(void) static void console_time_stop(void)
{ {
if (TRACK_CONSOLE_TIME) { if (TRACK_CONSOLE_TIME && boot_cpu()) {
timer_monotonic_get(&mt_stop); timer_monotonic_get(&mt_stop);
console_usecs += mono_time_diff_microseconds(&mt_start, &mt_stop); console_usecs += mono_time_diff_microseconds(&mt_start, &mt_stop);
} }