summaryrefslogtreecommitdiff
path: root/sim/testsuite/sim/fr30/mulh.cgs
blob: 1421f07b31a187947c521b76cff148251f7cbd08 (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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
# fr30 testcase for mulh $Rj,$Ri
# mach(): fr30

	.include "testutils.inc"

	START

	.text
	.global mulh
mulh:
	; Test mulh $Rj,$Ri
	; Positive operands
	mvi_h_gr   	0xdead0003,r7		; multiply small numbers
	mvi_h_gr   	0xbeef0002,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	6,mdl

	mvi_h_gr   	0xdead0001,r7		; multiply by 1
	mvi_h_gr   	0xbeef0002,r8
	set_cc          0x08		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 0
	test_h_dr  	2,mdl

	mvi_h_gr   	0xdead0002,r7		; multiply by 1
	mvi_h_gr   	0xbeef0001,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	2,mdl

	mvi_h_gr   	0xdead0000,r7		; multiply by 0
	mvi_h_gr   	0xbeef0002,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	0,mdl

	mvi_h_gr   	0xdead0002,r7		; multiply by 0
	mvi_h_gr   	0xbeef0000,r8
	set_cc          0x08		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 0
	test_h_dr  	0,mdl

	mvi_h_gr   	0xdead3fff,r7	; 15 bit result
	mvi_h_gr   	0xbeef0002,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	0x00007ffe,mdl

	mvi_h_gr   	0xdead4000,r7	; 16 bit result
	mvi_h_gr   	0xbeef0002,r8
	set_cc          0x0a		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 0
	test_h_dr  	0x00008000,mdl

	mvi_h_gr   	0xdead4000,r7	; 17 bit result
	mvi_h_gr   	0xbeef0004,r8
	set_cc          0x0b		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 1
	test_h_dr  	0x00010000,mdl

	mvi_h_gr   	0xdead7fff,r7	; max positive result
	mvi_h_gr   	0xbeef7fff,r8
	set_cc          0x0b		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 1
	test_h_dr  	0x3fff0001,mdl

	; Mixed operands
	mvi_h_gr   	-3,r7		; multiply small numbers
	mvi_h_gr   	2,r8
	set_cc          0x05		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 1
	test_h_dr  	-6,mdl

	mvi_h_gr   	3,r7		; multiply small numbers
	mvi_h_gr   	-2,r8
	set_cc          0x05		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 1
	test_h_dr  	-6,mdl

	mvi_h_gr   	1,r7		; multiply by 1
	mvi_h_gr   	-2,r8
	set_cc          0x04		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 0
	test_h_dr  	-2,mdl

	mvi_h_gr   	-2,r7		; multiply by 1
	mvi_h_gr   	1,r8
	set_cc          0x05		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 1
	test_h_dr  	-2,mdl

	mvi_h_gr   	0,r7		; multiply by 0
	mvi_h_gr   	-2,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	0,mdl

	mvi_h_gr   	-2,r7		; multiply by 0
	mvi_h_gr   	0,r8
	set_cc          0x08		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 0
	test_h_dr  	0,mdl

	mvi_h_gr   	0xdead2001,r7	; 15 bit result
	mvi_h_gr   	-2,r8
	set_cc          0x05		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 1
	test_h_dr  	0xffffbffe,mdl

	mvi_h_gr   	0xdead4000,r7	; 16 bit result
	mvi_h_gr   	-2,r8
	set_cc          0x04		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 0 0
	test_h_dr  	0xffff8000,mdl

	mvi_h_gr   	0xdead4001,r7	; 16 bit result
	mvi_h_gr   	-2,r8
	set_cc          0x06		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 1 0
	test_h_dr  	0xffff7ffe,mdl

	mvi_h_gr   	0xdead4000,r7	; 17 bit result
	mvi_h_gr   	-4,r8
	set_cc          0x07		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 1 1
	test_h_dr  	0xffff0000,mdl

	mvi_h_gr   	0xdead7fff,r7	; max negative result
	mvi_h_gr   	0xbeef8000,r8
	set_cc          0x07		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		1 0 1 1
	test_h_dr  	0xc0008000,mdl

	; Negative operands
	mvi_h_gr   	-3,r7		; multiply small numbers
	mvi_h_gr   	-2,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	6,mdl

	mvi_h_gr   	-1,r7		; multiply by 1
	mvi_h_gr   	-2,r8
	set_cc          0x08		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 0
	test_h_dr  	2,mdl

	mvi_h_gr   	-2,r7		; multiply by 1
	mvi_h_gr   	-1,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	2,mdl

	mvi_h_gr   	0xdeadc001,r7	; 15 bit result
	mvi_h_gr   	-2,r8
	set_cc          0x09		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 0 1
	test_h_dr  	0x00007ffe,mdl

	mvi_h_gr   	0xdeadc000,r7	; 16 bit result
	mvi_h_gr   	-2,r8
	set_cc          0x0a		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 0
	test_h_dr  	0x00008000,mdl

	mvi_h_gr   	0xdeadc000,r7	; 17 bit result
	mvi_h_gr   	-4,r8
	set_cc          0x0b		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 1
	test_h_dr  	0x00010000,mdl

	mvi_h_gr   	0xdead8001,r7	; almost max positive result
	mvi_h_gr   	0xbeef8001,r8
	set_cc          0x0b		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 1
	test_h_dr  	0x3fff0001,mdl

	mvi_h_gr   	0xdead8000,r7	; max positive result
	mvi_h_gr   	0xbeef8000,r8
	set_cc          0x0b		; Set mask opposite of expected
	mulh      	r7,r8
	test_cc		0 1 1 1
	test_h_dr  	0x40000000,mdl

	pass