Commit c873f201 authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Stefan Bader

x86/speculation: Rework speculative_store_bypass_update()

The upcoming support for the virtual SPEC_CTRL MSR on AMD needs to reuse
speculative_store_bypass_update() to avoid code duplication. Add an
argument for supplying a thread info (TIF) value and create a wrapper
speculative_store_bypass_update_current() which is used at the existing
call site.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Reviewed-by: default avatarBorislav Petkov <bp@suse.de>
Reviewed-by: default avatarKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>

CVE-2018-3639 (x86)

(cherry-picked from commit 0270be3e)
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent 5af2ce80
...@@ -42,6 +42,11 @@ extern void speculative_store_bypass_ht_init(void); ...@@ -42,6 +42,11 @@ extern void speculative_store_bypass_ht_init(void);
static inline void speculative_store_bypass_ht_init(void) { } static inline void speculative_store_bypass_ht_init(void) { }
#endif #endif
extern void speculative_store_bypass_update(void); extern void speculative_store_bypass_update(unsigned long tif);
static inline void speculative_store_bypass_update_current(void)
{
speculative_store_bypass_update(current_thread_info()->flags);
}
#endif #endif
...@@ -623,7 +623,7 @@ static int ssb_prctl_set(struct task_struct *task, unsigned long ctrl) ...@@ -623,7 +623,7 @@ static int ssb_prctl_set(struct task_struct *task, unsigned long ctrl)
* mitigation until it is next scheduled. * mitigation until it is next scheduled.
*/ */
if (task == current && update) if (task == current && update)
speculative_store_bypass_update(); speculative_store_bypass_update_current();
return 0; return 0;
} }
......
...@@ -345,10 +345,10 @@ static __always_inline void __speculative_store_bypass_update(unsigned long tifn ...@@ -345,10 +345,10 @@ static __always_inline void __speculative_store_bypass_update(unsigned long tifn
intel_set_ssb_state(tifn); intel_set_ssb_state(tifn);
} }
void speculative_store_bypass_update(void) void speculative_store_bypass_update(unsigned long tif)
{ {
preempt_disable(); preempt_disable();
__speculative_store_bypass_update(current_thread_info()->flags); __speculative_store_bypass_update(tif);
preempt_enable(); preempt_enable();
} }
......
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