Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp2098484pxp; Thu, 10 Mar 2022 19:58:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJxAwvCzMD8OPJTgRT7D3j9BDY5jLBvjqBe4aIxU3+d2VGbykiDYzwLg3aC3IijrpVLDnQrG X-Received: by 2002:a17:907:1c0e:b0:6db:41b2:8d98 with SMTP id nc14-20020a1709071c0e00b006db41b28d98mr6892557ejc.102.1646971129842; Thu, 10 Mar 2022 19:58:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646971129; cv=none; d=google.com; s=arc-20160816; b=SYtdMGXa+m8Zc50hw++s/INCOUw7R6Jy/EgGbTQ9nEZ4R41ol8uXF7dKUSsPf5S9Fn 8+kPhC1Wp7YXkj8GP39YWjYgkIGqIKaI+eLh6yZ5OaWQcZule++mO0E0dhRrYWzs7JH/ zM7fsccg6vxDCSwBzbKalSi5CfNUC3AZDG9esNRnHLTUQ1jXmm2AP8OFQvNM7mdg+YDn 5M7gIZepA8MJeFbJ8FuvWvEpJZqFmobVq2cQi1T+icR4ZsowK3mDYrLaCw8Gu5Ipv9fZ ESVSncJWOAD3ekjpVftIwsp7+sJM5UPVxjW8Xc5xnrvwxj06lNi1Z+h38qeSQyK2+oL0 vzEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WDjn2ANCbKXJC/IbPow3jEckMV0FHMm/T4wFWK2kk1U=; b=qv/uCycAzN97PDcDnZOjE2CNqEzpqmXCbvg5APwcL0oVCUeAOKOuuPHwj5kyb/Ur1S sWHicMdcugAZR/JScTbThYhILM6HAmf67rikHWnwNrNdxAr8CeC2ef0gVB8esPUBMds1 XbGcDqJ1dZGfeSoroqdsMp5IgDNERk8ZMEjo/nxIG4NeJlby3oeL+4w1S91zky6d0b9A sqnuWTpyVwtdaPDkxSvBcoEzLnILxvOq+F5+M1RbjbkD9d05TQhEnQckIt9xCYS/GU7H 3A8F3I1tSXNKiJHKmoVtIcv7c8Y0Ams++MGN9KikNRPIPRYKxgoOjBcg+mf+vptvjv5r eOSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="DKLabPk/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 5-20020a508e45000000b0040f5ee891c3si5478070edx.36.2022.03.10.19.58.28; Thu, 10 Mar 2022 19:58:49 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="DKLabPk/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243241AbiCJORV (ORCPT + 99 others); Thu, 10 Mar 2022 09:17:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43298 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240035AbiCJORM (ORCPT ); Thu, 10 Mar 2022 09:17:12 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 832B1C24AC; Thu, 10 Mar 2022 06:13:04 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id A32F9B81E9E; Thu, 10 Mar 2022 14:13:01 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id F0EDAC340E8; Thu, 10 Mar 2022 14:12:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1646921580; bh=2izHBbKePMU2Fb3LPgpGusKesTpyD1FWIKNwtBsOrao=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DKLabPk/FvS4kbH0YPVLZRZOtdp1WV62NqFFCDAHIXuGWtUcxxStqcrHh+LNf55wL gdP5OR6QIcSjvxer1/na0Ixuvu/XHp/zCs3VkoVza32ed44RIuraZqyovcqrPW9Iwq xJtyS14wOeD4GmhGp3+Ru4X4r6f+BLkrwPfdrhWU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Josh Poimboeuf , Borislav Petkov Subject: [PATCH 5.16 07/53] x86/speculation: Warn about Spectre v2 LFENCE mitigation Date: Thu, 10 Mar 2022 15:09:12 +0100 Message-Id: <20220310140812.046666764@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220310140811.832630727@linuxfoundation.org> References: <20220310140811.832630727@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.6 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Josh Poimboeuf commit eafd987d4a82c7bb5aa12f0e3b4f8f3dea93e678 upstream. With: f8a66d608a3e ("x86,bugs: Unconditionally allow spectre_v2=retpoline,amd") it became possible to enable the LFENCE "retpoline" on Intel. However, Intel doesn't recommend it, as it has some weaknesses compared to retpoline. Now AMD doesn't recommend it either. It can still be left available as a cmdline option. It's faster than retpoline but is weaker in certain scenarios -- particularly SMT, but even non-SMT may be vulnerable in some cases. So just unconditionally warn if the user requests it on the cmdline. [ bp: Massage commit message. ] Signed-off-by: Josh Poimboeuf Signed-off-by: Borislav Petkov Signed-off-by: Greg Kroah-Hartman --- arch/x86/kernel/cpu/bugs.c | 5 +++++ 1 file changed, 5 insertions(+) --- a/arch/x86/kernel/cpu/bugs.c +++ b/arch/x86/kernel/cpu/bugs.c @@ -651,6 +651,7 @@ static inline const char *spectre_v2_mod static inline const char *spectre_v2_module_string(void) { return ""; } #endif +#define SPECTRE_V2_LFENCE_MSG "WARNING: LFENCE mitigation is not recommended for this CPU, data leaks possible!\n" #define SPECTRE_V2_EIBRS_EBPF_MSG "WARNING: Unprivileged eBPF is enabled with eIBRS on, data leaks possible via Spectre v2 BHB attacks!\n" #ifdef CONFIG_BPF_SYSCALL @@ -972,6 +973,7 @@ static void __init spectre_v2_select_mit break; case SPECTRE_V2_CMD_RETPOLINE_LFENCE: + pr_err(SPECTRE_V2_LFENCE_MSG); mode = SPECTRE_V2_LFENCE; break; @@ -1787,6 +1789,9 @@ static char *ibpb_state(void) static ssize_t spectre_v2_show_state(char *buf) { + if (spectre_v2_enabled == SPECTRE_V2_LFENCE) + return sprintf(buf, "Vulnerable: LFENCE\n"); + if (spectre_v2_enabled == SPECTRE_V2_EIBRS && unprivileged_ebpf_enabled()) return sprintf(buf, "Vulnerable: Unprivileged eBPF enabled\n");