mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2026-05-04 20:26:13 +02:00
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:
parent
6ab545ba21
commit
3b2e4f542e
@ -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;
|
||||
|
||||
@ -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;
|
||||
}
|
||||
|
||||
@ -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
|
||||
*
|
||||
|
||||
@ -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
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user