0d6ddf8da7
The x86 timers are a bit of a mess. Cases where different stages use different counters and timestamps use different counters from udelays. The original intention was to only flip TSC_CONSTANT_RATE Kconfig to NOT_CONSTANT_TSC_RATE. The name would be incorrect though, those counters do run with a constant rate but we just lack tsc_freq_mhz() implementation for three platforms. Note that for boards with UNKNOWN_TSC_RATE=y, each stage will have a slow run of calibrate_tsc_with_pit(). This is easy enough to fix with followup implementation of tsc_freq_mhz() for the platforms. Implementations with LAPIC_MONOTONIC_TIMER typically will not have tsc_freq_mhz() implemented and default to UNKNOWN_TSC_RATE. However, as they don't use TSC for udelay() the slow calibrate_tsc_with_pit() is avoided. Because x86/tsc_delay.tsc was using two different guards and nb/via/vx900 claimed UDELAY_TSC, but pulled UDELAY_IO implementation, we also switch that romstage to use UDELAY_TSC. Change-Id: I1690cb80295d6b006b75ed69edea28899b674b68 Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/33928 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org> |
||
---|---|---|
.. | ||
acpi | ||
bootblock | ||
include/soc | ||
acpi.c | ||
car.c | ||
chip.c | ||
chip.h | ||
cpu.c | ||
cse.c | ||
elog.c | ||
fspcar.c | ||
glk_page_map.txt | ||
gpio_apl.c | ||
gpio_glk.c | ||
graphics.c | ||
gspi.c | ||
heci.c | ||
i2c.c | ||
Kconfig | ||
lpc.c | ||
Makefile.inc | ||
meminit.c | ||
meminit_util_apl.c | ||
meminit_util_glk.c | ||
memmap.c | ||
mmap_boot.c | ||
nhlt.c | ||
pdpt.c | ||
pmc.c | ||
pmutil.c | ||
pnpconfig.c | ||
pt.c | ||
reset.c | ||
romstage.c | ||
sd.c | ||
smihandler.c | ||
spi.c | ||
systemagent.c | ||
uart.c | ||
xdci.c | ||
xhci.c |