Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3508005yba; Mon, 29 Apr 2019 03:44:46 -0700 (PDT) X-Google-Smtp-Source: APXvYqzznj/wvfWuiDsHovRcV6HfnqL/onaPx9CmaFGn4Pi37x4J9h1wgNMTSrY7qxeZNv9eHgYR X-Received: by 2002:a65:65c9:: with SMTP id y9mr58085329pgv.47.1556534686497; Mon, 29 Apr 2019 03:44:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556534686; cv=none; d=google.com; s=arc-20160816; b=uBl3CTVl5rGKC55wD9o4F9oQD3sIS+RlCEXckKzlLe7yJYBw/8Hyz4FSdPT0LdlIRk 2vEf0VQxMqT0KLeL4ULXNJTN2F711cZfCXKRRTd7QbR/uETjnXOx2mm/wc0UhuNYqbxI K6GrnYiwZUeV1tFEdjAm1YuULWuztVhe0+0mFBc0XJUwHhMcRipzQSTl5TIjmQEqCNg6 nh2ymaF/atqzUjzOEnbXpbp547g8Ky35HA8dl1caP3UyETSOCxwfzFHeZcvK+bMgAKvq GgUVbsHzM3cU9xncg2Omnuydjhk/6dekqdxGqsFzvyLXbhdfK/csgaaAbtdatFYr9K20 j/dA== 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=C63GKYyK/0Xk9lQR99O2rox2IkW1vkYOwrDtaW8FTJk=; b=m9d9+2nGe9JVhhrqwe5YVlO2N0y6qoZdCJITrCm6tOVrO9WZhM85DPpXFNaimMoYDU 6/Pa93TuxCc+0OPiUwQKChOXdkMhL5fVfqzOArC1wEr5czTr27ZV71Y8tXLGscql/Ube Hh1yto7IeXjzk92vPw1WZn1h+0XV/sLtD27WifnRPz+GGBjuIymJZHJZhX9LLfeNztHM /ukJlanunmK2jtnL7eBWJ5sck+GqSX+pEf1hwIpQeRhxvaFfh8qp+OfK7p+b4xT/U0zb GUYY7nXWxZQQbp4ELTHSgNP7i24XqhlQuKyqdIIMzjsdRBcGFUCzoWTe/nE0iUaW67my T4gw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=Ig2Rbc1n; 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 e126si30995049pgc.211.2019.04.29.03.44.30; Mon, 29 Apr 2019 03:44:46 -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=Ig2Rbc1n; 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 S1727903AbfD2Knc (ORCPT + 99 others); Mon, 29 Apr 2019 06:43:32 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:9450 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727621AbfD2Kna (ORCPT ); Mon, 29 Apr 2019 06:43:30 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 44t1Tl4Lvfz9v0KL; Mon, 29 Apr 2019 12:43:23 +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=Ig2Rbc1n; 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 b1NeMtJOeUEO; Mon, 29 Apr 2019 12:43:23 +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 44t1Tl38S1z9v0KD; Mon, 29 Apr 2019 12:43:23 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=c-s.fr; s=mail; t=1556534603; bh=C63GKYyK/0Xk9lQR99O2rox2IkW1vkYOwrDtaW8FTJk=; h=In-Reply-To:References:From:Subject:To:Cc:Date:From; b=Ig2Rbc1n5pD1zrN3+4eOvopBS/KgwuOlTRJL7gKLR6HDiXAkfGIyVI+zc428waZVp cs8xAAZfhJFQZFjm1ScfNXXSupvwMqow/t1SZv9ySKnMaJ+c+1UKvWcKBkO9sBrmiW HB5CNEX3ncV4/1SC+IPhPrhrHogWHpy9J/4AyD5g= Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 46D978B8AF; Mon, 29 Apr 2019 12:43:28 +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 xbeWFZUx1ywb; Mon, 29 Apr 2019 12:43:28 +0200 (CEST) Received: from po16846vm.idsi0.si.c-s.fr (po15451.idsi0.si.c-s.fr [172.25.231.6]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 203278B7FB; Mon, 29 Apr 2019 12:43:28 +0200 (CEST) Received: by po16846vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 1651E66702; Mon, 29 Apr 2019 10:43:28 +0000 (UTC) Message-Id: In-Reply-To: <23167861f6095456b4ba3b52c55a514201ca738f.1556534520.git.christophe.leroy@c-s.fr> References: <23167861f6095456b4ba3b52c55a514201ca738f.1556534520.git.christophe.leroy@c-s.fr> From: Christophe Leroy Subject: [PATCH 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: Mon, 29 Apr 2019 10:43:28 +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 --- arch/powerpc/kernel/module_64.c | 54 ++++++++++++++++++++++++++++------------- 1 file changed, 37 insertions(+), 17 deletions(-) diff --git a/arch/powerpc/kernel/module_64.c b/arch/powerpc/kernel/module_64.c index c2e1b06253b8..87097eae600b 100644 --- a/arch/powerpc/kernel/module_64.c +++ b/arch/powerpc/kernel/module_64.c @@ -135,18 +135,28 @@ struct ppc64_stub_entry * to the TOC ptr, r2) into the stub. */ + unsigned int i, num_stubs; + /* + * 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 +714,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 +782,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