Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp4550548ioo; Tue, 31 May 2022 06:56:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyJqDMY6Yn8EZOJ6B0KskAnT/8UCUDN4pv/15SgsObj75eTVUXj/nnRXR34gDAAGRdJ4Xu4 X-Received: by 2002:a05:6402:510b:b0:42d:d18d:2080 with SMTP id m11-20020a056402510b00b0042dd18d2080mr11125390edd.263.1654005404591; Tue, 31 May 2022 06:56:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654005404; cv=none; d=google.com; s=arc-20160816; b=sMJaaVAHgFUx/TrGaF2TL0u9X5NwII+1R42aBo36G3g712KZa9w5UCP+lFjV9eQvig xwGNRTBPMr2KpBgN9CSIKrZIN9bh6HG3Ht8i78tKcuhmgfxybV9SrxPgRmgZjY2Dz38Q OEEaE4jrVX2fn4u2Q2MGG/bTZKpP6nrU4B3eZQi2R6MyHuOqqnc4b4KHl7U5mnarsx3K 5KOhCvC+7LO8BzdtyeVtByUJRhqMAxO2TgW1QvSQTKjvw1Onto5HnYt1Qa8O4YA2Nije dCeitF86fUsiOXPkAVvTkrPR52znQYAGB6bNGGoWjMtgSZVy5qGD5+q+/Cf26RX2/tQq 8HhQ== 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=S6qOoeFjEfwsrzcTRJRWaVpAJr8EdpyJo6DfKS9aLYs=; b=aLhqw0EOPTadefUZO9JW3oE6sfs6hmeRuley37IafLz+zh8SEHSdTnD4HKLjF/6DRq XaiOGFobX3k6O3HYO0BKcJuDll2BB37ROpNgJ+mKVsSYKI9cyDM3sLQzbhnlVVTxEmix BJBF9Srzw3PUMXRPcJaBWRpiI6+wrAtk4QraTnqXjPkyqb8SmXCioICz1cyAVOA3b551 o2EvxEo1HaBmU2PKZCO1WKJq9PjUNKyCGFB+AVYQ3tmuYXWk/7zZlf6cU239b1q99Pfv HbjiEoB+FjCD5O3C98hCyAd/YwcOKSyxp90iEE2uiNhaGMve6s1CdCUb4/zKbJABNYgS 9nnQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eciy1RJI; 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 hg7-20020a1709072cc700b006ff59255783si8258644ejc.874.2022.05.31.06.56.16; Tue, 31 May 2022 06:56:44 -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=eciy1RJI; 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 S242794AbiE3Ohv (ORCPT + 99 others); Mon, 30 May 2022 10:37:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40158 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239573AbiE3OSu (ORCPT ); Mon, 30 May 2022 10:18:50 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4D6C8122B4C; Mon, 30 May 2022 06:49:54 -0700 (PDT) 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 dfw.source.kernel.org (Postfix) with ESMTPS id BC90660FD6; Mon, 30 May 2022 13:49:13 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D4428C3411E; Mon, 30 May 2022 13:49:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1653918553; bh=AF0zBlv4K65o/Q7PnxvPyyw9KqF09vTd9402ZLCM7ks=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eciy1RJIoi8Rzhj1pFLNm3sScKuYWf4qm0XfD4rrJBlkMYfbNFgKZbI//OagzcN8q p56sWESviAHhfDJRrBoZNCzNd31sI201Yz4vQBtXaVMN5muK647S04X4uxIskkZ3vn JOxkK/ApvLPDiOCPWmpClm+hX4xHxIY/lWTU85wej436EEhomGFK7FVRBbWhiYfkWE 8Fi421BZ2RghG83qvMdUVzF/MZ+Pk64JIJH1rGhsEUHaNdBJACQy68TPhchngZ7E07 qPQAncJXt6K4skfCZmxr2cwWdXinBerSFXb1AifKKUmMLbSgiZszmXQcxdDJZEGGca XRO0Vds3PdiIg== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Ard Biesheuvel , Russell King , Sasha Levin , linux@armlinux.org.uk, linus.walleij@linaro.org, nico@fluxnic.net, keithpac@amazon.com, arnd@arndb.de, linux-arm-kernel@lists.infradead.org Subject: [PATCH AUTOSEL 5.4 51/55] ARM: 9201/1: spectre-bhb: rely on linker to emit cross-section literal loads Date: Mon, 30 May 2022 09:46:57 -0400 Message-Id: <20220530134701.1935933-51-sashal@kernel.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220530134701.1935933-1-sashal@kernel.org> References: <20220530134701.1935933-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 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: Ard Biesheuvel [ Upstream commit ad12c2f1587c6ec9b52ff226f438955bfae6ad89 ] The assembler does not permit 'LDR PC, ' when the symbol lives in a different section, which is why we have been relying on rather fragile open-coded arithmetic to load the address of the vector_swi routine into the program counter using a single LDR instruction in the SWI slot in the vector table. The literal was moved to a different section to in commit 19accfd373847 ("ARM: move vector stubs") to ensure that the vector stubs page does not need to be mapped readable for user space, which is the case for the vector page itself, as it carries the kuser helpers as well. So the cross-section literal load is open-coded, and this relies on the address of vector_swi to be at the very start of the vector stubs page, and we won't notice if we got it wrong until booting the kernel and see it break. Fortunately, it was guaranteed to break, so this was fragile but not problematic. Now that we have added two other variants of the vector table, we have 3 occurrences of the same trick, and so the size of our ISA/compiler/CPU validation space has tripled, in a way that may cause regressions to only be observed once booting the image in question on a CPU that exercises a particular vector table. So let's switch to true cross section references, and let the linker fix them up like it fixes up all the other cross section references in the vector page. Signed-off-by: Ard Biesheuvel Signed-off-by: Russell King (Oracle) Signed-off-by: Sasha Levin --- arch/arm/kernel/entry-armv.S | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/arch/arm/kernel/entry-armv.S b/arch/arm/kernel/entry-armv.S index 8e8efe28d799..4d900c61a0f7 100644 --- a/arch/arm/kernel/entry-armv.S +++ b/arch/arm/kernel/entry-armv.S @@ -1074,10 +1074,15 @@ ENDPROC(vector_bhb_bpiall_\name) .endm .section .stubs, "ax", %progbits - @ This must be the first word + @ These need to remain at the start of the section so that + @ they are in range of the 'SWI' entries in the vector tables + @ located 4k down. +.L__vector_swi: .word vector_swi #ifdef CONFIG_HARDEN_BRANCH_HISTORY +.L__vector_bhb_loop8_swi: .word vector_bhb_loop8_swi +.L__vector_bhb_bpiall_swi: .word vector_bhb_bpiall_swi #endif @@ -1220,10 +1225,11 @@ vector_addrexcptn: .globl vector_fiq .section .vectors, "ax", %progbits -.L__vectors_start: W(b) vector_rst W(b) vector_und - W(ldr) pc, .L__vectors_start + 0x1000 +ARM( .reloc ., R_ARM_LDR_PC_G0, .L__vector_swi ) +THUMB( .reloc ., R_ARM_THM_PC12, .L__vector_swi ) + W(ldr) pc, . W(b) vector_pabt W(b) vector_dabt W(b) vector_addrexcptn @@ -1232,10 +1238,11 @@ vector_addrexcptn: #ifdef CONFIG_HARDEN_BRANCH_HISTORY .section .vectors.bhb.loop8, "ax", %progbits -.L__vectors_bhb_loop8_start: W(b) vector_rst W(b) vector_bhb_loop8_und - W(ldr) pc, .L__vectors_bhb_loop8_start + 0x1004 +ARM( .reloc ., R_ARM_LDR_PC_G0, .L__vector_bhb_loop8_swi ) +THUMB( .reloc ., R_ARM_THM_PC12, .L__vector_bhb_loop8_swi ) + W(ldr) pc, . W(b) vector_bhb_loop8_pabt W(b) vector_bhb_loop8_dabt W(b) vector_addrexcptn @@ -1243,10 +1250,11 @@ vector_addrexcptn: W(b) vector_bhb_loop8_fiq .section .vectors.bhb.bpiall, "ax", %progbits -.L__vectors_bhb_bpiall_start: W(b) vector_rst W(b) vector_bhb_bpiall_und - W(ldr) pc, .L__vectors_bhb_bpiall_start + 0x1008 +ARM( .reloc ., R_ARM_LDR_PC_G0, .L__vector_bhb_bpiall_swi ) +THUMB( .reloc ., R_ARM_THM_PC12, .L__vector_bhb_bpiall_swi ) + W(ldr) pc, . W(b) vector_bhb_bpiall_pabt W(b) vector_bhb_bpiall_dabt W(b) vector_addrexcptn -- 2.35.1