Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1016606imu; Fri, 9 Nov 2018 09:35:02 -0800 (PST) X-Google-Smtp-Source: AJdET5cEen57JvcpOt56TNL4yM2ZtM49y49fLFhlblwd8RXFQQnrt/7T2drxpWbIGtu4jXQFnsPk X-Received: by 2002:a63:441e:: with SMTP id r30mr8399570pga.128.1541784902484; Fri, 09 Nov 2018 09:35:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541784902; cv=none; d=google.com; s=arc-20160816; b=ym+80+V+sYslv37iRfUr2O9zJshZbcJ34mJbUnqmv8eY29CQN6SRHbjHlSDRHjM5B/ tF/5ouRPYC1YcSqmHgDNp+1Bnb96y9X7qMy4RA4Ia0vdTL5qyFyAIXF8zU9dAHEHWw2U X3jFl9FHDLifjmrCdEw5nfHCldTp3StAm9jsg2XSq44xiFaubW7FKKc8z+bupyYXsDR8 iqsj6DbLRhNLbP3PljENPbO1gXJtwv7ggoF2QpJCKoS8D4ZqeTtPlO2LguiWyQPDBEzu D4E4//F/KWM7PRrmG6i3Ilc4aY8p2smtw06nRfPwpx/VqMavqTn1B/WApDoOeqOxK/6l zqLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:cc:to:subject:from:references :in-reply-to:message-id; bh=IUzVT44PA3Z7WmCwzzJ6HheswaTg99SCs7TDOf6Tui0=; b=cFkfQW6DUZBCfRbnD4ZhP9RnOuz+RCbW7UTtZ2XQL1BofdvEu7G3EuHejBXB/XsolP ECvdE0o0pcNAd2KELGb0UtH3YEaQOeqQ2XpIAaWmTof8BYeTzKrV2UvuEm80fVM6GQCq tew+Pl+UfJYCK7juqQazFKYDNWdRqKxM0KU7ly1ylIQpZu2k3TSHC5ECLL4WdBHFzRHK e9RHPyY6RNQ8wWe1p2PaQaAsJO907ZLJYA+J6RiNJqu7GSWFxKu3PflWP16uoveQER1J vc8MRPKwHoYdmxE1/hg5BjXxT63YS1SmMgVFD4UFUfgKQBQHg5REyqXWeVs6v3TMmw5l GPCA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a195-v6si8730352pfa.214.2018.11.09.09.34.37; Fri, 09 Nov 2018 09:35:02 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728833AbeKJDPE (ORCPT + 99 others); Fri, 9 Nov 2018 22:15:04 -0500 Received: from pegase1.c-s.fr ([93.17.236.30]:59526 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727995AbeKJDPD (ORCPT ); Fri, 9 Nov 2018 22:15:03 -0500 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 42s6gk5079z9v0XQ; Fri, 9 Nov 2018 18:33:22 +0100 (CET) X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id uyVpYnVD5Y1y; Fri, 9 Nov 2018 18:33:22 +0100 (CET) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 42s6gk4TLpz9v0XL; Fri, 9 Nov 2018 18:33:22 +0100 (CET) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 6DC6F8B899; Fri, 9 Nov 2018 18:33:28 +0100 (CET) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id L9-Mg3FuEuqH; Fri, 9 Nov 2018 18:33:28 +0100 (CET) Received: from po14163vm.idsi0.si.c-s.fr (po15451.idsi0.si.c-s.fr [172.25.231.2]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 3E0BE8B887; Fri, 9 Nov 2018 18:33:28 +0100 (CET) Received: by po14163vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 2203469A2A; Fri, 9 Nov 2018 17:33:28 +0000 (UTC) Message-Id: In-Reply-To: References: From: Christophe Leroy Subject: [PATCH 7/9] powerpc/signal: Use code patching instead of hardcoding To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Date: Fri, 9 Nov 2018 17:33:28 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Instead of hardcoding code modifications, use code patching functions. Signed-off-by: Christophe Leroy --- arch/powerpc/include/asm/ppc-opcode.h | 1 + arch/powerpc/kernel/signal_32.c | 12 ++++++------ arch/powerpc/kernel/signal_64.c | 7 ++++--- 3 files changed, 11 insertions(+), 9 deletions(-) diff --git a/arch/powerpc/include/asm/ppc-opcode.h b/arch/powerpc/include/asm/ppc-opcode.h index a6e9e314c707..7f693e0f7499 100644 --- a/arch/powerpc/include/asm/ppc-opcode.h +++ b/arch/powerpc/include/asm/ppc-opcode.h @@ -257,6 +257,7 @@ #define PPC_INST_MTSPR_DSCR_USER_MASK 0xfc1ffffe #define PPC_INST_MFVSRD 0x7c000066 #define PPC_INST_MTVSRD 0x7c000166 +#define PPC_INST_SC 0x44000002 #define PPC_INST_SLBFEE 0x7c0007a7 #define PPC_INST_SLBIA 0x7c0003e4 diff --git a/arch/powerpc/kernel/signal_32.c b/arch/powerpc/kernel/signal_32.c index e6474a45cef5..9d39e0eb03ff 100644 --- a/arch/powerpc/kernel/signal_32.c +++ b/arch/powerpc/kernel/signal_32.c @@ -470,9 +470,9 @@ static int save_user_regs(struct pt_regs *regs, struct mcontext __user *frame, return 1; if (sigret) { - /* Set up the sigreturn trampoline: li r0,sigret; sc */ - if (__put_user(0x38000000UL + sigret, &frame->tramp[0]) - || __put_user(0x44000002UL, &frame->tramp[1])) + /* Set up the sigreturn trampoline: li 0,sigret; sc */ + if (__put_user(PPC_INST_ADDI + sigret, &frame->tramp[0]) + || __put_user(PPC_INST_SC, &frame->tramp[1])) return 1; flush_icache_range((unsigned long) &frame->tramp[0], (unsigned long) &frame->tramp[2]); @@ -619,9 +619,9 @@ static int save_tm_user_regs(struct pt_regs *regs, if (__put_user(msr, &frame->mc_gregs[PT_MSR])) return 1; if (sigret) { - /* Set up the sigreturn trampoline: li r0,sigret; sc */ - if (__put_user(0x38000000UL + sigret, &frame->tramp[0]) - || __put_user(0x44000002UL, &frame->tramp[1])) + /* Set up the sigreturn trampoline: li 0,sigret; sc */ + if (__put_user(PPC_INST_ADDI + sigret, &frame->tramp[0]) + || __put_user(PPC_INST_SC, &frame->tramp[1])) return 1; flush_icache_range((unsigned long) &frame->tramp[0], (unsigned long) &frame->tramp[2]); diff --git a/arch/powerpc/kernel/signal_64.c b/arch/powerpc/kernel/signal_64.c index 83d51bf586c7..e53ad11be385 100644 --- a/arch/powerpc/kernel/signal_64.c +++ b/arch/powerpc/kernel/signal_64.c @@ -598,11 +598,12 @@ static long setup_trampoline(unsigned int syscall, unsigned int __user *tramp) long err = 0; /* addi r1, r1, __SIGNAL_FRAMESIZE # Pop the dummy stackframe */ - err |= __put_user(0x38210000UL | (__SIGNAL_FRAMESIZE & 0xffff), &tramp[0]); + err |= __put_user(PPC_INST_ADDI | __PPC_RT(R1) | __PPC_RA(R1) | + (__SIGNAL_FRAMESIZE & 0xffff), &tramp[0]); /* li r0, __NR_[rt_]sigreturn| */ - err |= __put_user(0x38000000UL | (syscall & 0xffff), &tramp[1]); + err |= __put_user(PPC_INST_ADDI | (syscall & 0xffff), &tramp[1]); /* sc */ - err |= __put_user(0x44000002UL, &tramp[2]); + err |= __put_user(PPC_INST_SC, &tramp[2]); /* Minimal traceback info */ for (i=TRAMP_TRACEBACK; i < TRAMP_SIZE ;i++) -- 2.13.3