D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
lib
/
modules
/
4.4.0-1128-aws
/
build
/
arch
/
x86
/
include
/
asm
/
Filename :
spec_ctrl.h
back
Copy
#ifndef _ASM_X86_SPEC_CTRL_H #define _ASM_X86_SPEC_CTRL_H #include <linux/stringify.h> #include <asm/msr-index.h> #include <asm/cpufeatures.h> #include <asm/alternative-asm.h> #ifdef __ASSEMBLY__ .extern ibrs_enabled .extern x86_spec_ctrl_base #define _SPEC_CTRL_IBRS (1 << SPEC_CTRL_IBRS_SHIFT) #define __ASM_ENABLE_IBRS \ pushq %rax; \ pushq %rcx; \ pushq %rdx; \ movl $MSR_IA32_SPEC_CTRL, %ecx; \ movq x86_spec_ctrl_base, %rdx; \ shr $32, %rdx; \ movq x86_spec_ctrl_base, %rax; \ orl $_SPEC_CTRL_IBRS, %eax; \ wrmsr; \ popq %rdx; \ popq %rcx; \ popq %rax #define __ASM_ENABLE_IBRS_CLOBBER \ movl $MSR_IA32_SPEC_CTRL, %ecx; \ movq x86_spec_ctrl_base, %rdx; \ shr $32, %rdx; \ movq x86_spec_ctrl_base, %rax; \ orl $_SPEC_CTRL_IBRS, %eax; \ wrmsr; #define __ASM_DISABLE_IBRS \ pushq %rax; \ pushq %rcx; \ pushq %rdx; \ movl $MSR_IA32_SPEC_CTRL, %ecx; \ movq x86_spec_ctrl_base, %rdx; \ shr $32, %rdx; \ movq x86_spec_ctrl_base, %rax; \ wrmsr; \ popq %rdx; \ popq %rcx; \ popq %rax .macro ENABLE_IBRS testl $1, ibrs_enabled jz 10f __ASM_ENABLE_IBRS jmp 20f 10: lfence 20: .endm .macro ENABLE_IBRS_CLOBBER testl $1, ibrs_enabled jz 11f __ASM_ENABLE_IBRS_CLOBBER jmp 21f 11: lfence 21: .endm .macro DISABLE_IBRS testl $1, ibrs_enabled jz 9f __ASM_DISABLE_IBRS 9: .endm #endif /* __ASSEMBLY__ */ #endif /* _ASM_X86_SPEC_CTRL_H */