From: Luke Kenneth Casson Leighton Date: Mon, 15 Jan 2024 22:42:01 +0000 (+0000) Subject: bug 676: maxloc - finally got something working X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a5facb217b2f028597022719ab5bc935778bfb14;p=openpower-isa.git bug 676: maxloc - finally got something working --- diff --git a/src/openpower/decoder/isa/test_caller_svp64_maxloc.py b/src/openpower/decoder/isa/test_caller_svp64_maxloc.py index 151984de..61a4074b 100644 --- a/src/openpower/decoder/isa/test_caller_svp64_maxloc.py +++ b/src/openpower/decoder/isa/test_caller_svp64_maxloc.py @@ -55,7 +55,7 @@ class DDFFirstTestCase(FHDLTestCase): self.assertEqual(sim.gpr(i), SelectableInt(expected[i], 64)) def test_sv_maxloc_1(self): - self.sv_maxloc([9,10,11,10]) + self.sv_maxloc([1,3,3,3]) def tst_sv_maxloc_2(self): self.sv_maxloc([3,4,1,5]) @@ -91,11 +91,15 @@ class DDFFirstTestCase(FHDLTestCase): "setvl 2,0,4,0,1,1", # set MVL=4, VL=MIN(MVL,CTR) #"sv.addi/mr/sm=ge/dm=ns 4, *4, 0", # r4 = last non-masked value "mtcrf 128, 0", # clear CR0 (in case VL=0?) - "sv.minmax./ff=lt/m=ge 4, *10, 4, 1", # uses r4 as accumulator - "sv.svstep/mr/m=ge 3, 0, 6, 1", # svstep: get vector dststep + "sv.minmax./ff=le/m=ge 4, *10, 4, 1", # uses r4 as accumulator + "cror 0,1,0", # test for greater or equal, or VL=0 + "cror 0,2,0", # test for greater or equal, or VL=0 + "sv.creqv *19,*16,*16", # set mask on already-tested + "sv.crand *19,*19,0", # clear if CR0=0 + "sv.svstep/mr/m=so 1, 0, 6, 1", # svstep: get vector dststep "sv.creqv *16,*16,*16", # set mask on already-tested #"sv.addi/dm=1<r4 (and dec CTR) ])