|
@@ -284,8 +284,13 @@ static __always_inline void setup_smap(struct cpuinfo_x86 *c)
|
|
raw_local_save_flags(eflags);
|
|
raw_local_save_flags(eflags);
|
|
BUG_ON(eflags & X86_EFLAGS_AC);
|
|
BUG_ON(eflags & X86_EFLAGS_AC);
|
|
|
|
|
|
- if (cpu_has(c, X86_FEATURE_SMAP))
|
|
|
|
|
|
+ if (cpu_has(c, X86_FEATURE_SMAP)) {
|
|
|
|
+#ifdef CONFIG_X86_SMAP
|
|
set_in_cr4(X86_CR4_SMAP);
|
|
set_in_cr4(X86_CR4_SMAP);
|
|
|
|
+#else
|
|
|
|
+ clear_in_cr4(X86_CR4_SMAP);
|
|
|
|
+#endif
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
/*
|