From 9872d99215ba9234b927d2c55625b70b4f555c60 Mon Sep 17 00:00:00 2001 From: Andrew Cooper Date: Wed, 18 Mar 2020 20:02:34 +0000 Subject: [PATCH] x86/ucode: Move microcode into its own directory Split the existing asm/microcode.h in half, keeping the per-cpu cpu_sig available to external users, and moving everything else into private.h Take the opportunity to trim and clean up the include lists for all 3 source files, all of which include rather more than necessary. No functional change. Signed-off-by: Andrew Cooper Acked-by: Jan Beulich --- xen/arch/x86/Makefile | 3 -- xen/arch/x86/cpu/Makefile | 1 + xen/arch/x86/cpu/microcode/Makefile | 3 ++ .../{microcode_amd.c => cpu/microcode/amd.c} | 12 +++--- .../x86/{microcode.c => cpu/microcode/core.c} | 15 ++------ .../microcode/intel.c} | 9 ++--- xen/arch/x86/cpu/microcode/private.h | 37 +++++++++++++++++++ xen/include/asm-x86/microcode.h | 30 --------------- 8 files changed, 53 insertions(+), 57 deletions(-) create mode 100644 xen/arch/x86/cpu/microcode/Makefile rename xen/arch/x86/{microcode_amd.c => cpu/microcode/amd.c} (99%) rename xen/arch/x86/{microcode.c => cpu/microcode/core.c} (99%) rename xen/arch/x86/{microcode_intel.c => cpu/microcode/intel.c} (98%) create mode 100644 xen/arch/x86/cpu/microcode/private.h diff --git a/xen/arch/x86/Makefile b/xen/arch/x86/Makefile index ed709e2373..e954edbc2e 100644 --- a/xen/arch/x86/Makefile +++ b/xen/arch/x86/Makefile @@ -43,9 +43,6 @@ obj-$(CONFIG_INDIRECT_THUNK) += indirect-thunk.o obj-y += ioport_emulate.o obj-y += irq.o obj-$(CONFIG_KEXEC) += machine_kexec.o -obj-y += microcode_amd.o -obj-y += microcode_intel.o -obj-y += microcode.o obj-y += mm.o x86_64/mm.o obj-$(CONFIG_HVM) += monitor.o obj-y += mpparse.o diff --git a/xen/arch/x86/cpu/Makefile b/xen/arch/x86/cpu/Makefile index de983006a1..35561fe51d 100644 --- a/xen/arch/x86/cpu/Makefile +++ b/xen/arch/x86/cpu/Makefile @@ -1,4 +1,5 @@ obj-y += mcheck/ +obj-y += microcode/ obj-y += mtrr/ obj-y += amd.o diff --git a/xen/arch/x86/cpu/microcode/Makefile b/xen/arch/x86/cpu/microcode/Makefile new file mode 100644 index 0000000000..aae235245b --- /dev/null +++ b/xen/arch/x86/cpu/microcode/Makefile @@ -0,0 +1,3 @@ +obj-y += amd.o +obj-y += core.o +obj-y += intel.o diff --git a/xen/arch/x86/microcode_amd.c b/xen/arch/x86/cpu/microcode/amd.c similarity index 99% rename from xen/arch/x86/microcode_amd.c rename to xen/arch/x86/cpu/microcode/amd.c index bc7459416c..9028889813 100644 --- a/xen/arch/x86/microcode_amd.c +++ b/xen/arch/x86/cpu/microcode/amd.c @@ -16,16 +16,14 @@ #include #include -#include -#include -#include -#include -#include +#include /* TODO: Fix asm/tlbflush.h breakage */ +#include #include #include -#include -#include +#include + +#include "private.h" #define pr_debug(x...) ((void)0) diff --git a/xen/arch/x86/microcode.c b/xen/arch/x86/cpu/microcode/core.c similarity index 99% rename from xen/arch/x86/microcode.c rename to xen/arch/x86/cpu/microcode/core.c index 27a88c6826..ac5da6b2fe 100644 --- a/xen/arch/x86/microcode.c +++ b/xen/arch/x86/cpu/microcode/core.c @@ -22,29 +22,22 @@ */ #include +#include #include +#include #include -#include -#include -#include #include -#include -#include -#include #include #include -#include -#include -#include #include #include #include -#include #include #include #include -#include + +#include "private.h" /* * Before performing a late microcode update on any thread, we diff --git a/xen/arch/x86/microcode_intel.c b/xen/arch/x86/cpu/microcode/intel.c similarity index 98% rename from xen/arch/x86/microcode_intel.c rename to xen/arch/x86/cpu/microcode/intel.c index 91b7d473f7..90fb006c94 100644 --- a/xen/arch/x86/microcode_intel.c +++ b/xen/arch/x86/cpu/microcode/intel.c @@ -23,15 +23,12 @@ #include #include -#include -#include -#include -#include -#include #include #include -#include +#include + +#include "private.h" #define pr_debug(x...) ((void)0) diff --git a/xen/arch/x86/cpu/microcode/private.h b/xen/arch/x86/cpu/microcode/private.h new file mode 100644 index 0000000000..2e3be79eaf --- /dev/null +++ b/xen/arch/x86/cpu/microcode/private.h @@ -0,0 +1,37 @@ +#ifndef ASM_X86_MICROCODE_PRIVATE_H +#define ASM_X86_MICROCODE_PRIVATE_H + +#include + +#include + +enum microcode_match_result { + OLD_UCODE, /* signature matched, but revision id is older or equal */ + NEW_UCODE, /* signature matched, but revision id is newer */ + MIS_UCODE, /* signature mismatched */ +}; + +struct microcode_patch { + union { + struct microcode_intel *mc_intel; + struct microcode_amd *mc_amd; + void *mc; + }; +}; + +struct microcode_ops { + struct microcode_patch *(*cpu_request_microcode)(const void *buf, + size_t size); + int (*collect_cpu_info)(struct cpu_signature *csig); + int (*apply_microcode)(const struct microcode_patch *patch); + int (*start_update)(void); + void (*end_update_percpu)(void); + void (*free_patch)(void *mc); + bool (*match_cpu)(const struct microcode_patch *patch); + enum microcode_match_result (*compare_patch)( + const struct microcode_patch *new, const struct microcode_patch *old); +}; + +extern const struct microcode_ops *microcode_ops; + +#endif /* ASM_X86_MICROCODE_PRIVATE_H */ diff --git a/xen/include/asm-x86/microcode.h b/xen/include/asm-x86/microcode.h index 1a2bbacc6c..9b6ff7db08 100644 --- a/xen/include/asm-x86/microcode.h +++ b/xen/include/asm-x86/microcode.h @@ -3,35 +3,6 @@ #include -enum microcode_match_result { - OLD_UCODE, /* signature matched, but revision id is older or equal */ - NEW_UCODE, /* signature matched, but revision id is newer */ - MIS_UCODE, /* signature mismatched */ -}; - -struct cpu_signature; - -struct microcode_patch { - union { - struct microcode_intel *mc_intel; - struct microcode_amd *mc_amd; - void *mc; - }; -}; - -struct microcode_ops { - struct microcode_patch *(*cpu_request_microcode)(const void *buf, - size_t size); - int (*collect_cpu_info)(struct cpu_signature *csig); - int (*apply_microcode)(const struct microcode_patch *patch); - int (*start_update)(void); - void (*end_update_percpu)(void); - void (*free_patch)(void *mc); - bool (*match_cpu)(const struct microcode_patch *patch); - enum microcode_match_result (*compare_patch)( - const struct microcode_patch *new, const struct microcode_patch *old); -}; - struct cpu_signature { unsigned int sig; unsigned int pf; @@ -39,6 +10,5 @@ struct cpu_signature { }; DECLARE_PER_CPU(struct cpu_signature, cpu_sig); -extern const struct microcode_ops *microcode_ops; #endif /* ASM_X86__MICROCODE_H */ -- 2.30.2