Skip to content

Commit

Permalink
x86: Reload cpuid after loading microcode for the BSP
Browse files Browse the repository at this point in the history
Right now, we're doing very early init - then parsing boot modules -
and only then doing the microcode load for the BSP. This results in
having possibly stale cpuid info that doesn't correspond to the current
microcode. Fix that by reloading if cpu 0.

Signed-off-by: Pedro Falcato <[email protected]>
  • Loading branch information
heatd committed Nov 30, 2024
1 parent 5337062 commit cb8f96b
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion kernel/arch/x86_64/cpu.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -84,13 +84,22 @@ uint64_t x86_get_tsc_rate(void)

extern "C" void intel_ucode_load(void);

static void __cpu_identify(void);

void x86_load_ucode(void)
{
if (bootcpu_info.manufacturer == X86_CPU_MANUFACTURER_INTEL)
intel_ucode_load();

if (get_cpu_nr() == 0)
{
/* If we're cpu 0, try to reload cpuid bits, since we might be loading ucode a little after
* the initial cpu_identify. */
__cpu_identify();
}
}

void __cpu_identify(void)
static void __cpu_identify(void)
{
uint32_t eax = 0;
uint32_t ebx = 0;
Expand Down

0 comments on commit cb8f96b

Please sign in to comment.