add testcases for divde, divde., divdeu, divdeu. emulated
instructions to cover few scenarios,
        * with same dividend and divisor to have undefine RT
          for divdeu[.]
        * with divide by zero to have undefine RT for both
          divde[.] and divdeu[.]
        * with negative dividend to cover -|divisor| < r <= 0 if
          the dividend is negative for divde[.]
        * normal case with proper dividend and divisor for both
          divde[.] and divdeu[.]

Reviewed-by: Sandipan Das <sandi...@linux.ibm.com>
Signed-off-by: Balamuruhan S <bal...@linux.ibm.com>
Acked-by: Naveen N. Rao <naveen.n....@linux.vnet.ibm.com>
---
 arch/powerpc/lib/test_emulate_step.c | 156 +++++++++++++++++++++++++++
 1 file changed, 156 insertions(+)

diff --git a/arch/powerpc/lib/test_emulate_step.c 
b/arch/powerpc/lib/test_emulate_step.c
index d242e9f72e0c..0a201b771477 100644
--- a/arch/powerpc/lib/test_emulate_step.c
+++ b/arch/powerpc/lib/test_emulate_step.c
@@ -1019,6 +1019,162 @@ static struct compute_test compute_tests[] = {
                        }
                }
        },
+       {
+               .mnemonic = "divde",
+               .subtests = {
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDE(20, 21, 22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       },
+                       {
+                               .descr = "RA = 1L, RB = 0",
+                               .instr = ppc_inst(PPC_RAW_DIVDE(20, 21, 22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = 1L,
+                                       .gpr[22] = 0,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDE(20, 21, 22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       }
+               }
+       },
+       {
+               .mnemonic = "divde.",
+               .subtests = {
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDE_DOT(20, 21, 
22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       },
+                       {
+                               .descr = "RA = 1L, RB = 0",
+                               .instr = ppc_inst(PPC_RAW_DIVDE_DOT(20, 21, 
22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = 1L,
+                                       .gpr[22] = 0,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDE_DOT(20, 21, 
22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       }
+               }
+       },
+       {
+               .mnemonic = "divdeu",
+               .subtests = {
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU(20, 21, 22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       },
+                       {
+                               .descr = "RA = 1L, RB = 0",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU(20, 21, 22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = 1L,
+                                       .gpr[22] = 0,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU(20, 21, 22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MAX - 1, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU(20, 21, 22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MAX - 1,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN + 1, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU(20, 21, 22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN + 1,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       }
+               }
+       },
+       {
+               .mnemonic = "divdeu.",
+               .subtests = {
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU_DOT(20, 21, 
22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       },
+                       {
+                               .descr = "RA = 1L, RB = 0",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU_DOT(20, 21, 
22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = 1L,
+                                       .gpr[22] = 0,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU_DOT(20, 21, 
22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MAX - 1, RB = LONG_MAX",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU_DOT(20, 21, 
22)),
+                               .regs = {
+                                       .gpr[21] = LONG_MAX - 1,
+                                       .gpr[22] = LONG_MAX,
+                               }
+                       },
+                       {
+                               .descr = "RA = LONG_MIN + 1, RB = LONG_MIN",
+                               .instr = ppc_inst(PPC_RAW_DIVDEU_DOT(20, 21, 
22)),
+                               .flags = IGNORE_GPR(20),
+                               .regs = {
+                                       .gpr[21] = LONG_MIN + 1,
+                                       .gpr[22] = LONG_MIN,
+                               }
+                       }
+               }
+       },
        {
                .mnemonic = "paddi",
                .cpu_feature = CPU_FTR_ARCH_31,
-- 
2.24.1

Reply via email to