x86/speculation/mds: Add SMT warning message

MDS is vulnerable with SMT.  Make that clear with a one-time printk
whenever SMT first gets enabled.

Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Tyler Hicks <tyhicks@canonical.com>
Acked-by: Jiri Kosina <jkosina@suse.cz>
This commit is contained in:
Josh Poimboeuf 2019-04-02 10:00:51 -05:00 committed by Thomas Gleixner
parent 7c3658b201
commit 39226ef02b
1 changed files with 8 additions and 0 deletions

View File

@ -673,6 +673,9 @@ static void update_indir_branch_cond(void)
static_branch_disable(&switch_to_cond_stibp); static_branch_disable(&switch_to_cond_stibp);
} }
#undef pr_fmt
#define pr_fmt(fmt) fmt
/* Update the static key controlling the MDS CPU buffer clear in idle */ /* Update the static key controlling the MDS CPU buffer clear in idle */
static void update_mds_branch_idle(void) static void update_mds_branch_idle(void)
{ {
@ -693,6 +696,8 @@ static void update_mds_branch_idle(void)
static_branch_disable(&mds_idle_clear); static_branch_disable(&mds_idle_clear);
} }
#define MDS_MSG_SMT "MDS CPU bug present and SMT on, data leak possible. See https://www.kernel.org/doc/html/latest/admin-guide/hw-vuln/mds.html for more details.\n"
void arch_smt_update(void) void arch_smt_update(void)
{ {
/* Enhanced IBRS implies STIBP. No update required. */ /* Enhanced IBRS implies STIBP. No update required. */
@ -717,6 +722,8 @@ void arch_smt_update(void)
switch (mds_mitigation) { switch (mds_mitigation) {
case MDS_MITIGATION_FULL: case MDS_MITIGATION_FULL:
case MDS_MITIGATION_VMWERV: case MDS_MITIGATION_VMWERV:
if (sched_smt_active() && !boot_cpu_has(X86_BUG_MSBDS_ONLY))
pr_warn_once(MDS_MSG_SMT);
update_mds_branch_idle(); update_mds_branch_idle();
break; break;
case MDS_MITIGATION_OFF: case MDS_MITIGATION_OFF:
@ -1149,6 +1156,7 @@ static int __init l1tf_cmdline(char *str)
early_param("l1tf", l1tf_cmdline); early_param("l1tf", l1tf_cmdline);
#undef pr_fmt #undef pr_fmt
#define pr_fmt(fmt) fmt
#ifdef CONFIG_SYSFS #ifdef CONFIG_SYSFS