dedf12aef851af5f2d776c82326bc7bcb38f0962
1 from openpower
.simulator
.program
import Program
2 from openpower
.sv
.trans
.pysvp64dis
import load
, dump
3 from openpower
.sv
.trans
.svp64
import SVP64Asm
4 from openpower
.decoder
.power_insn
import Database
, Verbosity
5 from openpower
.decoder
.power_enums
import find_wiki_dir
6 from openpower
.sv
import sv_binutils_fptrans
12 class SVSTATETestCase(unittest
.TestCase
):
14 def _do_tst(self
, expected
):
15 isa
= SVP64Asm(expected
)
17 with
Program(lst
, bigendian
=False) as program
:
18 print ("ops", program
._instructions
)
20 program
.binfile
.seek(0)
21 binfile
.write(program
.binfile
.read())
22 program
.binfile
.seek(0)
28 print ("insns", insns
)
29 for i
, line
in enumerate(dump(insns
, verbosity
=Verbosity
.SHORT
)):
30 name
= expected
[i
].split(" ")[0]
31 with self
.subTest("%d:%s" % (i
, name
)):
32 print("instruction", repr(line
), repr(expected
[i
]))
33 self
.assertEqual(expected
[i
], line
,
34 "instruction does not match "
35 "'%s' expected '%s'" % (line
, expected
[i
]))
39 expected
= ['addi 1,5,2',
45 self
._do
_tst
(expected
)
47 def test_1_svshape2(self
):
49 'svshape2 12,1,15,5,0,0'
51 self
._do
_tst
(expected
)
53 def test_2_d_custom_op(self
):
59 self
._do
_tst
(expected
)
61 def test_3_sv_isel(self
):
65 'sv.isel 12,2,3,*483',
69 self
._do
_tst
(expected
)
71 def test_4_sv_crand(self
):
73 'sv.crand *16,*2,*33',
75 'sv.crand/ff=eq/m=r10 12,2,33',
76 'sv.crand/m=r10 12,2,33',
77 'sv.crand/m=r10/sz 12,2,33',
78 # XXX dz/sz is not the canonical way, must be zz
79 'sv.crand/dz/m=r10/sz 12,2,33', # NOT OK
80 'sv.crand/m=r10/zz 12,2,33', # SHOULD PASS
82 self
._do
_tst
(expected
)
84 def test_5_setvl(self
):
89 self
._do
_tst
(expected
)
91 def test_6_sv_setvl(self
):
93 "sv.setvl 5,4,5,0,1,1",
94 "sv.setvl 63,35,5,0,1,1",
96 self
._do
_tst
(expected
)
98 def test_7_batch(self
):
99 "these come from https://bugs.libre-soc.org/show_bug.cgi?id=917#c25"
113 "sv.fmuls *32,*32,*40",
119 "sv.fmuls *32,*32,*40",
134 "sv.lfs *48,256(16)",
135 "sv.fmuls *40,*32,*40",
137 "sv.fmuls *32,*32,*48",
145 "sv.lfs *48,256(16)",
146 "sv.fmuls *40,*32,*40",
148 "sv.fmuls *32,*32,*48",
165 "sv.fmuls *32,*32,*40",
170 self
._do
_tst
(expected
)
172 def test_8_madd(self
):
178 self
._do
_tst
(expected
)
180 def test_9_fptrans(self
):
181 "enumerates a list of fptrans instruction disassembly entries"
182 db
= Database(find_wiki_dir())
183 entries
= sorted(sv_binutils_fptrans
.collect(db
))
184 dis
= lambda entry
: sv_binutils_fptrans
.dis(entry
, binutils
=False)
186 for generator
in map(dis
, entries
):
187 for line
in generator
:
191 def test_10_vec(self
):
193 "sv.add./vec2 *3,*7,*11",
194 "sv.add./vec3 *3,*7,*11",
195 "sv.add./vec4 *3,*7,*11",
197 self
._do
_tst
(expected
)
199 def test_11_elwidth(self
):
201 "sv.add./dw=8 *3,*7,*11",
202 "sv.add./dw=16 *3,*7,*11",
203 "sv.add./dw=32 *3,*7,*11",
204 "sv.add./sw=8 *3,*7,*11",
205 "sv.add./sw=16 *3,*7,*11",
206 "sv.add./sw=32 *3,*7,*11",
207 "sv.add./dw=8/sw=16 *3,*7,*11",
208 "sv.add./dw=16/sw=32 *3,*7,*11",
209 "sv.add./dw=32/sw=8 *3,*7,*11",
210 "sv.add./w=32 *3,*7,*11",
211 "sv.add./w=8 *3,*7,*11",
212 "sv.add./w=16 *3,*7,*11",
214 self
._do
_tst
(expected
)
216 def test_12_sat(self
):
218 "sv.add./satu *3,*7,*11",
219 "sv.add./sats *3,*7,*11",
221 self
._do
_tst
(expected
)
223 def test_12_mr_r(self
):
225 "sv.add./mrr/vec2 *3,*7,*11",
226 "sv.add./mr/vec2 *3,*7,*11",
227 "sv.add./mrr *3,*7,*11",
228 "sv.add./mr *3,*7,*11",
230 self
._do
_tst
(expected
)
232 def test_13_RC1(self
):
234 "sv.add/ff=RC1 *3,*7,*11",
235 "sv.add/pr=RC1 *3,*7,*11",
236 "sv.add/ff=~RC1 *3,*7,*11",
237 "sv.add/pr=~RC1 *3,*7,*11",
239 self
._do
_tst
(expected
)
241 def test_14_rc1_ff_pr(self
):
243 "sv.add./ff=eq *3,*7,*11",
244 "sv.add./ff=ns *3,*7,*11",
245 "sv.add./ff=lt *3,*7,*11",
246 "sv.add./ff=ge *3,*7,*11",
247 "sv.add./ff=le *3,*7,*11",
248 "sv.add./ff=gt *3,*7,*11",
249 "sv.add./ff=ne *3,*7,*11",
250 "sv.add./pr=eq *3,*7,*11",
251 "sv.add./pr=ns *3,*7,*11",
253 self
._do
_tst
(expected
)
255 def test_15_predicates(self
):
257 "sv.add./m=r3 *3,*7,*11",
258 "sv.add./m=1<<r3 *3,*7,*11",
259 "sv.add./m=~r10 *3,*7,*11",
260 "sv.add./m=so *3,*7,*11",
261 "sv.add./m=ne *3,*7,*11",
262 "sv.add./m=lt *3,*7,*11",
264 "sv.extsw/m=r30 3,7",
265 "sv.extsw/dm=~r30/sm=r30 3,7",
266 "sv.extsw/dm=eq/sm=gt 3,7",
267 "sv.extsw/sm=~r3 3,7",
268 "sv.extsw/dm=r30 3,7",
270 self
._do
_tst
(expected
)
272 def test_15_els(self
):
274 "sv.stw/els *4,16(2)",
275 "sv.lfs/els *1,256(4)",
277 self
._do
_tst
(expected
)
279 def test_16_bc(self
):
280 """bigger list in test_pysvp64dis_branch.py, this one's "quick"
283 "sv.bc/all 12,*1,0xc",
284 "sv.bc/snz 12,*1,0xc",
285 "sv.bc/m=r3/snz 12,*1,0xc",
286 "sv.bc/m=r3/sz 12,*1,0xc",
287 "sv.bc/all/sl/slu 12,*1,0xc",
288 "sv.bc/all/lru/sl/slu/snz 12,*1,0xc",
289 "sv.bc/all/lru/sl/slu/snz/vs 12,*1,0xc",
290 "sv.bc/all/lru/sl/slu/snz/vsi 12,*1,0xc",
291 "sv.bc/all/lru/sl/slu/snz/vsb 12,*1,0xc",
292 "sv.bc/all/lru/sl/slu/snz/vsbi 12,*1,0xc",
293 "sv.bc/all/ctr/lru/sl/slu/snz 12,*1,0xc",
294 "sv.bc/all/cti/lru/sl/slu/snz 12,*1,0xc",
295 "sv.bc/all/ctr/lru/sl/slu/snz/vsb 12,*1,0xc",
297 self
._do
_tst
(expected
)
299 def test_17_vli(self
):
301 "sv.add/ff=RC1/vli 3,7,11",
302 "sv.add/ff=~RC1/vli 3,7,11",
304 self
._do
_tst
(expected
)
306 def test_18_sea(self
):
310 self
._do
_tst
(expected
)
312 def test_19_ldst_idx_els(self
):
314 "sv.stdx/els *4,16,2",
315 "sv.stdx/els/sea *4,16,2",
316 "sv.ldx/els *4,16,2",
317 "sv.ldx/els/sea *4,16,2",
319 self
._do
_tst
(expected
)
321 def test_20_cmp(self
):
324 "sv.cmp/ff=RC1 *4,1,*0,1",
325 "sv.cmp/ff=RC1/vli *4,1,*0,1",
326 "sv.cmp/ff=~RC1 *4,1,*0,1",
327 "sv.cmp/ff=RC1/m=r3/sz *4,1,*0,1",
328 "sv.cmp/dz/ff=RC1/m=r3 *4,1,*0,1",
329 "sv.cmp/dz/ff=RC1/m=r3/sz *4,1,*0,1",
331 self
._do
_tst
(expected
)
333 def test_21_addex(self
):
339 self
._do
_tst
(expected
)
341 def test_22_ld(self
):
344 "ld 4,16(5)", # sigh, needs magic-shift (D||0b00)
345 "sv.ld 4,16(5)", # ditto
347 self
._do
_tst
(expected
)
349 def test_23_lq(self
):
352 "lq 4,16(5)", # ditto, magic-shift (DQ||0b0000)
353 "lq 4,32(5)", # ditto
354 "sv.lq 4,16(5)", # ditto
356 self
._do
_tst
(expected
)
358 def test_24_bc(self
):
363 self
._do
_tst
(expected
)
365 def test_25_stq(self
):
372 self
._do
_tst
(expected
)
374 def test_26_sv_stq_vector_name(self
):
376 "sv.stq *4,16(*5)", # RSp not recognised as "vector" name
378 self
._do
_tst
(expected
)
380 def test_27_sc(self
):
387 self
._do
_tst
(expected
)
389 def test_28_rfid(self
):
394 self
._do
_tst
(expected
)
396 def test_29_postinc(self
):
399 "sv.lwzu/pi *6,8(2)",
400 "sv.lwzu/pi *6,24(2)",
401 "sv.stwu/pi *6,24(2)",
403 self
._do
_tst
(expected
)
405 def test_29_dsld_dsrd(self
):
416 self
._do
_tst
(expected
)
418 def test_30_divmod2du(self
):
422 "sv.divmod2du 5,4,5,3",
423 "sv.divmod2du *6,4,*0,3",
424 "sv.maddedu 5,4,5,3",
425 "sv.maddedu *6,4,5,3",
427 self
._do
_tst
(expected
)
429 def test_31_shadd_shadduw(self
):
448 self
._do
_tst
(expected
)
450 if __name__
== "__main__":