add expected results to "sc" instruction in TrapTestCase.
authorLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Wed, 18 Oct 2023 21:05:52 +0000 (22:05 +0100)
committerLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Fri, 22 Dec 2023 19:26:21 +0000 (19:26 +0000)
this demonstrates how "sc" is meant to work in standard (system) mode.
this *may* be exactly what TestIssuer does, it will have to be checked

src/openpower/test/trap/trap_cases.py

index 704102d282e274b5eb7567f28ead3ce71be3a6c3..32b20125f8f54fd67174c8545a0ea3392b365053 100644 (file)
@@ -55,11 +55,16 @@ class TrapTestCase(TestAccumulatorBase):
         lst = ["sc 0"]
         initial_regs = [0] * 32
         initial_regs[1] = 1
-        initial_sprs = {'SRR0': 0x12345678, 'SRR1': 0x5678}
+        initial_sprs = {'SRR0': 0x12345678, 'SRR1': 0x5678} # to overwrite
+        # expected results: PC should be at 0xc00 (sc address)
         e = ExpectedState(pc=0xc00)
         e.intregs[1] = 1
+        e.sprs['SRR0'] = 4                  # PC to return to: CIA+4
+        e.sprs['SRR1'] = 0x9000000000022903 # MSR to restore after sc return
+        e.msr = 0x9000000000000001          # MSR changed to this by sc/trap
         self.add_case(Program(lst, bigendian),
-                      initial_regs, initial_sprs)
+                      initial_regs, initial_sprs,
+                      expected=e)
 
     def case_1_rfid(self):
         lst = ["rfid"]