x86: Ensure the CPU identity exists for timer init

When bootstage is used the timer can be inited before the CPU identity
is set up, resulting in the checks for the vendor not working.

Add a special call to work around this.

Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
Simon Glass 2024-08-27 19:44:25 -06:00
parent 6ab545ba21
commit 3b2e4f542e
4 changed files with 24 additions and 0 deletions

View File

@ -501,6 +501,11 @@ int x86_cpu_reinit_f(void)
return 0;
}
void x86_get_identity_for_timer(void)
{
setup_identity();
}
void x86_enable_caches(void)
{
unsigned long cr0;

View File

@ -75,3 +75,9 @@ void board_debug_uart_init(void)
/* this was already done in SPL */
}
#endif
void x86_get_identity_for_timer(void)
{
/* set the vendor to Intel so that native_calibrate_tsc() works */
gd->arch.x86_vendor = X86_VENDOR_INTEL;
}

View File

@ -43,6 +43,15 @@ int x86_cpu_reinit_f(void);
*/
int x86_cpu_init_tpl(void);
/**
* x86_get_identity_for_timer() - Set up CPU identity for use by the early timer
*
* The timer can be needed early in board_f if bootstage is enabled. This
* function can be called from the TSC timer to make sure that the CPU-identity
* info has been set up
*/
void x86_get_identity_for_timer(void);
/**
* cpu_reinit_fpu() - Reinit the FPU if something is wrong with it
*

View File

@ -403,6 +403,10 @@ static void tsc_timer_ensure_setup(bool early)
if (!gd->arch.clock_rate) {
unsigned long fast_calibrate;
/* deal with this being called before x86_cpu_init_f() */
if (!gd->arch.x86_vendor)
x86_get_identity_for_timer();
/**
* There is no obvious way to obtain this information from EFI
* boot services. This value was measured on a Framework Laptop