Received: by 2002:a05:7412:f584:b0:e2:908c:2ebd with SMTP id eh4csp2068629rdb; Tue, 5 Sep 2023 13:25:18 -0700 (PDT) X-Google-Smtp-Source: AGHT+IERtpkct4NXAqKWaXgshikZFvSMioX/sjj5zEax82hQuxn99Yl5iw9M8Gj2Nk1Yb/amKcmv X-Received: by 2002:a17:90a:8d10:b0:26d:15dd:6702 with SMTP id c16-20020a17090a8d1000b0026d15dd6702mr11374735pjo.5.1693945518219; Tue, 05 Sep 2023 13:25:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1693945518; cv=none; d=google.com; s=arc-20160816; b=koCC2fG80kANzU/Syo9U18oVPBJ/385fnPDF8cK4HPu7IHOX0mjAWaI3Z2Ak8yt5MB IYxWDUzSGmk0yjMMReByVcXLcNvuuxL1MhRcQPMkgd+T3Mw/A3abRBwRh//U2MzsNhFB zp2BsEbiENrubSwBrOkoOgcwdIrJm3SdujzFd5nEZRiq42444zvl/biEo1TjVqVcuU65 9UpTtXIOTUtg+f0Zklhgvayyo0taZcsHqGN7B1eIqu5t8ACr94V0Iuj8nV45m8zse/z1 exOrR60DYi2TgkLeUWd9oSomeRZV1FbnmWA55FgSVFQ9m6QKxtPIQIJjhOcENM53N8gD zVIA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=3ApSNYHhJpy++9sG1VhdjV9UD1fMFH07firldp4mzuw=; fh=ZwaEcDYNCnlh+U7YxZ1LCEcet9pcdhSkEX0cCEOksvY=; b=HZboxvCBjcvJkVP/Jui/HwvEearYRuWsPvm7kPY4tqCScDYt32KfxucYFy595e5SFa yE8ST/eXMXK5cnxyncr2+xG5nddTYpCWx7F2/SFm9SvB1ac2pNjE7sUgCpp8kw1+8SJq 0cwxMMwCN8s0iy4ZIFUZjGjnruZ6zkIS2Oza0M0FDcz1KmjYFVp5szlqRXJPya7+UsQW jA8irznjYMsnsde3Qn5EkAgD4Wgorwu+G40um1bEzyEpNk/y20yyFN/9wGTKniJHh9Ui 3M4o/BVJ53FyDF5Q0Dpu8mGpjnhNCTp2q8nXe5ukIpLQTviuODKGFM5pezFktMQX5UzC qBXA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=sXCNsgLa; 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=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y5-20020a17090a154500b00263dcd605a9si12030963pja.25.2023.09.05.13.25.02; Tue, 05 Sep 2023 13:25:18 -0700 (PDT) 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=@kernel.org header.s=k20201202 header.b=sXCNsgLa; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345122AbjIEQzv (ORCPT + 99 others); Tue, 5 Sep 2023 12:55:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36974 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351005AbjIEFFT (ORCPT ); Tue, 5 Sep 2023 01:05:19 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87805CCB for ; Mon, 4 Sep 2023 22:05:16 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 4FB09B810B6 for ; Tue, 5 Sep 2023 05:05:15 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 86566C433CD; Tue, 5 Sep 2023 05:05:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1693890315; bh=C+YCkTUh8ihxjpusHHaJLeMc+FVNQx8mBHbTaOEXDhA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=sXCNsgLaM8aEbRc2/Leqy6I2zYjLcCj2ejLoVoGwiBaxGXhTBf3cGZrFO5ScNOkpZ OnLWgGmzV3oYp6eeQyCDR8MCdElW0TzILvE0QLI1mvFBBd7pqN2gdFHaxtqiAPH1k1 vAXwPFjRHiPHRuuiWa/C25FolegpJOOwAqF2u40EnOBQF/U+JJSE+7PD0vQiDFr7RX b56byd6G64V/cWopEugipO6htuyrayTzkiovb/zfgfHyObeZ5xnDOoau7LG+9k1EHt q1S/aZilW6NjlHrOfhmVE/UDZ7QmLQvHpt7K00g87+mFopd8eczlC+plLf+xpQvddw 6YoLlaP30W7kw== From: Josh Poimboeuf To: x86@kernel.org Cc: linux-kernel@vger.kernel.org, Borislav Petkov , Peter Zijlstra , Babu Moger , Paolo Bonzini , Sean Christopherson , David.Kaplan@amd.com, Andrew Cooper , Nikolay Borisov , gregkh@linuxfoundation.org, Thomas Gleixner Subject: [PATCH v3 13/20] x86/srso: Remove 'pred_cmd' label Date: Mon, 4 Sep 2023 22:04:57 -0700 Message-ID: X-Mailer: git-send-email 2.41.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS 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 SBPB is only enabled in two distinct cases: 1) when SRSO has been disabled with srso=off 2) when SRSO has been fixed (in future HW) Simplify the control flow by getting rid of the 'pred_cmd' label and moving the SBPB enablement check to the two corresponding code sites. This makes it more clear when exactly SBPB gets enabled. Signed-off-by: Josh Poimboeuf --- arch/x86/kernel/cpu/bugs.c | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/arch/x86/kernel/cpu/bugs.c b/arch/x86/kernel/cpu/bugs.c index e45dd69aff7f..4f1ad2350f49 100644 --- a/arch/x86/kernel/cpu/bugs.c +++ b/arch/x86/kernel/cpu/bugs.c @@ -2410,13 +2410,21 @@ static void __init srso_select_mitigation(void) { bool has_microcode = boot_cpu_has(X86_FEATURE_IBPB_BRTYPE); - if (!boot_cpu_has_bug(X86_BUG_SRSO) || cpu_mitigations_off()) - goto pred_cmd; + if (cpu_mitigations_off()) + return; + + if (!boot_cpu_has_bug(X86_BUG_SRSO)) { + if (boot_cpu_has(X86_FEATURE_SBPB)) + x86_pred_cmd = PRED_CMD_SBPB; + return; + } if (has_microcode) { /* * Zen1/2 with SMT off aren't vulnerable after the right * IBPB microcode has been applied. + * + * Zen1/2 don't have SBPB, no need to try to enable it here. */ if (boot_cpu_data.x86 < 0x19 && !cpu_smt_possible()) { setup_force_cpu_cap(X86_FEATURE_SRSO_NO); @@ -2439,7 +2447,9 @@ static void __init srso_select_mitigation(void) switch (srso_cmd) { case SRSO_CMD_OFF: - goto pred_cmd; + if (boot_cpu_has(X86_FEATURE_SBPB)) + x86_pred_cmd = PRED_CMD_SBPB; + return; case SRSO_CMD_MICROCODE: if (has_microcode) { @@ -2501,11 +2511,6 @@ static void __init srso_select_mitigation(void) out: pr_info("%s\n", srso_strings[srso_mitigation]); - -pred_cmd: - if ((!boot_cpu_has_bug(X86_BUG_SRSO) || srso_cmd == SRSO_CMD_OFF) && - boot_cpu_has(X86_FEATURE_SBPB)) - x86_pred_cmd = PRED_CMD_SBPB; } #undef pr_fmt -- 2.41.0