From: Luke Kenneth Casson Leighton Date: Wed, 10 May 2023 18:30:51 +0000 (+0100) Subject: add ld/st data-dependent fail-first /vli (inclusive) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d58fa98d9cb69dbe0c76d24a5ba048e24dbcf32c;p=openpower-isa.git add ld/st data-dependent fail-first /vli (inclusive) --- diff --git a/src/openpower/decoder/isa/test_caller_svp64_ldst.py b/src/openpower/decoder/isa/test_caller_svp64_ldst.py index 58acee8f..57402f65 100644 --- a/src/openpower/decoder/isa/test_caller_svp64_ldst.py +++ b/src/openpower/decoder/isa/test_caller_svp64_ldst.py @@ -704,7 +704,7 @@ class DecoderTestCase(FHDLTestCase): self.assertEqual(sim.gpr(i+12), av[i]) def test_sv_load_dd_ffirst_excl(self): - """data-dependent fail-first on LD/ST + """data-dependent fail-first on LD/ST, exclusive (VLi=0) """ lst = SVP64Asm( [ @@ -756,6 +756,59 @@ class DecoderTestCase(FHDLTestCase): print ("%i %x %x" % (i, sim.gpr(i).value, expected_regs[i])) self.assertEqual(sim.gpr(i), expected_regs[i]) + def test_sv_load_dd_ffirst_incl(self): + """data-dependent fail-first on LD/ST, inclusive (/vli) + """ + lst = SVP64Asm( + [ + # load VL bytes but test if they are zero and truncate + "sv.lbz/ff=RC1/vli *16, 1(10)", # deliberately offset by 1 + ] + ) + lst = list(lst) + + # SVSTATE (in this case, VL=8) + svstate = SVP64State() + svstate.vl = 8 # VL + svstate.maxvl = 8 # MAXVL + print("SVSTATE", bin(svstate.asint())) + + tst_string = "hel\x00e\x00" + initial_regs = [0] * 32 + initial_regs[3] = len(tst_string) # including the zero + initial_regs[10] = 16 # load address + initial_regs[12] = 40 # store address + for i in range(8): # set to garbage + initial_regs[16+i] = (0xbeef00) + i # identifying garbage + + # calculate expected regs + expected_regs = deepcopy(initial_regs) + for i, c in enumerate(tst_string[1:]): # note the offset 1(10) + c = ord(c) + expected_regs[16+i] = c + if c == 0: break # strcpy stop at NUL *including* NUL + + # some memory with identifying garbage in it + initial_mem = {16: 0xf0f1_f2f3_f4f5_f6f7, + 24: 0x4041_4243_4445_4647, + 40: 0x8081_8283_8485_8687, + 48: 0x9091_9293_9495_9697, + } + + for i, c in enumerate(tst_string): + write_byte(initial_mem, 16+i, ord(c)) + + with Program(lst, bigendian=False) as program: + sim = self.run_tst_program(program, svstate=svstate, + initial_mem=initial_mem, + initial_regs=initial_regs) + mem = sim.mem.dump(printout=True, asciidump=True) + print (mem) + self.assertEqual(sim.svstate.vl, 3) + for i in range(len(expected_regs)): + print ("%i %x %x" % (i, sim.gpr(i).value, expected_regs[i])) + self.assertEqual(sim.gpr(i), expected_regs[i]) + def run_tst_program(self, prog, initial_regs=None, svstate=None, initial_fprs=None, initial_mem=None):