d39717e2e290e0b321f111d139dbc2d5febacea4
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
11 class SVSTATETestCase(unittest
.TestCase
):
13 def _do_tst(self
, expected
):
14 isa
= SVP64Asm(expected
)
16 with
Program(lst
, bigendian
=False) as program
:
17 print ("ops", program
._instructions
)
18 program
.binfile
.seek(0)
19 insns
= load(program
.binfile
)
23 print ("insns", insns
)
24 for i
, line
in enumerate(dump(insns
, verbosity
=Verbosity
.SHORT
)):
25 name
= expected
[i
].split(" ")[0]
26 with self
.subTest("%d:%s" % (i
, name
)):
27 print("instruction", repr(line
), repr(expected
[i
]))
28 self
.assertEqual(expected
[i
], line
,
29 "instruction does not match "
30 "'%s' expected '%s'" % (line
, expected
[i
]))
34 expected
= ['addi 1,5,2',
40 self
._do
_tst
(expected
)
42 def test_1_svshape2(self
):
44 'svshape2 12,1,15,5,0,0'
46 self
._do
_tst
(expected
)
48 def test_2_d_custom_op(self
):
54 self
._do
_tst
(expected
)
56 def test_3_sv_isel(self
):
60 'sv.isel 12,2,3,*483',
64 self
._do
_tst
(expected
)
66 def test_4_sv_crand(self
):
68 'sv.crand *16,*2,*33',
70 'sv.crand/ff=eq/m=r10 12,2,33',
71 'sv.crand/m=r10 12,2,33',
72 'sv.crand/m=r10/sz 12,2,33',
73 # XXX dz/sz is not the canonical way, must be zz
74 'sv.crand/dz/m=r10/sz 12,2,33', # NOT OK
75 'sv.crand/m=r10/zz 12,2,33', # SHOULD PASS
77 self
._do
_tst
(expected
)
79 def test_5_setvl(self
):
84 self
._do
_tst
(expected
)
86 def test_6_sv_setvl(self
):
88 "sv.setvl 5,4,5,0,1,1",
89 "sv.setvl 63,35,5,0,1,1",
91 self
._do
_tst
(expected
)
93 def test_7_batch(self
):
94 "these come from https://bugs.libre-soc.org/show_bug.cgi?id=917#c25"
108 "sv.fmuls *32,*32,*40",
114 "sv.fmuls *32,*32,*40",
129 "sv.lfs *48,256(16)",
130 "sv.fmuls *40,*32,*40",
132 "sv.fmuls *32,*32,*48",
140 "sv.lfs *48,256(16)",
141 "sv.fmuls *40,*32,*40",
143 "sv.fmuls *32,*32,*48",
160 "sv.fmuls *32,*32,*40",
165 self
._do
_tst
(expected
)
167 def test_8_madd(self
):
173 self
._do
_tst
(expected
)
175 def test_9_fptrans(self
):
176 "enumerates a list of fptrans instruction disassembly entries"
177 db
= Database(find_wiki_dir())
178 entries
= sorted(sv_binutils_fptrans
.collect(db
))
179 dis
= lambda entry
: sv_binutils_fptrans
.dis(entry
, binutils
=False)
181 for generator
in map(dis
, entries
):
182 for line
in generator
:
186 def test_10_vec(self
):
188 "sv.add./vec2 *3,*7,*11",
189 "sv.add./vec3 *3,*7,*11",
190 "sv.add./vec4 *3,*7,*11",
192 self
._do
_tst
(expected
)
194 def test_11_elwidth(self
):
196 "sv.add./dw=8 *3,*7,*11",
197 "sv.add./dw=16 *3,*7,*11",
198 "sv.add./dw=32 *3,*7,*11",
199 "sv.add./sw=8 *3,*7,*11",
200 "sv.add./sw=16 *3,*7,*11",
201 "sv.add./sw=32 *3,*7,*11",
202 "sv.add./dw=8/sw=16 *3,*7,*11",
203 "sv.add./dw=16/sw=32 *3,*7,*11",
204 "sv.add./dw=32/sw=8 *3,*7,*11",
205 "sv.add./w=32 *3,*7,*11",
206 "sv.add./w=8 *3,*7,*11",
207 "sv.add./w=16 *3,*7,*11",
209 self
._do
_tst
(expected
)
211 def test_12_sat(self
):
213 "sv.add./satu *3,*7,*11",
214 "sv.add./sats *3,*7,*11",
216 self
._do
_tst
(expected
)
218 def test_12_mr_r(self
):
220 "sv.add./mrr/vec2 *3,*7,*11",
221 "sv.add./mr/vec2 *3,*7,*11",
222 "sv.add./mrr *3,*7,*11",
223 "sv.add./mr *3,*7,*11",
225 self
._do
_tst
(expected
)
227 def test_13_RC1(self
):
229 "sv.add/ff=RC1 *3,*7,*11",
230 "sv.add/pr=RC1 *3,*7,*11",
231 "sv.add/ff=~RC1 *3,*7,*11",
232 "sv.add/pr=~RC1 *3,*7,*11",
234 self
._do
_tst
(expected
)
236 def test_14_rc1_ff_pr(self
):
238 "sv.add./ff=eq *3,*7,*11",
239 "sv.add./ff=ns *3,*7,*11",
240 "sv.add./ff=lt *3,*7,*11",
241 "sv.add./ff=ge *3,*7,*11",
242 "sv.add./ff=le *3,*7,*11",
243 "sv.add./ff=gt *3,*7,*11",
244 "sv.add./ff=ne *3,*7,*11",
245 "sv.add./pr=eq *3,*7,*11",
246 "sv.add./pr=ns *3,*7,*11",
248 self
._do
_tst
(expected
)
250 def test_15_predicates(self
):
252 "sv.add./m=r3 *3,*7,*11",
253 "sv.add./m=1<<r3 *3,*7,*11",
254 "sv.add./m=~r10 *3,*7,*11",
255 "sv.add./m=so *3,*7,*11",
256 "sv.add./m=ne *3,*7,*11",
257 "sv.add./m=lt *3,*7,*11",
259 "sv.extsw/m=r30 3,7",
260 "sv.extsw/dm=~r30/sm=r30 3,7",
261 "sv.extsw/dm=eq/sm=gt 3,7",
262 "sv.extsw/sm=~r3 3,7",
263 "sv.extsw/dm=r30 3,7",
265 self
._do
_tst
(expected
)
267 def test_15_els(self
):
269 "sv.stw/els *4,16(2)",
270 "sv.lfs/els *1,256(4)",
272 self
._do
_tst
(expected
)
274 def test_16_bc(self
):
275 """bigger list in test_pysvp64dis_branch.py, this one's "quick"
278 "sv.bc/all 12,*1,0xc",
279 "sv.bc/snz 12,*1,0xc",
280 "sv.bc/m=r3/snz 12,*1,0xc",
281 "sv.bc/m=r3/sz 12,*1,0xc",
282 "sv.bc/all/sl/slu 12,*1,0xc",
283 "sv.bc/all/lru/sl/slu/snz 12,*1,0xc",
284 "sv.bc/all/lru/sl/slu/snz/vs 12,*1,0xc",
285 "sv.bc/all/lru/sl/slu/snz/vsi 12,*1,0xc",
286 "sv.bc/all/lru/sl/slu/snz/vsb 12,*1,0xc",
287 "sv.bc/all/lru/sl/slu/snz/vsbi 12,*1,0xc",
288 "sv.bc/all/ctr/lru/sl/slu/snz 12,*1,0xc",
289 "sv.bc/all/cti/lru/sl/slu/snz 12,*1,0xc",
290 "sv.bc/all/ctr/lru/sl/slu/snz/vsb 12,*1,0xc",
292 self
._do
_tst
(expected
)
294 def test_17_vli(self
):
296 "sv.add/ff=RC1/vli 3,7,11",
297 "sv.add/ff=~RC1/vli 3,7,11",
299 self
._do
_tst
(expected
)
301 def test_18_sea(self
):
305 self
._do
_tst
(expected
)
307 def test_19_ldst_idx_els(self
):
309 "sv.stdx/els *4,16,2",
310 "sv.stdx/els/sea *4,16,2",
311 "sv.ldx/els *4,16,2",
312 "sv.ldx/els/sea *4,16,2",
314 self
._do
_tst
(expected
)
316 def test_20_cmp(self
):
319 "sv.cmp/ff=RC1 *4,1,*0,1",
320 "sv.cmp/ff=RC1/vli *4,1,*0,1",
321 "sv.cmp/ff=~RC1 *4,1,*0,1",
322 "sv.cmp/ff=RC1/m=r3/sz *4,1,*0,1",
323 "sv.cmp/dz/ff=RC1/m=r3 *4,1,*0,1",
324 "sv.cmp/dz/ff=RC1/m=r3/sz *4,1,*0,1",
326 self
._do
_tst
(expected
)
328 def test_21_addex(self
):
334 self
._do
_tst
(expected
)
336 def test_22_ld(self
):
339 "ld 4,16(5)", # sigh, needs magic-shift (D||0b00)
340 "sv.ld 4,16(5)", # ditto
342 self
._do
_tst
(expected
)
344 def test_23_lq(self
):
347 "lq 4,16(5)", # ditto, magic-shift (DQ||0b0000)
348 "lq 4,32(5)", # ditto
349 "sv.lq 4,16(5)", # ditto
351 self
._do
_tst
(expected
)
353 def test_24_bc(self
):
358 self
._do
_tst
(expected
)
360 def test_25_stq(self
):
367 self
._do
_tst
(expected
)
369 def test_26_sv_stq_vector_name(self
):
371 "sv.stq *4,16(*5)", # RSp not recognised as "vector" name
373 self
._do
_tst
(expected
)
375 def test_27_sc(self
):
382 self
._do
_tst
(expected
)
384 def test_28_rfid(self
):
389 self
._do
_tst
(expected
)
391 def test_29_postinc(self
):
394 "sv.lwzu/pi *6,8(2)",
395 "sv.lwzu/pi *6,24(2)",
396 "sv.stwu/pi *6,24(2)",
398 self
._do
_tst
(expected
)
400 def test_29_dsld_dsrd(self
):
411 self
._do
_tst
(expected
)
413 def test_30_divmod2du(self
):
417 "sv.divmod2du 5,4,5,3",
418 "sv.divmod2du *6,4,*0,3",
419 "sv.maddedu 5,4,5,3",
420 "sv.maddedu *6,4,5,3",
422 self
._do
_tst
(expected
)
424 def test_31_shadd_shadduw(self
):
443 self
._do
_tst
(expected
)
445 if __name__
== "__main__":