aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/sh/fsub.s
blob: dfe9172f57aae4fec122477ad6540a74519ce51b (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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
# sh testcase for fsub
# mach: sh
# as(sh):	-defsym sim_cpu=0

	.include "testutils.inc"

	start
fsub_single:
	set_grs_a5a5
	set_fprs_a5a5
	# 0.0 - 0.0 = 0.0.
	fldi0	fr0
	fldi0	fr1
	fsub	fr0, fr1
	fldi0	fr2
	fcmp/eq	fr1, fr2
	bt	.L0
	fail
.L0:
	# 1.0 - 0.0 = 1.0.
	fldi0	fr0
	fldi1	fr1
	fsub	fr0, fr1
	fldi1	fr2
	fcmp/eq	fr1, fr2
	bt	.L1
	fail
.L1:
	# 1.0 - 1.0 = 0.0.
	fldi1	fr0
	fldi1	fr1
	fsub	fr0, fr1
	fldi0	fr2
	fcmp/eq	fr1, fr2
	bt	.L2
	fail
.L2:
	# 0.0 - 1.0 = -1.0.
	fldi1	fr0
	fldi0	fr1
	fsub	fr0, fr1
	fldi1	fr2
	fneg	fr2
	fcmp/eq	fr1, fr2
	bt	.L3
	fail
.L3:
	test_grs_a5a5
	assert_fpreg_i	 1, fr0
	assert_fpreg_i	-1, fr1
	assert_fpreg_i	-1, fr2
	test_fpr_a5a5	fr3
	test_fpr_a5a5	fr4
	test_fpr_a5a5	fr5
	test_fpr_a5a5	fr6
	test_fpr_a5a5	fr7
	test_fpr_a5a5	fr8
	test_fpr_a5a5	fr9
	test_fpr_a5a5	fr10
	test_fpr_a5a5	fr11
	test_fpr_a5a5	fr12
	test_fpr_a5a5	fr13
	test_fpr_a5a5	fr14
	test_fpr_a5a5	fr15

fsub_double:
	set_grs_a5a5
	set_fprs_a5a5
	double_prec
	# 0.0 - 0.0 = 0.0.
	fldi0	fr0
	fldi0	fr2
	_s2d	fr0, dr0
	_s2d	fr2, dr2
	fsub	dr0, dr2
	fldi0	fr4
	_s2d	fr4, dr4
	fcmp/eq	dr2, dr4
	bt	.L10
	fail
.L10:	
	# 1.0 - 0.0 = 1.0.
	fldi0	fr0
	fldi1	fr2
	_s2d	fr0, dr0
	_s2d	fr2, dr2
	fsub	dr0, dr2
	fldi1	fr4
	_s2d	fr4, dr4
	fcmp/eq	dr2, dr4
	bt	.L11
	fail
.L11:	
	# 1.0 - 1.0 = 0.0.
	fldi1	fr0
	fldi1	fr2
	_s2d	fr0, dr0
	_s2d	fr2, dr2
	fsub	dr0, dr2
	fldi0	fr4
	_s2d	fr4, dr4
	fcmp/eq	dr2, dr4
	bt	.L12
	fail
.L12:	
	# 0.0 - 1.0 = -1.0.
	fldi1	fr0
	fldi0	fr2
	_s2d	fr0, dr0
	_s2d	fr2, dr2
	fsub	dr0, dr2
	fldi1	fr4
	single_prec
	fneg	fr4
	double_prec
	_s2d	fr4, dr4
	fcmp/eq	dr2, dr4
	bt	.L13
	fail
.L13:
	test_grs_a5a5
	assert_dpreg_i	 1, dr0
	assert_dpreg_i	-1, dr2
	assert_dpreg_i	-1, dr4
	test_fpr_a5a5	fr6
	test_fpr_a5a5	fr7
	test_fpr_a5a5	fr8
	test_fpr_a5a5	fr9
	test_fpr_a5a5	fr10
	test_fpr_a5a5	fr11
	test_fpr_a5a5	fr12
	test_fpr_a5a5	fr13
	test_fpr_a5a5	fr14
	test_fpr_a5a5	fr15
	pass
	exit 0