x86/microcode/amd: Use correct per CPU ucode_cpu_info

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Thomas Gleixner <tglx@xxxxxxxxxxxxx>

commit ecfd41089348fa4cc767dc588367e9fdf8cb6b9d upstream

find_blobs_in_containers() is invoked on every CPU but overwrites
unconditionally ucode_cpu_info of CPU0.

Fix this by using the proper CPU data and move the assignment into the
call site apply_ucode_from_containers() so that the function can be
reused.

Signed-off-by: Thomas Gleixner <tglx@xxxxxxxxxxxxx>
Signed-off-by: Borislav Petkov (AMD) <bp@xxxxxxxxx>
Link: https://lore.kernel.org/r/20231010150702.433454320@xxxxxxxxxxxxx
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
 arch/x86/kernel/cpu/microcode/amd.c |    6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

--- a/arch/x86/kernel/cpu/microcode/amd.c
+++ b/arch/x86/kernel/cpu/microcode/amd.c
@@ -503,9 +503,6 @@ static void find_blobs_in_containers(uns
 	if (!get_builtin_microcode(&cp, x86_family(cpuid_1_eax)))
 		cp = find_microcode_in_initrd(ucode_path);
 
-	/* Needed in load_microcode_amd() */
-	ucode_cpu_info->cpu_sig.sig = cpuid_1_eax;
-
 	*ret = cp;
 }
 
@@ -513,6 +510,9 @@ static void apply_ucode_from_containers(
 {
 	struct cpio_data cp = { };
 
+	/* Needed in load_microcode_amd() */
+	ucode_cpu_info[smp_processor_id()].cpu_sig.sig = cpuid_1_eax;
+
 	find_blobs_in_containers(cpuid_1_eax, &cp);
 	if (!(cp.data && cp.size))
 		return;


Patches currently in stable-queue which might be from tglx@xxxxxxxxxxxxx are

queue-6.6/x86-microcode-intel-cleanup-code-further.patch
queue-6.6/x86-microcode-intel-simplify-scan_microcode.patch
queue-6.6/x86-microcode-mop-up-early-loading-leftovers.patch
queue-6.6/x86-microcode-provide-new-control-functions.patch
queue-6.6/x86-microcode-intel-save-the-microcode-only-after-a-successful-late-load.patch
queue-6.6/x86-microcode-32-move-early-loading-after-paging-enable.patch
queue-6.6/x86-microcode-intel-simplify-early-loading.patch
queue-6.6/x86-microcode-add-per-cpu-control-field.patch
queue-6.6/x86-microcode-add-per-cpu-result-state.patch
queue-6.6/x86-microcode-prepare-for-minimal-revision-check.patch
queue-6.6/x86-microcode-intel-simplify-and-rename-generic_load_microcode.patch
queue-6.6/x86-microcode-amd-get-rid-of-the-_load_microcode_amd-forward-declaration.patch
queue-6.6/x86-microcode-handle-offline-cpus-correctly.patch
queue-6.6/x86-microcode-get-rid-of-the-schedule-work-indirection.patch
queue-6.6/x86-microcode-intel-rework-intel_cpu_collect_info.patch
queue-6.6/x86-microcode-amd-use-cached-microcode-for-ap-load.patch
queue-6.6/x86-microcode-replace-the-all-in-one-rendevous-handler.patch
queue-6.6/x86-microcode-amd-add-get_patch_level.patch
queue-6.6/x86-apic-provide-apic_force_nmi_on_cpu.patch
queue-6.6/sched-core-prevent-rescheduling-when-interrupts-are-disabled.patch
queue-6.6/x86-cpu-fix-warm-boot-hang-regression-on-amd-sc1100-.patch
queue-6.6/x86-microcode-intel-rework-intel_find_matching_signature.patch
queue-6.6/x86-microcode-remove-pointless-apply-invocation.patch
queue-6.6/x86-microcode-intel-reuse-intel_cpu_collect_info.patch
queue-6.6/x86-microcode-amd-use-correct-per-cpu-ucode_cpu_info.patch
queue-6.6/x86-microcode-amd-cache-builtin-initrd-microcode-early.patch
queue-6.6/x86-microcode-protect-against-instrumentation.patch
queue-6.6/x86-microcode-clean-up-mc_cpu_down_prep.patch
queue-6.6/x86-microcode-amd-cache-builtin-microcode-too.patch
queue-6.6/x86-microcode-amd-merge-early_apply_microcode-into-its-single-callsite.patch
queue-6.6/x86-microcode-rendezvous-and-load-in-nmi.patch
queue-6.6/x86-microcode-intel-rip-out-mixed-stepping-support-for-intel-cpus.patch
queue-6.6/x86-microcode-intel-unify-microcode-apply-functions.patch
queue-6.6/intel_idle-handle-older-cpus-which-stop-the-tsc-in-deeper-c-states-correctly.patch
queue-6.6/x86-microcode-intel-switch-to-kvmalloc.patch
queue-6.6/x86-microcode-clarify-the-late-load-logic.patch
queue-6.6/x86-microcode-sanitize-__wait_for_cpus.patch
queue-6.6/x86-microcode-rework-early-revisions-reporting.patch
queue-6.6/rcuref-plug-slowpath-race-in-rcuref_put.patch
queue-6.6/x86-microcode-handle-nosmt-correctly.patch




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux