Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp7418665yba; Thu, 2 May 2019 09:29:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqyG4L/v0x+TfsicH8greRH2jT0g5VccrZCsur5bgIjQ84BWTyVDSUwnksQHyD+VA7TPZjjv X-Received: by 2002:a63:6941:: with SMTP id e62mr4466124pgc.99.1556814567344; Thu, 02 May 2019 09:29:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556814567; cv=none; d=google.com; s=arc-20160816; b=jlftQ7uJdT6M9iAN1Rc0zYjITFFp4gmIwS6OZ0Y+kjP/1axplqQhEp3+93d+1un6R+ Ph/FYnM8giHvORlMBwATMS95wUEROwG/Oc6+tVfc6ch3acHPAtb6R7Y1aJCIgZ21BokJ HIfwjQ+AVpU2ETYwDBQcwoutm6NG0uJIGGi6mbH4BG1WRqoYluNyxgmdwhTqBzZD2B0F q9KhLlFgIfpJcTPK4PoMjEVWotnSSdsgBnGIt3ura7K8CSOIVqwaD00AGohvCIiQutI9 E/A1A3c0ZZNOk/+Z7lCUDo6X/QBCFY3b/0XvKMrOjdFD9341w1c4oM0DAmVu+0ArQE6m F9Tw== 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:dkim-signature; bh=WYN0o2e28rw4KS1Iqn2OUuOv3s2mGJlGe3yXVUGCAYs=; b=CHGdPx33Gu+6v8BvYTTvu/yG3jZddOgiDDZMExpsD3PPt87Jszy42l3Obzsa2qG6KF gLI4FFmWVxDNVLvgSHlH2MiicthTTgoGf2V2B3ZoM0Il19gw0iYsxyg7fQNZkSqMXrmH Ff2oFQSkPIp+GJvpPkxJzXIXw8BnW1ppcPBnmu19cZ2PEmDte14ZVEaWv9plfDPZYCcu 2umvGVe+TRkR1g99cyn9bDf+7PBFZdKMj/mz7wlq2gVww+WHdFfwSuEo+ERcxfB41e4R 6bp+TgWb7wDx+GyXiwWc+djyMBiHpGNY8hEAdFS40+uWl+FWhXkZNTfObIT3DC6JsHi+ psNg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=UNio1EoX; 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 e13si41649578pgs.341.2019.05.02.09.29.12; Thu, 02 May 2019 09:29:27 -0700 (PDT) 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; dkim=pass header.i=@c-s.fr header.s=mail header.b=UNio1EoX; 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 S1726674AbfEBQ1j (ORCPT + 99 others); Thu, 2 May 2019 12:27:39 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:63296 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726283AbfEBQ1e (ORCPT ); Thu, 2 May 2019 12:27:34 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 44w0zR01Ptz9tycn; Thu, 2 May 2019 18:27:31 +0200 (CEST) Authentication-Results: localhost; dkim=pass reason="1024-bit key; insecure key" header.d=c-s.fr header.i=@c-s.fr header.b=UNio1EoX; dkim-adsp=pass; dkim-atps=neutral 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 pz2HD9vn8F2E; Thu, 2 May 2019 18:27:30 +0200 (CEST) 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 44w0zQ4pdVz9tyck; Thu, 2 May 2019 18:27:30 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=c-s.fr; s=mail; t=1556814450; bh=WYN0o2e28rw4KS1Iqn2OUuOv3s2mGJlGe3yXVUGCAYs=; h=In-Reply-To:References:From:Subject:To:Cc:Date:From; b=UNio1EoXzFxZZvYUAwASfmM863neBDqPX5DnKe8QNTlsJmM1GkOoCoxvYL+AmqsqA l72Sha1+Mgy72Br5yul/o+0V1GSdRMTgi7E5VbTwCY9UoB+WWpr8G7nLle2EPGJA24 HQ6oce/7tNDobzgrPc9KyoWcaKFQISP7EV08hilk= Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 56D1D8B8FE; Thu, 2 May 2019 18:27:32 +0200 (CEST) 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 cRhWZjiNrc6s; Thu, 2 May 2019 18:27:32 +0200 (CEST) Received: from po16846vm.idsi0.si.c-s.fr (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 1BC1B8B899; Thu, 2 May 2019 18:27:32 +0200 (CEST) Received: by po16846vm.idsi0.si.c-s.fr (Postfix, from userid 0) id E46FA672AF; Thu, 2 May 2019 16:27:31 +0000 (UTC) Message-Id: <238e7fa33c16b5d1ad946cde5c063890eaed860a.1556814003.git.christophe.leroy@c-s.fr> In-Reply-To: <298f344bdb21ab566271f5d18c6782ed20f072b7.1556814003.git.christophe.leroy@c-s.fr> References: <298f344bdb21ab566271f5d18c6782ed20f072b7.1556814003.git.christophe.leroy@c-s.fr> From: Christophe Leroy Subject: [PATCH v2 3/3] powerpc/module64: Use symbolic instructions names. To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Date: Thu, 2 May 2019 16:27:31 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To increase readability/maintainability, replace hard coded instructions values by symbolic names. Signed-off-by: Christophe Leroy --- v2: rearranged comments ; fixed warning by adding () in an 'if' around X | Y arch/powerpc/kernel/module_64.c | 53 +++++++++++++++++++++++++++-------------- 1 file changed, 35 insertions(+), 18 deletions(-) diff --git a/arch/powerpc/kernel/module_64.c b/arch/powerpc/kernel/module_64.c index c2e1b06253b8..516c590c7a1f 100644 --- a/arch/powerpc/kernel/module_64.c +++ b/arch/powerpc/kernel/module_64.c @@ -133,20 +133,27 @@ struct ppc64_stub_entry * the stub, but it's significantly shorter to put these values at the * end of the stub code, and patch the stub address (32-bits relative * to the TOC ptr, r2) into the stub. + * + * addis r11,r2, + * addi r11,r11, + * std r2,R2_STACK_OFFSET(r1) + * ld r12,32(r11) + * ld r2,40(r11) + * mtctr r12 + * bctr */ - static u32 ppc64_stub_insns[] = { - 0x3d620000, /* addis r11,r2, */ - 0x396b0000, /* addi r11,r11, */ + PPC_INST_ADDIS | __PPC_RT(R11) | __PPC_RA(R2), + PPC_INST_ADDI | __PPC_RT(R11) | __PPC_RA(R11), /* Save current r2 value in magic place on the stack. */ - 0xf8410000|R2_STACK_OFFSET, /* std r2,R2_STACK_OFFSET(r1) */ - 0xe98b0020, /* ld r12,32(r11) */ + PPC_INST_STD | __PPC_RS(R2) | __PPC_RA(R1) | R2_STACK_OFFSET, + PPC_INST_LD | __PPC_RT(R12) | __PPC_RA(R11) | 32, #ifdef PPC64_ELF_ABI_v1 /* Set up new r2 from function descriptor */ - 0xe84b0028, /* ld r2,40(r11) */ + PPC_INST_LD | __PPC_RT(R2) | __PPC_RA(R11) | 40, #endif - 0x7d8903a6, /* mtctr r12 */ - 0x4e800420 /* bctr */ + PPC_INST_MTCTR | __PPC_RS(R12), + PPC_INST_BCTR, }; #ifdef CONFIG_DYNAMIC_FTRACE @@ -704,18 +711,21 @@ int apply_relocate_add(Elf64_Shdr *sechdrs, * ld r2, ...(r12) * add r2, r2, r12 */ - if ((((uint32_t *)location)[0] & ~0xfffc) - != 0xe84c0000) + if ((((uint32_t *)location)[0] & ~0xfffc) != + PPC_INST_LD | __PPC_RT(R2) | __PPC_RA(R12)) break; - if (((uint32_t *)location)[1] != 0x7c426214) + if (((uint32_t *)location)[1] != + PPC_INST_ADD | __PPC_RT(R2) | __PPC_RA(R2) | __PPC_RB(R12)) break; /* * If found, replace it with: * addis r2, r12, (.TOC.-func)@ha * addi r2, r12, (.TOC.-func)@l */ - ((uint32_t *)location)[0] = 0x3c4c0000 + PPC_HA(value); - ((uint32_t *)location)[1] = 0x38420000 + PPC_LO(value); + ((uint32_t *)location)[0] = PPC_INST_ADDIS | __PPC_RT(R2) | + __PPC_RA(R12) | PPC_HA(value); + ((uint32_t *)location)[1] = PPC_INST_ADDI | __PPC_RT(R2) | + __PPC_RA(R12) | PPC_LO(value); break; case R_PPC64_REL16_HA: @@ -769,12 +779,19 @@ static unsigned long create_ftrace_stub(const Elf64_Shdr *sechdrs, { struct ppc64_stub_entry *entry; unsigned int i, num_stubs; + /* + * ld r12,PACATOC(r13) + * addis r12,r12, + * addi r12,r12, + * mtctr r12 + * bctr + */ static u32 stub_insns[] = { - 0xe98d0000 | PACATOC, /* ld r12,PACATOC(r13) */ - 0x3d8c0000, /* addis r12,r12, */ - 0x398c0000, /* addi r12,r12, */ - 0x7d8903a6, /* mtctr r12 */ - 0x4e800420, /* bctr */ + PPC_INST_LD | __PPC_RT(R12) | __PPC_RA(R13) | PACATOC, + PPC_INST_ADDIS | __PPC_RT(R12) | __PPC_RA(R12), + PPC_INST_ADDI | __PPC_RT(R12) | __PPC_RA(R12), + PPC_INST_MTCTR | __PPC_RS(R12), + PPC_INST_BCTR, }; long reladdr; -- 2.13.3