/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _ASM_X86_SHARED_MSR_H #define _ASM_X86_SHARED_MSR_H struct msr { union { struct { u32 l; u32 h; }; u64 q; }; }; /* * The kernel proper already defines rdmsr()/wrmsr(), but they are not for the * boot kernel since they rely on tracepoint/exception handling infrastructure * that's not available here. */ static inline void raw_rdmsr(unsigned int reg, struct msr *m) { asm volatile("rdmsr" : "=a" (m->l), "=d" (m->h) : "c" (reg)); } static inline void raw_wrmsr(unsigned int reg, const struct msr *m) { asm volatile("wrmsr" : : "c" (reg), "a"(m->l), "d" (m->h) : "memory"); } #endif /* _ASM_X86_SHARED_MSR_H */