self.assertEqual(sim.gpr(i), SelectableInt(expected[i], 64))
def test_sv_add_scalar_reduce(self):
- """>>> lst = ['sv.add/mr 1, 5.v, 1'
+ """>>> lst = ['sv.add/mr 1, *5, 1'
]
note: there are 2 adds (VL=2) but *three values involved*
adds:
* 1 = 5 + 1 => 0x101 + 0x202 => 0x303
* 1 = 6 + 1 => 0x303 + 0x404 => 0x707
"""
- isa = SVP64Asm(['sv.add/mr 1, 5.v, 1'
+ isa = SVP64Asm(['sv.add/mr 1, *5, 1'
])
lst = list(isa)
print ("listing", lst)
initial_regs[6] = 0x0404
# SVSTATE (in this case, VL=2)
svstate = SVP64State()
- svstate.vl[0:7] = 2 # VL
- svstate.maxvl[0:7] = 2 # MAXVL
- print ("SVSTATE", bin(svstate.spr.asint()))
+ svstate.vl = 2 # VL
+ svstate.maxvl = 2 # MAXVL
+ print ("SVSTATE", bin(svstate.asint()))
# copy before running, then compute answers
expected_regs = deepcopy(initial_regs)
# r1 = r1 + r5 + r6
self._check_regs(sim, expected_regs)
def test_sv_add_prefix_sum(self):
- """>>> lst = ['sv.add/mr 2.v, 2.v, 1.v'
+ """>>> lst = ['sv.add/mr *2, *2, *1'
]
adds performed - not in reverse
* 2 = 2 + 1 => 1 + 2 => 3
pascal's triangle!
"""
- isa = SVP64Asm(['sv.add/mr 2.v, 2.v, 1.v'
+ isa = SVP64Asm(['sv.add/mr *2, *2, *1'
])
lst = list(isa)
print ("listing", lst)
initial_regs[4] = 0x4
# SVSTATE (in this case, VL=2)
svstate = SVP64State()
- svstate.vl[0:7] = 3 # VL
- svstate.maxvl[0:7] = 3 # MAXVL
- print ("SVSTATE", bin(svstate.spr.asint()))
+ svstate.vl = 3 # VL
+ svstate.maxvl = 3 # MAXVL
+ print ("SVSTATE", bin(svstate.asint()))
# copy before running, then compute answers
expected_regs = deepcopy(initial_regs)
for i in range(3):
self._check_regs(sim, expected_regs)
def test_sv_add_prefix_sum_reverse(self):
- """>>> lst = ['sv.add/mrr 2.v, 2.v, 1.v'
+ """>>> lst = ['sv.add/mrr *2, *2, *1'
]
adds performed - *in reverse order*
* 4 = 4 + 3 => 1 + 2 => 3
* 3 = 3 + 2 => 3 + 2 => 5
* 2 = 2 + 1 => 3 + 4 => 7
"""
- isa = SVP64Asm(['sv.add/mrr 2.v, 2.v, 1.v'
+ isa = SVP64Asm(['sv.add/mrr *2, *2, *1'
])
lst = list(isa)
print ("listing", lst)
initial_regs[4] = 0x1
# SVSTATE (in this case, VL=2)
svstate = SVP64State()
- svstate.vl[0:7] = 3 # VL
- svstate.maxvl[0:7] = 3 # MAXVL
- print ("SVSTATE", bin(svstate.spr.asint()))
+ svstate.vl = 3 # VL
+ svstate.maxvl = 3 # MAXVL
+ print ("SVSTATE", bin(svstate.asint()))
# copy before running, then compute answers
expected_regs = deepcopy(initial_regs)
for i in range(3):
self._check_regs(sim, expected_regs)
def test_fp_muls_reduce(self):
- """>>> lst = ["sv.fmuls/mr 1, 2.v, 1",
+ """>>> lst = ["sv.fmuls/mr 1, *2, 1",
]
note that VL=3 but *four values are involved*
answer should be 7.0 * -9.8 * -9.8 * 2.0 = 1344.56
* FPR 1 multiplied by FPR 3, -9.8
* FPR 1 multiplied by FPR 4, 2.0
"""
- isa = SVP64Asm(["sv.fmuls/mr 1, 2.v, 1",
+ isa = SVP64Asm(["sv.fmuls/mr 1, *2, 1",
])
lst = list(isa)
print ("listing", lst)
# SVSTATE (in this case, VL=2)
svstate = SVP64State()
- svstate.vl[0:7] = 3 # VL
- svstate.maxvl[0:7] = 3 # MAXVL
- print ("SVSTATE", bin(svstate.spr.asint()))
+ svstate.vl = 3 # VL
+ svstate.maxvl = 3 # MAXVL
+ print ("SVSTATE", bin(svstate.asint()))
with Program(lst, bigendian=False) as program:
sim = self.run_tst_program(program, svstate=svstate,
initial_fprs=fprs)
# answer should be 7.0 * -9.8 * -9.8 * 2.0 = 1344.56
- self.assertEqual(sim.fpr(1), SelectableInt(0x4095023d60000000, 64))
+ self.assertEqual(sim.fpr(1), SelectableInt(0x4095023d20000000, 64))
# these should not have been changed
self.assertEqual(sim.fpr(2), SelectableInt(0xC02399999999999A, 64))
self.assertEqual(sim.fpr(3), SelectableInt(0xC02399999999999A, 64))
self.assertEqual(sim.fpr(4), SelectableInt(0x4000000000000000, 64))
def test_sv_fpmadds(self):
- """>>> lst = ["sv.fmadds/mr 6, 2.v, 4.v, 6"
+ """>>> lst = ["sv.fmadds/mr 6, *2, *4, 6"
]
this example uses f6 as a multiply-accumulate-sum mapreduce
"""
- lst = SVP64Asm(["sv.fmadds/mr 6, 2.v, 4.v, 6"
+ lst = SVP64Asm(["sv.fmadds/mr 6, *2, *4, 6"
])
lst = list(lst)
# SVSTATE (in this case, VL=2)
svstate = SVP64State()
- svstate.vl[0:7] = 2 # VL
- svstate.maxvl[0:7] = 2 # MAXVL
- print ("SVSTATE", bin(svstate.spr.asint()))
+ svstate.vl = 2 # VL
+ svstate.maxvl = 2 # MAXVL
+ print ("SVSTATE", bin(svstate.asint()))
with Program(lst, bigendian=False) as program:
sim = self.run_tst_program(program, svstate=svstate,