powerpc/ppc-opcode: Define and use PPC_RAW_SETB()
authorChristophe Leroy <christophe.leroy@csgroup.eu>
Thu, 7 Jul 2022 14:55:16 +0000 (16:55 +0200)
committerMichael Ellerman <mpe@ellerman.id.au>
Wed, 27 Jul 2022 11:36:05 +0000 (21:36 +1000)
We have PPC_INST_SETB then build the 'setb' instruction in the
user.

Instead, define PPC_RAW_SETB() and use it.

Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/b08a4f26919a8f8cdcf7544ab552d9c1c63418b5.1657205708.git.christophe.leroy@csgroup.eu
arch/powerpc/include/asm/ppc-opcode.h
arch/powerpc/lib/test_emulate_step.c

index 5527a955fb4a9bc6df0e132581875dbf9ee63f86..7b81b37a191ea53cebf39d95d3c8326fa4eb19e2 100644 (file)
 #define PPC_INST_STRING                        0x7c00042a
 #define PPC_INST_STRING_MASK           0xfc0007fe
 #define PPC_INST_STRING_GEN_MASK       0xfc00067e
-#define PPC_INST_SETB                  0x7c000100
 #define PPC_INST_STSWI                 0x7c0005aa
 #define PPC_INST_STSWX                 0x7c00052a
 #define PPC_INST_TRECHKPT              0x7c0007dd
 #define PPC_RAW_BL(offset)             (0x48000001 | PPC_LI(offset))
 #define PPC_RAW_TW(t0, a, b)           (0x7f000008 | ___PPC_RS(t0) | ___PPC_RA(a) | ___PPC_RB(b))
 #define PPC_RAW_TRAP()                 PPC_RAW_TW(31, 0, 0)
+#define PPC_RAW_SETB(t, bfa)           (0x7c000100 | ___PPC_RT(t) | ___PPC_RA((bfa) << 2))
 
 /* Deal with instructions that older assemblers aren't aware of */
 #define        PPC_BCCTR_FLUSH         stringify_in_c(.long PPC_INST_BCCTR_FLUSH)
index f2e47be05e8c9b8e67093b26871811ab977376b2..23c7805fb7b3bddfd20f4976e796ce8e68a26d67 100644 (file)
@@ -53,9 +53,6 @@
        ppc_inst_prefix(PPC_PREFIX_MLS | __PPC_PRFX_R(pr) | IMM_H(i), \
                        PPC_RAW_ADDI(t, a, i))
 
-#define TEST_SETB(t, bfa)       ppc_inst(PPC_INST_SETB | ___PPC_RT(t) | ___PPC_RA((bfa & 0x7) << 2))
-
-
 static void __init init_pt_regs(struct pt_regs *regs)
 {
        static unsigned long msr;
@@ -935,21 +932,21 @@ static struct compute_test compute_tests[] = {
                .subtests = {
                        {
                                .descr = "BFA = 1, CR = GT",
-                               .instr = TEST_SETB(20, 1),
+                               .instr = ppc_inst(PPC_RAW_SETB(20, 1)),
                                .regs = {
                                        .ccr = 0x4000000,
                                }
                        },
                        {
                                .descr = "BFA = 4, CR = LT",
-                               .instr = TEST_SETB(20, 4),
+                               .instr = ppc_inst(PPC_RAW_SETB(20, 4)),
                                .regs = {
                                        .ccr = 0x8000,
                                }
                        },
                        {
                                .descr = "BFA = 5, CR = EQ",
-                               .instr = TEST_SETB(20, 5),
+                               .instr = ppc_inst(PPC_RAW_SETB(20, 5)),
                                .regs = {
                                        .ccr = 0x200,
                                }