Commit 96b0ee45 authored by Borislav Petkov's avatar Borislav Petkov Committed by Borislav Petkov

x86, microcode, AMD: Add a reusable buffer

Add a simple 4K page which gets allocated on driver init and freed on
driver exit instead of vmalloc'ing small buffers for each ucode patch.
Signed-off-by: default avatarBorislav Petkov <borislav.petkov@amd.com>
parent f72c1a57
...@@ -71,6 +71,9 @@ struct microcode_amd { ...@@ -71,6 +71,9 @@ struct microcode_amd {
static struct equiv_cpu_entry *equiv_cpu_table; static struct equiv_cpu_entry *equiv_cpu_table;
/* page-sized ucode patch buffer */
void *patch;
static int collect_cpu_info_amd(int cpu, struct cpu_signature *csig) static int collect_cpu_info_amd(int cpu, struct cpu_signature *csig)
{ {
struct cpuinfo_x86 *c = &cpu_data(cpu); struct cpuinfo_x86 *c = &cpu_data(cpu);
...@@ -351,9 +354,14 @@ static struct microcode_ops microcode_amd_ops = { ...@@ -351,9 +354,14 @@ static struct microcode_ops microcode_amd_ops = {
struct microcode_ops * __init init_amd_microcode(void) struct microcode_ops * __init init_amd_microcode(void)
{ {
patch = (void *)get_zeroed_page(GFP_KERNEL);
if (!patch)
return NULL;
return &microcode_amd_ops; return &microcode_amd_ops;
} }
void __exit exit_amd_microcode(void) void __exit exit_amd_microcode(void)
{ {
free_page((unsigned long)patch);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment