Commit 47b04699 authored by Christophe Leroy's avatar Christophe Leroy Committed by Michael Ellerman

powerpc/modules: Use PPC_RAW_xx() macros

To improve readability, use PPC_RAW_xx() macros instead of
open coding. Those macros are self-explanatory so the comments
can go as well.
Signed-off-by: default avatarChristophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/99d9ee8849d3992beeadb310a665aae01c3abfb1.1621506159.git.christophe.leroy@csgroup.eu
parent 1c9debbc
...@@ -287,12 +287,9 @@ ...@@ -287,12 +287,9 @@
#define PPC_INST_LD 0xe8000000 #define PPC_INST_LD 0xe8000000
#define PPC_INST_STD 0xf8000000 #define PPC_INST_STD 0xf8000000
#define PPC_INST_MFLR 0x7c0802a6 #define PPC_INST_MFLR 0x7c0802a6
#define PPC_INST_MTCTR 0x7c0903a6
#define PPC_INST_ADDI 0x38000000
#define PPC_INST_ADDIS 0x3c000000 #define PPC_INST_ADDIS 0x3c000000
#define PPC_INST_ADD 0x7c000214 #define PPC_INST_ADD 0x7c000214
#define PPC_INST_BLR 0x4e800020 #define PPC_INST_BLR 0x4e800020
#define PPC_INST_BCTR 0x4e800420
#define PPC_INST_DIVD 0x7c0003d2 #define PPC_INST_DIVD 0x7c0003d2
#define PPC_INST_RLDICR 0x78000004 #define PPC_INST_RLDICR 0x78000004
#define PPC_INST_ORI 0x60000000 #define PPC_INST_ORI 0x60000000
...@@ -485,12 +482,12 @@ ...@@ -485,12 +482,12 @@
#define PPC_RAW_BLRL() (0x4e800021) #define PPC_RAW_BLRL() (0x4e800021)
#define PPC_RAW_MTLR(r) (0x7c0803a6 | ___PPC_RT(r)) #define PPC_RAW_MTLR(r) (0x7c0803a6 | ___PPC_RT(r))
#define PPC_RAW_MFLR(t) (PPC_INST_MFLR | ___PPC_RT(t)) #define PPC_RAW_MFLR(t) (PPC_INST_MFLR | ___PPC_RT(t))
#define PPC_RAW_BCTR() (PPC_INST_BCTR) #define PPC_RAW_BCTR() (0x4e800420)
#define PPC_RAW_BCTRL() (0x4e800421) #define PPC_RAW_BCTRL() (0x4e800421)
#define PPC_RAW_MTCTR(r) (PPC_INST_MTCTR | ___PPC_RT(r)) #define PPC_RAW_MTCTR(r) (0x7c0903a6 | ___PPC_RT(r))
#define PPC_RAW_ADDI(d, a, i) (PPC_INST_ADDI | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i)) #define PPC_RAW_ADDI(d, a, i) (0x38000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i))
#define PPC_RAW_LI(r, i) PPC_RAW_ADDI(r, 0, i) #define PPC_RAW_LI(r, i) PPC_RAW_ADDI(r, 0, i)
#define PPC_RAW_ADDIS(d, a, i) (PPC_INST_ADDIS | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i)) #define PPC_RAW_ADDIS(d, a, i) (0x3c000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i))
#define PPC_RAW_ADDIC(d, a, i) (0x30000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i)) #define PPC_RAW_ADDIC(d, a, i) (0x30000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i))
#define PPC_RAW_ADDIC_DOT(d, a, i) (0x34000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i)) #define PPC_RAW_ADDIC_DOT(d, a, i) (0x34000000 | ___PPC_RT(d) | ___PPC_RA(a) | IMM_L(i))
#define PPC_RAW_LIS(r, i) PPC_RAW_ADDIS(r, 0, i) #define PPC_RAW_LIS(r, i) PPC_RAW_ADDIS(r, 0, i)
......
...@@ -145,10 +145,9 @@ int module_frob_arch_sections(Elf32_Ehdr *hdr, ...@@ -145,10 +145,9 @@ int module_frob_arch_sections(Elf32_Ehdr *hdr,
static inline int entry_matches(struct ppc_plt_entry *entry, Elf32_Addr val) static inline int entry_matches(struct ppc_plt_entry *entry, Elf32_Addr val)
{ {
if (entry->jump[0] != (PPC_INST_ADDIS | __PPC_RT(R12) | PPC_HA(val))) if (entry->jump[0] != PPC_RAW_LIS(_R12, PPC_HA(val)))
return 0; return 0;
if (entry->jump[1] != (PPC_INST_ADDI | __PPC_RT(R12) | __PPC_RA(R12) | if (entry->jump[1] != PPC_RAW_ADDI(_R12, _R12, PPC_LO(val)))
PPC_LO(val)))
return 0; return 0;
return 1; return 1;
} }
...@@ -175,16 +174,10 @@ static uint32_t do_plt_call(void *location, ...@@ -175,16 +174,10 @@ static uint32_t do_plt_call(void *location,
entry++; entry++;
} }
/* entry->jump[0] = PPC_RAW_LIS(_R12, PPC_HA(val));
* lis r12, sym@ha entry->jump[1] = PPC_RAW_ADDI(_R12, _R12, PPC_LO(val));
* addi r12, r12, sym@l entry->jump[2] = PPC_RAW_MTCTR(_R12);
* mtctr r12 entry->jump[3] = PPC_RAW_BCTR();
* bctr
*/
entry->jump[0] = PPC_INST_ADDIS | __PPC_RT(R12) | PPC_HA(val);
entry->jump[1] = PPC_INST_ADDI | __PPC_RT(R12) | __PPC_RA(R12) | PPC_LO(val);
entry->jump[2] = PPC_INST_MTCTR | __PPC_RS(R12);
entry->jump[3] = PPC_INST_BCTR;
pr_debug("Initialized plt for 0x%x at %p\n", val, entry); pr_debug("Initialized plt for 0x%x at %p\n", val, entry);
return (uint32_t)entry; return (uint32_t)entry;
......
...@@ -122,27 +122,19 @@ struct ppc64_stub_entry ...@@ -122,27 +122,19 @@ struct ppc64_stub_entry
* the stub, but it's significantly shorter to put these values at the * 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 * end of the stub code, and patch the stub address (32-bits relative
* to the TOC ptr, r2) into the stub. * to the TOC ptr, r2) into the stub.
*
* addis r11,r2, <high>
* addi r11,r11, <low>
* std r2,R2_STACK_OFFSET(r1)
* ld r12,32(r11)
* ld r2,40(r11)
* mtctr r12
* bctr
*/ */
static u32 ppc64_stub_insns[] = { static u32 ppc64_stub_insns[] = {
PPC_INST_ADDIS | __PPC_RT(R11) | __PPC_RA(R2), PPC_RAW_ADDIS(_R11, _R2, 0),
PPC_INST_ADDI | __PPC_RT(R11) | __PPC_RA(R11), PPC_RAW_ADDI(_R11, _R11, 0),
/* Save current r2 value in magic place on the stack. */ /* Save current r2 value in magic place on the stack. */
PPC_INST_STD | __PPC_RS(R2) | __PPC_RA(R1) | R2_STACK_OFFSET, PPC_RAW_STD(_R2, _R1, R2_STACK_OFFSET),
PPC_INST_LD | __PPC_RT(R12) | __PPC_RA(R11) | 32, PPC_RAW_LD(_R12, _R11, 32),
#ifdef PPC64_ELF_ABI_v1 #ifdef PPC64_ELF_ABI_v1
/* Set up new r2 from function descriptor */ /* Set up new r2 from function descriptor */
PPC_INST_LD | __PPC_RT(R2) | __PPC_RA(R11) | 40, PPC_RAW_LD(_R2, _R11, 40),
#endif #endif
PPC_INST_MTCTR | __PPC_RS(R12), PPC_RAW_MTCTR(_R12),
PPC_INST_BCTR, PPC_RAW_BCTR(),
}; };
/* Count how many different 24-bit relocations (different symbol, /* Count how many different 24-bit relocations (different symbol,
...@@ -336,21 +328,12 @@ int module_frob_arch_sections(Elf64_Ehdr *hdr, ...@@ -336,21 +328,12 @@ int module_frob_arch_sections(Elf64_Ehdr *hdr,
#ifdef CONFIG_MPROFILE_KERNEL #ifdef CONFIG_MPROFILE_KERNEL
#define PACATOC offsetof(struct paca_struct, kernel_toc)
/*
* ld r12,PACATOC(r13)
* addis r12,r12,<high>
* addi r12,r12,<low>
* mtctr r12
* bctr
*/
static u32 stub_insns[] = { static u32 stub_insns[] = {
PPC_INST_LD | __PPC_RT(R12) | __PPC_RA(R13) | PACATOC, PPC_RAW_LD(_R12, _R13, offsetof(struct paca_struct, kernel_toc)),
PPC_INST_ADDIS | __PPC_RT(R12) | __PPC_RA(R12), PPC_RAW_ADDIS(_R12, _R12, 0),
PPC_INST_ADDI | __PPC_RT(R12) | __PPC_RA(R12), PPC_RAW_ADDI(_R12, _R12, 0),
PPC_INST_MTCTR | __PPC_RS(R12), PPC_RAW_MTCTR(_R12),
PPC_INST_BCTR, PPC_RAW_BCTR(),
}; };
/* /*
...@@ -507,7 +490,7 @@ static int restore_r2(const char *name, u32 *instruction, struct module *me) ...@@ -507,7 +490,7 @@ static int restore_r2(const char *name, u32 *instruction, struct module *me)
if (!instr_is_relative_link_branch(ppc_inst(*prev_insn))) if (!instr_is_relative_link_branch(ppc_inst(*prev_insn)))
return 1; return 1;
if (*instruction != PPC_INST_NOP) { if (*instruction != PPC_RAW_NOP()) {
pr_err("%s: Expected nop after call, got %08x at %pS\n", pr_err("%s: Expected nop after call, got %08x at %pS\n",
me->name, *instruction, instruction); me->name, *instruction, instruction);
return 0; return 0;
...@@ -696,21 +679,17 @@ int apply_relocate_add(Elf64_Shdr *sechdrs, ...@@ -696,21 +679,17 @@ int apply_relocate_add(Elf64_Shdr *sechdrs,
* ld r2, ...(r12) * ld r2, ...(r12)
* add r2, r2, r12 * add r2, r2, r12
*/ */
if ((((uint32_t *)location)[0] & ~0xfffc) != if ((((uint32_t *)location)[0] & ~0xfffc) != PPC_RAW_LD(_R2, _R12, 0))
(PPC_INST_LD | __PPC_RT(R2) | __PPC_RA(R12)))
break; break;
if (((uint32_t *)location)[1] != if (((uint32_t *)location)[1] != PPC_RAW_ADD(_R2, _R2, _R12))
(PPC_INST_ADD | __PPC_RT(R2) | __PPC_RA(R2) | __PPC_RB(R12)))
break; break;
/* /*
* If found, replace it with: * If found, replace it with:
* addis r2, r12, (.TOC.-func)@ha * addis r2, r12, (.TOC.-func)@ha
* addi r2, r2, (.TOC.-func)@l * addi r2, r2, (.TOC.-func)@l
*/ */
((uint32_t *)location)[0] = PPC_INST_ADDIS | __PPC_RT(R2) | ((uint32_t *)location)[0] = PPC_RAW_ADDIS(_R2, _R12, PPC_HA(value));
__PPC_RA(R12) | PPC_HA(value); ((uint32_t *)location)[1] = PPC_RAW_ADDI(_R2, _R2, PPC_LO(value));
((uint32_t *)location)[1] = PPC_INST_ADDI | __PPC_RT(R2) |
__PPC_RA(R2) | PPC_LO(value);
break; break;
case R_PPC64_REL16_HA: case R_PPC64_REL16_HA:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment