From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 4B05FC433F5 for ; Tue, 25 Jan 2022 09:42:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:References:In-Reply-To: Message-Id:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=ho+hUeve2pj9aVA6vyG5fiX2KvoeZET540xrpM4huys=; b=RIaVF0ubrrcJvM wp/HZL5Jnvvz9GBILrBbjTE2jqx31zTSRvuIbCFxfnwh/jYE+letJK9trdJzpa56rYKpJa0QtMYnb S6XCXlSAscR3T+A0cDDMU7R9Jwfn0Z/bANCk8JOiztShc5dX8luwMif7HfnN2KX0Ro5JZZXUbkMDW ZBybNfQYdpULogXa1ak1OondaQl4P0Nm7N/EbdwGfR+4DVOQGQ/iqb4Aio6pcqmH0ge4IE83B1SfY pPpY9IOVFQuF/80rLxSGgKt7qZfaH0XEd4q7yUa6rux4yPFiwa54/ScP+5ytXjiswb2lPUw90i97I P0mCnqLq516vAJhsTyfA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nCIK8-007ECI-MY; Tue, 25 Jan 2022 09:41:14 +0000 Received: from ams.source.kernel.org ([2604:1380:4601:e00::1]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nCHv1-0073QZ-0y for linux-arm-kernel@lists.infradead.org; Tue, 25 Jan 2022 09:15:16 +0000 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 A671FB81732; Tue, 25 Jan 2022 09:15:13 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 558B7C340E8; Tue, 25 Jan 2022 09:15:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1643102112; bh=5CU3hVcUUrrAtI+VHPsC7I+bj7z+ck1jQdWMKOCM39c=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qqHrJfQitoYSRKlT8nlXeH17rYUeXXkdWq4Ri8VY3ZaNIAY4ePROSrlStES1SLQGZ tEUynmT9fJi7+G/YLK3lcqGJayZqHLM09r+rpLa82AOoUQukyZHMtKcv/w+ym0Mmk/ ap3JeISqlWIfuW8UrtPP/Zt3BtZSW/eSIpaj/llbbHyuVq3Ak4j9zKBMTn4PTYWqVJ 9jNbXhq+5eMfccIQ65p063vQuQ5+T3fP6JSdmattMkM4jg88HrWAxyDz4kr4TRNZe4 k6NKsF4AWw7pZ2vJJnzw1koP6ZMPUZlyf1IKyuN/U+l6G6bjHkxIoczNT6TEHrSX6d ugoGlzK59Udcg== From: Ard Biesheuvel To: linux@armlinux.org.uk, linux-arm-kernel@lists.infradead.org Cc: linux-hardening@vger.kernel.org, Ard Biesheuvel , Arnd Bergmann , Kees Cook , Keith Packard , Linus Walleij , Nick Desaulniers , Marc Zyngier Subject: [PATCH v6 4/8] ARM: entry: avoid clobbering R9 in IRQ handler Date: Tue, 25 Jan 2022 10:14:49 +0100 Message-Id: <20220125091453.1475246-5-ardb@kernel.org> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20220125091453.1475246-1-ardb@kernel.org> References: <20220125091453.1475246-1-ardb@kernel.org> MIME-Version: 1.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=1216; h=from:subject; bh=5CU3hVcUUrrAtI+VHPsC7I+bj7z+ck1jQdWMKOCM39c=; b=owEB7QES/pANAwAKAcNPIjmS2Y8kAcsmYgBh77+EKwryGpxQeAF7iDJiZrxU30CtGWxP+u9iQr1c h3df2L6JAbMEAAEKAB0WIQT72WJ8QGnJQhU3VynDTyI5ktmPJAUCYe+/hAAKCRDDTyI5ktmPJGQSC/ 9+EupbXGT4o1empU/QZzrPVb9vEA67V2uYfZoH7YjTAA9JG7ChZVdPgwj/fMpZ9RbfUUx9jpOxrqGn W6oG9OqIeeNq/k1nJwNunEnEFPTHVygkyshpY1ldJrqR4ltHNNjU/nTmYqd5CInm0kPE6ygmhaNOCF TbgmmmR+JyOsznLhPOtyky6+czopVqHkZdCZobvJ9t2NJYvapMP0zATur1DU8aDcslaG7YKQR+WbhQ zorjyFqw2kRrWMD6eW8nKrANyt+VXX9wkGfJq+3JnpdkmAdLvwsycOmGRAJfURsDLuWFDeIn2JCbsG vSf9fFLgiNdr1VLdn4VlsHOt1n8+SkPyuXkv03oBbBSV8afRcxAVKfyIdobukqne2MzQDmfJC1UNxx RzZJmKmdOQTRIZaukyQ5TJCxKIcNQpCcdOxSYnoCXR9QVOiYhaYEpYovJyybhNWzuqtc5lR7QJZGYx hH61cs/7hrV+TgwYTzfzHCELQQq5Rl92/+Y9w5rQ3pFuY= X-Developer-Key: i=ardb@kernel.org; a=openpgp; fpr=F43D03328115A198C90016883D200E9CA6329909 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220125_011515_268265_B9A2A1E9 X-CRM114-Status: GOOD ( 12.32 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Avoid using R9 in the IRQ handler code, as the entry code uses it for tsk, and expects it to remain untouched between the IRQ entry and exit code. Signed-off-by: Ard Biesheuvel --- arch/arm/kernel/entry-armv.S | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/arch/arm/kernel/entry-armv.S b/arch/arm/kernel/entry-armv.S index b58bda51e4b8..038aabb6578f 100644 --- a/arch/arm/kernel/entry-armv.S +++ b/arch/arm/kernel/entry-armv.S @@ -38,11 +38,10 @@ #ifdef CONFIG_UNWINDER_ARM mov fpreg, sp @ Preserve original SP #else - mov r8, fp @ Preserve original FP - mov r9, sp @ Preserve original SP + mov r7, fp @ Preserve original FP + mov r8, sp @ Preserve original SP #endif ldr_this_cpu sp, irq_stack_ptr, r2, r3 - .if \from_user == 0 UNWIND( .setfp fpreg, sp ) @ @@ -82,8 +81,8 @@ UNWIND( .setfp fpreg, sp ) #ifdef CONFIG_UNWINDER_ARM mov sp, fpreg @ Restore original SP #else - mov fp, r8 @ Restore original FP - mov sp, r9 @ Restore original SP + mov fp, r7 @ Restore original FP + mov sp, r8 @ Restore original SP #endif // CONFIG_UNWINDER_ARM #endif // CONFIG_IRQSTACKS .endm -- 2.30.2 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel