summaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/sh64/compact/addc.cgs
blob: f6e46e1a9693d460f03c5b030e93d66a4e17dc79 (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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# sh testcase for addc $rm, $rn -*- Asm -*-
# mach: all
# as: -isa=shcompact
# ld: -m shelf32

	.include "compact/testutils.inc"

	# Initialise some registers with values which help us to verify
	# that the correct source registers are used by the ADDC instruction.

	.macro init
	mov #0, r0
	mov #1, r1
	mov #2, r2
	mov #3, r3
	mov #5, r5
	mov #15, r15
	.endm
	
	start

	init
add:
	clrt
	addc r0, r0
	assert r0, #0
	clrt
	addc r0, r1
	assert r1, #1
	clrt
	addc r1, r2
	assert r2, #3
	clrt
	addc r3, r5
	assert r5, #8
	clrt
	addc r5, r5
	assert r5, #16
	clrt
	addc r15, r1
	assert r1, #16

	init
addt:
	sett
	addc r0, r0
	assert r0, #1
	sett
	addc r0, r1
	assert r1, #3
	sett
	addc r1, r2
	assert r2, #6
	sett
	addc r3, r5
	assert r5, #9
	sett
	addc r5, r5
	assert r5, #19
	sett
	addc r15, r1
	assert r1, #19

	bra next
	nop

wrong:
	fail

next:
	init
large:
	clrt
	mov #1, r0
	neg r0, r0
	mov #2, r1
	addc r0, r1
	assert r1, #1

	init
larget:
	sett
	mov #1, r0
	neg r0, r0
	mov #2, r1
	addc r0, r1
	assert r1, #2

okay:	
	pass