add test for scalar sv.maddedu
authorJacob Lifshay <programmerjake@gmail.com>
Tue, 18 Oct 2022 05:49:42 +0000 (22:49 -0700)
committerLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Fri, 2 Jun 2023 18:51:15 +0000 (19:51 +0100)
src/openpower/test/bigint/bigint_cases.py

index 52c73fe10193e94f08202c390d419493cd72350b..b6d86322d0d05b93eb23b5f26307b6aff22939a0 100644 (file)
@@ -252,6 +252,20 @@ class SVP64BigIntCases(TestAccumulatorBase):
         e.intregs[4] = 0x1234                  # 64-bit carry-out
         self.add_case(prog, gprs, expected=e, initial_svstate=svstate)
 
+    def case_sv_bigint_scalar_maddedu(self):
+        prog = Program(list(SVP64Asm(["sv.maddedu 6,5,3,4"])), False)
+        gprs = [0] * 32
+        gprs[5] = 0x1357_0000_9BDF_0000        # scalar input
+        gprs[3] = 0x1_0001                      # scalar multiplier
+        gprs[4] = 0xFEDC                        # 64-bit carry-in
+        svstate = SVP64State()
+        svstate.vl = 16  # detect writing to RT+MAXVL or RT+1 rather than RC
+        svstate.maxvl = 16
+        e = ExpectedState(pc=8, int_regs=gprs)
+        e.intregs[6] = 0x1357_9BDF_9BDF_FEDC  # scalar output
+        e.intregs[4] = 0x1357                  # 64-bit carry-out
+        self.add_case(prog, gprs, expected=e, initial_svstate=svstate)
+
     def case_sv_bigint_div_by_scalar(self):
         """performs a carry-rollover-vector-divmod with a scalar,
         using "RC" as a 64-bit carry.  matched with the sv.maddedu