Commit 950d0055 authored by Michael Roth's avatar Michael Roth Committed by Borislav Petkov

x86/boot: Use MSR read/write helpers instead of inline assembly

Update all C code to use the new boot_rdmsr()/boot_wrmsr() helpers
instead of relying on inline assembly.
Suggested-by: default avatarBorislav Petkov <bp@alien8.de>
Signed-off-by: default avatarMichael Roth <michael.roth@amd.com>
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
Link: https://lore.kernel.org/r/20220307213356.2797205-7-brijesh.singh@amd.com
parent 176db622
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#include <asm/svm.h> #include <asm/svm.h>
#include "error.h" #include "error.h"
#include "../msr.h"
struct ghcb boot_ghcb_page __aligned(PAGE_SIZE); struct ghcb boot_ghcb_page __aligned(PAGE_SIZE);
struct ghcb *boot_ghcb; struct ghcb *boot_ghcb;
...@@ -56,23 +57,19 @@ static unsigned long insn_get_seg_base(struct pt_regs *regs, int seg_reg_idx) ...@@ -56,23 +57,19 @@ static unsigned long insn_get_seg_base(struct pt_regs *regs, int seg_reg_idx)
static inline u64 sev_es_rd_ghcb_msr(void) static inline u64 sev_es_rd_ghcb_msr(void)
{ {
unsigned long low, high; struct msr m;
asm volatile("rdmsr" : "=a" (low), "=d" (high) : boot_rdmsr(MSR_AMD64_SEV_ES_GHCB, &m);
"c" (MSR_AMD64_SEV_ES_GHCB));
return ((high << 32) | low); return m.q;
} }
static inline void sev_es_wr_ghcb_msr(u64 val) static inline void sev_es_wr_ghcb_msr(u64 val)
{ {
u32 low, high; struct msr m;
low = val & 0xffffffffUL; m.q = val;
high = val >> 32; boot_wrmsr(MSR_AMD64_SEV_ES_GHCB, &m);
asm volatile("wrmsr" : : "c" (MSR_AMD64_SEV_ES_GHCB),
"a"(low), "d" (high) : "memory");
} }
static enum es_result vc_decode_insn(struct es_em_ctxt *ctxt) static enum es_result vc_decode_insn(struct es_em_ctxt *ctxt)
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
#include <asm/required-features.h> #include <asm/required-features.h>
#include <asm/msr-index.h> #include <asm/msr-index.h>
#include "string.h" #include "string.h"
#include "msr.h"
static u32 err_flags[NCAPINTS]; static u32 err_flags[NCAPINTS];
...@@ -130,12 +131,11 @@ int check_cpu(int *cpu_level_ptr, int *req_level_ptr, u32 **err_flags_ptr) ...@@ -130,12 +131,11 @@ int check_cpu(int *cpu_level_ptr, int *req_level_ptr, u32 **err_flags_ptr)
/* If this is an AMD and we're only missing SSE+SSE2, try to /* If this is an AMD and we're only missing SSE+SSE2, try to
turn them on */ turn them on */
u32 ecx = MSR_K7_HWCR; struct msr m;
u32 eax, edx;
asm("rdmsr" : "=a" (eax), "=d" (edx) : "c" (ecx)); boot_rdmsr(MSR_K7_HWCR, &m);
eax &= ~(1 << 15); m.l &= ~(1 << 15);
asm("wrmsr" : : "a" (eax), "d" (edx), "c" (ecx)); boot_wrmsr(MSR_K7_HWCR, &m);
get_cpuflags(); /* Make sure it really did something */ get_cpuflags(); /* Make sure it really did something */
err = check_cpuflags(); err = check_cpuflags();
...@@ -145,28 +145,28 @@ int check_cpu(int *cpu_level_ptr, int *req_level_ptr, u32 **err_flags_ptr) ...@@ -145,28 +145,28 @@ int check_cpu(int *cpu_level_ptr, int *req_level_ptr, u32 **err_flags_ptr)
/* If this is a VIA C3, we might have to enable CX8 /* If this is a VIA C3, we might have to enable CX8
explicitly */ explicitly */
u32 ecx = MSR_VIA_FCR; struct msr m;
u32 eax, edx;
asm("rdmsr" : "=a" (eax), "=d" (edx) : "c" (ecx)); boot_rdmsr(MSR_VIA_FCR, &m);
eax |= (1<<1)|(1<<7); m.l |= (1 << 1) | (1 << 7);
asm("wrmsr" : : "a" (eax), "d" (edx), "c" (ecx)); boot_wrmsr(MSR_VIA_FCR, &m);
set_bit(X86_FEATURE_CX8, cpu.flags); set_bit(X86_FEATURE_CX8, cpu.flags);
err = check_cpuflags(); err = check_cpuflags();
} else if (err == 0x01 && is_transmeta()) { } else if (err == 0x01 && is_transmeta()) {
/* Transmeta might have masked feature bits in word 0 */ /* Transmeta might have masked feature bits in word 0 */
u32 ecx = 0x80860004; struct msr m, m_tmp;
u32 eax, edx;
u32 level = 1; u32 level = 1;
asm("rdmsr" : "=a" (eax), "=d" (edx) : "c" (ecx)); boot_rdmsr(0x80860004, &m);
asm("wrmsr" : : "a" (~0), "d" (edx), "c" (ecx)); m_tmp = m;
m_tmp.l = ~0;
boot_wrmsr(0x80860004, &m_tmp);
asm("cpuid" asm("cpuid"
: "+a" (level), "=d" (cpu.flags[0]) : "+a" (level), "=d" (cpu.flags[0])
: : "ecx", "ebx"); : : "ecx", "ebx");
asm("wrmsr" : : "a" (eax), "d" (edx), "c" (ecx)); boot_wrmsr(0x80860004, &m);
err = check_cpuflags(); err = check_cpuflags();
} else if (err == 0x01 && } else if (err == 0x01 &&
......
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