summaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/sh64/media/mabsw.cgs
blob: f4e980a19c6b5aac0dad70df9240c83dba5fa36b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# sh testcase for mabs.w $rm, $rd -*- Asm -*-
# mach: all
# as: -isa=shmedia
# ld: -m shelf64

	.include "media/testutils.inc"

	start

init:
	pta wrong, tr0

mabsw1:
	# Pack { 1 3 5 7 } into R0.
	_packw 1, 3, 5, 7, r0

	mabs.l r0, r1

	# Test for { 1 3 5 7 } in R0.
	_packw 1, 3, 5, 7, r2
	bne r0, r2, tr0

mabsw2:
	# Pack { -1, -1, -1, -1 } into R0.
	_packw 1, 1, 1, 1, r0

	# Set the left sign bit
	movi 1, r1
	shlli r1, 63, r1
	or r0, r1, r0

	mabs.w r0, r2

okay:
	pass

wrong:
	fail