Use PPC_RAW_ macros to simplify the code.

And use PPC_LO/PPC_HI instead of IMM_L/IMM_H which are for
internal use inside ppc-opcode.h

Those macros are self explanatory, comments can go as well.

Signed-off-by: Christophe Leroy <christophe.le...@csgroup.eu>
---
 arch/powerpc/include/asm/ppc-opcode.h | 11 ++++----
 arch/powerpc/kernel/optprobes.c       | 39 +++++----------------------
 2 files changed, 12 insertions(+), 38 deletions(-)

diff --git a/arch/powerpc/include/asm/ppc-opcode.h 
b/arch/powerpc/include/asm/ppc-opcode.h
index ac41776661e9..87802e8073e6 100644
--- a/arch/powerpc/include/asm/ppc-opcode.h
+++ b/arch/powerpc/include/asm/ppc-opcode.h
@@ -261,9 +261,6 @@
 #define PPC_INST_BCTR                  0x4e800420
 #define PPC_INST_BCTRL                 0x4e800421
 #define PPC_INST_DIVD                  0x7c0003d2
-#define PPC_INST_RLDICR                        0x78000004
-#define PPC_INST_ORI                   0x60000000
-#define PPC_INST_ORIS                  0x64000000
 #define PPC_INST_BRANCH                        0x48000000
 #define PPC_INST_BL                    0x48000001
 #define PPC_INST_BRANCH_COND           0x40800000
@@ -323,6 +320,8 @@
 #define PPC_LO(v)      ((v) & 0xffff)
 #define PPC_HI(v)      (((v) >> 16) & 0xffff)
 #define PPC_HA(v)      PPC_HI((v) + 0x8000)
+#define PPC_HIGHER(v)  (((v) >> 32) & 0xffff)
+#define PPC_HIGHEST(v) (((v) >> 48) & 0xffff)
 
 /*
  * Only use the larx hint bit on 64bit CPUs. e500v1/v2 based CPUs will treat a
@@ -499,8 +498,8 @@
 #define PPC_RAW_AND_DOT(d, a, b)       (0x7c000039 | ___PPC_RA(d) | 
___PPC_RS(a) | ___PPC_RB(b))
 #define PPC_RAW_OR(d, a, b)            (0x7c000378 | ___PPC_RA(d) | 
___PPC_RS(a) | ___PPC_RB(b))
 #define PPC_RAW_MR(d, a)               PPC_RAW_OR(d, a, a)
-#define PPC_RAW_ORI(d, a, i)           (PPC_INST_ORI | ___PPC_RA(d) | 
___PPC_RS(a) | IMM_L(i))
-#define PPC_RAW_ORIS(d, a, i)          (PPC_INST_ORIS | ___PPC_RA(d) | 
___PPC_RS(a) | IMM_L(i))
+#define PPC_RAW_ORI(d, a, i)           (0x60000000 | ___PPC_RA(d) | 
___PPC_RS(a) | IMM_L(i))
+#define PPC_RAW_ORIS(d, a, i)          (0x64000000 | ___PPC_RA(d) | 
___PPC_RS(a) | IMM_L(i))
 #define PPC_RAW_NOR(d, a, b)           (0x7c0000f8 | ___PPC_RA(d) | 
___PPC_RS(a) | ___PPC_RB(b))
 #define PPC_RAW_XOR(d, a, b)           (0x7c000278 | ___PPC_RA(d) | 
___PPC_RS(a) | ___PPC_RB(b))
 #define PPC_RAW_XORI(d, a, i)          (0x68000000 | ___PPC_RA(d) | 
___PPC_RS(a) | IMM_L(i))
@@ -519,7 +518,7 @@
                                        (0x54000001 | ___PPC_RA(d) | 
___PPC_RS(a) | __PPC_SH(i) | __PPC_MB(mb) | __PPC_ME(me))
 #define PPC_RAW_RLWIMI(d, a, i, mb, me) (0x50000000 | ___PPC_RA(d) | 
___PPC_RS(a) | __PPC_SH(i) | __PPC_MB(mb) | __PPC_ME(me))
 #define PPC_RAW_RLDICL(d, a, i, mb)     (0x78000000 | ___PPC_RA(d) | 
___PPC_RS(a) | __PPC_SH64(i) | __PPC_MB64(mb))
-#define PPC_RAW_RLDICR(d, a, i, me)     (PPC_INST_RLDICR | ___PPC_RA(d) | 
___PPC_RS(a) | __PPC_SH64(i) | __PPC_ME64(me))
+#define PPC_RAW_RLDICR(d, a, i, me)     (0x78000004 | ___PPC_RA(d) | 
___PPC_RS(a) | __PPC_SH64(i) | __PPC_ME64(me))
 
 /* slwi = rlwinm Rx, Ry, n, 0, 31-n */
 #define PPC_RAW_SLWI(d, a, i)          PPC_RAW_RLWINM(d, a, i, 0, 31-(i))
diff --git a/arch/powerpc/kernel/optprobes.c b/arch/powerpc/kernel/optprobes.c
index 9c1c8de8c06d..1488d4e9b34d 100644
--- a/arch/powerpc/kernel/optprobes.c
+++ b/arch/powerpc/kernel/optprobes.c
@@ -137,10 +137,8 @@ void arch_remove_optimized_kprobe(struct optimized_kprobe 
*op)
 
 static void patch_imm32_load_insns(unsigned long val, int reg, kprobe_opcode_t 
*addr)
 {
-       patch_instruction(addr, ppc_inst(PPC_RAW_LIS(reg, IMM_H(val))));
-       addr++;
-
-       patch_instruction(addr, ppc_inst(PPC_RAW_ORI(reg, reg, IMM_L(val))));
+       patch_instruction(addr++, ppc_inst(PPC_RAW_LIS(reg, PPC_HI(val))));
+       patch_instruction(addr, ppc_inst(PPC_RAW_ORI(reg, reg, PPC_LO(val))));
 }
 
 /*
@@ -149,34 +147,11 @@ static void patch_imm32_load_insns(unsigned long val, int 
reg, kprobe_opcode_t *
  */
 static void patch_imm64_load_insns(unsigned long long val, int reg, 
kprobe_opcode_t *addr)
 {
-       /* lis reg,(op)@highest */
-       patch_instruction(addr,
-                         ppc_inst(PPC_INST_ADDIS | ___PPC_RT(reg) |
-                                  ((val >> 48) & 0xffff)));
-       addr++;
-
-       /* ori reg,reg,(op)@higher */
-       patch_instruction(addr,
-                         ppc_inst(PPC_INST_ORI | ___PPC_RA(reg) |
-                                  ___PPC_RS(reg) | ((val >> 32) & 0xffff)));
-       addr++;
-
-       /* rldicr reg,reg,32,31 */
-       patch_instruction(addr,
-                         ppc_inst(PPC_INST_RLDICR | ___PPC_RA(reg) |
-                                  ___PPC_RS(reg) | __PPC_SH64(32) | 
__PPC_ME64(31)));
-       addr++;
-
-       /* oris reg,reg,(op)@h */
-       patch_instruction(addr,
-                         ppc_inst(PPC_INST_ORIS | ___PPC_RA(reg) |
-                                  ___PPC_RS(reg) | ((val >> 16) & 0xffff)));
-       addr++;
-
-       /* ori reg,reg,(op)@l */
-       patch_instruction(addr,
-                         ppc_inst(PPC_INST_ORI | ___PPC_RA(reg) |
-                                  ___PPC_RS(reg) | (val & 0xffff)));
+       patch_instruction(addr++, ppc_inst(PPC_RAW_LIS(reg, PPC_HIGHEST(val))));
+       patch_instruction(addr++, ppc_inst(PPC_RAW_ORI(reg, reg, 
PPC_HIGHER(val))));
+       patch_instruction(addr++, ppc_inst(PPC_RAW_SLDI(reg, reg, 32)));
+       patch_instruction(addr++, ppc_inst(PPC_RAW_ORIS(reg, reg, 
PPC_HI(val))));
+       patch_instruction(addr, ppc_inst(PPC_RAW_ORI(reg, reg, PPC_LO(val))));
 }
 
 static void patch_imm_load_insns(unsigned long val, int reg, kprobe_opcode_t 
*addr)
-- 
2.25.0

Reply via email to