]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/testsuite/gdb.arch/powerpc-power10.exp
Update copyright year range in header of all files managed by GDB
[thirdparty/binutils-gdb.git] / gdb / testsuite / gdb.arch / powerpc-power10.exp
CommitLineData
1d506c26 1# Copyright 2021-2024 Free Software Foundation, Inc.
82d9b280
WS
2
3# This program is free software; you can redistribute it and/or modify
4# it under the terms of the GNU General Public License as published by
5# the Free Software Foundation; either version 3 of the License, or
6# (at your option) any later version.
7#
8# This program is distributed in the hope that it will be useful,
9# but WITHOUT ANY WARRANTY; without even the implied warranty of
10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11# GNU General Public License for more details.
12#
13# You should have received a copy of the GNU General Public License
14# along with this program. If not, see <http://www.gnu.org/licenses/>.
15
16# This file is part of the gdb testsuite.
17
18# Test PowerPC instructions disassembly of power10 instructions.
19
20standard_testfile .s
21set objfile [standard_output_file ${testfile}.o]
22
73c06197 23require {istarget "powerpc*-*-*"}
82d9b280
WS
24
25if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${objfile}" object {debug}] != "" } {
26 untested "PowerPC instructions disassembly"
27 return -1
28}
29
30clean_restart ${objfile}
31
32# Disassemble the function.
33set func ""
34
35gdb_test "set disassembler-options power10"
36set test "disass func"
37gdb_test_multiple $test $test {
38 -re "\r\nDump of assembler code for function func:(\r\n.*\r\n)End of assembler dump.\r\n$gdb_prompt $" {
39 set func $expect_out(1,string)
40 pass $test
41 }
42}
43
44proc instr_to_patt {instr} {
45 global decimal hex
46 # 0x0000000000000018 <+24>: stxvd2x vs43,r4,r5
47 return "\[ \t\]*$hex <\\+$decimal>:\[ \t\]*[string_to_regexp $instr]"
48}
49
50proc func_check {instr} {
51 global func
52
53 set test "found: $instr"
54 if [regexp -nocase -line [instr_to_patt $instr] $func] {
55 pass $test
56 } else {
57 fail $test
58 }
59}
60
61func_check "brd r0,r1"
62func_check "brh r0,r1"
63func_check "brw r0,r1"
64func_check "cfuged r0,r1,r2"
65func_check "cntlzdm r0,r1,r2"
66func_check "cnttzdm r0,r1,r2"
67func_check "dcffixqq f28,v0"
68func_check "dctfixqq v0,f26"
69func_check "lxvkq vs0,1"
70func_check "lxvkq vs0,16"
71func_check "lxvkq vs0,17"
72func_check "lxvkq vs0,18"
73func_check "lxvkq vs0,19"
74func_check "lxvkq vs0,2"
75func_check "lxvkq vs0,20"
76func_check "lxvkq vs0,21"
77func_check "lxvkq vs0,22"
78func_check "lxvkq vs0,23"
79func_check "lxvkq vs0,24"
80func_check "lxvkq vs0,3"
81func_check "lxvkq vs0,4"
82func_check "lxvkq vs0,5"
83func_check "lxvkq vs0,6"
84func_check "lxvkq vs0,7"
85func_check "lxvkq vs0,8"
86func_check "lxvkq vs0,9"
87func_check "lxvp vs20,0(0)"
88func_check "lxvp vs20,16(0)"
89func_check "lxvp vs20,32(0)"
90func_check "lxvpx vs20,0,r1"
91func_check "lxvrbx vs0,r1,r2"
92func_check "lxvrdx vs0,r1,r2"
93func_check "lxvrhx vs0,r1,r2"
94func_check "lxvrwx vs0,r1,r2"
95func_check "mfvsrld r0,vs26"
96func_check "mfvsrld r0,vs27"
97func_check "mfvsrld r0,vs28"
98func_check "mfvsrld r0,vs29"
99func_check "mffprd r0,f26"
100func_check "mffprd r0,f27"
101func_check "mffprd r0,f28"
102func_check "mffprd r0,f29"
103func_check "mtvsrbm v0,r1"
104func_check "mtvsrbmi v0,0"
105func_check "mtvsrbmi v0,3"
106func_check "mtvsrbmi v0,7"
107func_check "mtvsrdm v0,r1"
108func_check "mtvsrhm v0,r1"
109func_check "mtvsrqm v0,r1"
110func_check "mtvsrwm v0,r1"
111func_check "paddi r0,r1,0"
112func_check "paddi r0,r1,12"
113func_check "paddi r0,r1,48"
114func_check "paddi r0,r1,98"
115func_check "pdepd r0,r1,r2"
116func_check "pextd r0,r1,r2"
117func_check "plbz r0,0(r1)"
118func_check "plbz r0,16(r1)"
119func_check "plbz r0,32(r1)"
120func_check "plbz r0,64(r1)"
121func_check "plbz r0,8(r1)"
122func_check "pld r0,0(r1)"
123func_check "pld r0,16(r1)"
124func_check "pld r0,32(r1)"
125func_check "pld r0,64(r1)"
126func_check "pld r0,8(r1)"
127func_check "plfd f28,0(0)"
128func_check "plfd f28,16(0)"
129func_check "plfd f28,32(0)"
130func_check "plfd f28,4(0)"
131func_check "plfd f28,64(0)"
132func_check "plfd f28,8(0)"
133func_check "plfs f28,0(0)"
134func_check "plfs f28,16(0)"
135func_check "plfs f28,32(0)"
136func_check "plfs f28,4(0)"
137func_check "plfs f28,64(0)"
138func_check "plfs f28,8(0)"
139func_check "plha r0,0(r1)"
140func_check "plha r0,16(r1)"
141func_check "plha r0,32(r1)"
142func_check "plha r0,64(r1)"
143func_check "plha r0,8(r1)"
144func_check "plhz r0,0(r1)"
145func_check "plhz r0,16(r1)"
146func_check "plhz r0,32(r1)"
147func_check "plhz r0,64(r1)"
148func_check "plhz r0,8(r1)"
149func_check "plq r26,0(0)"
150func_check "plq r26,16(0)"
151func_check "plq r26,32(0)"
152func_check "plq r26,48(0)"
153func_check "plq r26,64(0)"
154func_check "plq r26,8(0)"
155func_check "plwa r0,0(r1)"
156func_check "plwa r0,16(r1)"
157func_check "plwa r0,32(r1)"
158func_check "plwa r0,64(r1)"
159func_check "plwa r0,8(r1)"
160func_check "plwz r0,0(r1)"
161func_check "plwz r0,16(r1)"
162func_check "plwz r0,32(r1)"
163func_check "plwz r0,64(r1)"
164func_check "plwz r0,8(r1)"
165func_check "plxsd v0,0(r1)"
166func_check "plxsd v0,16(r1)"
167func_check "plxsd v0,32(r1)"
168func_check "plxsd v0,4(r1)"
169func_check "plxsd v0,64(r1)"
170func_check "plxsd v0,8(r1)"
171func_check "plxssp v0,0(r1)"
172func_check "plxssp v0,16(r1)"
173func_check "plxssp v0,32(r1)"
174func_check "plxssp v0,4(r1)"
175func_check "plxssp v0,64(r1)"
176func_check "plxssp v0,8(r1)"
177func_check "plxv vs0,0(r1)"
178func_check "plxv vs0,16(r1)"
179func_check "plxv vs0,4(r1)"
180func_check "plxv vs0,8(r1)"
181func_check "plxvp vs20,0(0)"
182func_check "plxvp vs20,16(0)"
183func_check "plxvp vs20,24(0)"
184func_check "plxvp vs20,32(0)"
185func_check "plxvp vs20,8(0)"
49977100
CL
186func_check "pmdmxvbf16ger2 a4,vs0,vs1,0,0,0"
187func_check "pmdmxvbf16ger2 a4,vs0,vs1,0,0,1"
188func_check "pmdmxvbf16ger2 a4,vs0,vs1,0,13,0"
189func_check "pmdmxvbf16ger2 a4,vs0,vs1,0,13,1"
190func_check "pmdmxvbf16ger2 a4,vs0,vs1,11,0,0"
191func_check "pmdmxvbf16ger2 a4,vs0,vs1,11,0,1"
192func_check "pmdmxvbf16ger2 a4,vs0,vs1,11,13,0"
193func_check "pmdmxvbf16ger2 a4,vs0,vs1,11,13,1"
194func_check "pmdmxvbf16ger2nn a4,vs0,vs1,0,0,0"
195func_check "pmdmxvbf16ger2nn a4,vs0,vs1,0,0,1"
196func_check "pmdmxvbf16ger2nn a4,vs0,vs1,0,13,0"
197func_check "pmdmxvbf16ger2nn a4,vs0,vs1,0,13,1"
198func_check "pmdmxvbf16ger2nn a4,vs0,vs1,11,0,0"
199func_check "pmdmxvbf16ger2nn a4,vs0,vs1,11,0,1"
200func_check "pmdmxvbf16ger2nn a4,vs0,vs1,11,13,0"
201func_check "pmdmxvbf16ger2nn a4,vs0,vs1,11,13,1"
202func_check "pmdmxvbf16ger2np a4,vs0,vs1,0,0,0"
203func_check "pmdmxvbf16ger2np a4,vs0,vs1,0,0,1"
204func_check "pmdmxvbf16ger2np a4,vs0,vs1,0,13,0"
205func_check "pmdmxvbf16ger2np a4,vs0,vs1,0,13,1"
206func_check "pmdmxvbf16ger2np a4,vs0,vs1,11,0,0"
207func_check "pmdmxvbf16ger2np a4,vs0,vs1,11,0,1"
208func_check "pmdmxvbf16ger2np a4,vs0,vs1,11,13,0"
209func_check "pmdmxvbf16ger2np a4,vs0,vs1,11,13,1"
210func_check "pmdmxvbf16ger2pn a4,vs0,vs1,0,0,0"
211func_check "pmdmxvbf16ger2pn a4,vs0,vs1,0,0,1"
212func_check "pmdmxvbf16ger2pn a4,vs0,vs1,0,13,0"
213func_check "pmdmxvbf16ger2pn a4,vs0,vs1,0,13,1"
214func_check "pmdmxvbf16ger2pn a4,vs0,vs1,11,0,0"
215func_check "pmdmxvbf16ger2pn a4,vs0,vs1,11,0,1"
216func_check "pmdmxvbf16ger2pn a4,vs0,vs1,11,13,0"
217func_check "pmdmxvbf16ger2pn a4,vs0,vs1,11,13,1"
218func_check "pmdmxvbf16ger2pp a4,vs0,vs1,0,0,0"
219func_check "pmdmxvbf16ger2pp a4,vs0,vs1,0,0,1"
220func_check "pmdmxvbf16ger2pp a4,vs0,vs1,0,13,0"
221func_check "pmdmxvbf16ger2pp a4,vs0,vs1,0,13,1"
222func_check "pmdmxvbf16ger2pp a4,vs0,vs1,11,0,0"
223func_check "pmdmxvbf16ger2pp a4,vs0,vs1,11,0,1"
224func_check "pmdmxvbf16ger2pp a4,vs0,vs1,11,13,0"
225func_check "pmdmxvbf16ger2pp a4,vs0,vs1,11,13,1"
226func_check "pmdmxvf16ger2 a4,vs0,vs1,0,0,0"
227func_check "pmdmxvf16ger2 a4,vs0,vs1,0,0,1"
228func_check "pmdmxvf16ger2 a4,vs0,vs1,0,13,0"
229func_check "pmdmxvf16ger2 a4,vs0,vs1,0,13,1"
230func_check "pmdmxvf16ger2 a4,vs0,vs1,11,0,0"
231func_check "pmdmxvf16ger2 a4,vs0,vs1,11,0,1"
232func_check "pmdmxvf16ger2 a4,vs0,vs1,11,13,0"
233func_check "pmdmxvf16ger2 a4,vs0,vs1,11,13,1"
234func_check "pmdmxvf16ger2nn a4,vs0,vs1,0,0,0"
235func_check "pmdmxvf16ger2nn a4,vs0,vs1,0,0,1"
236func_check "pmdmxvf16ger2nn a4,vs0,vs1,0,13,0"
237func_check "pmdmxvf16ger2nn a4,vs0,vs1,0,13,1"
238func_check "pmdmxvf16ger2nn a4,vs0,vs1,11,0,0"
239func_check "pmdmxvf16ger2nn a4,vs0,vs1,11,0,1"
240func_check "pmdmxvf16ger2nn a4,vs0,vs1,11,13,0"
241func_check "pmdmxvf16ger2nn a4,vs0,vs1,11,13,1"
242func_check "pmdmxvf16ger2np a4,vs0,vs1,0,0,0"
243func_check "pmdmxvf16ger2np a4,vs0,vs1,0,0,1"
244func_check "pmdmxvf16ger2np a4,vs0,vs1,0,13,0"
245func_check "pmdmxvf16ger2np a4,vs0,vs1,0,13,1"
246func_check "pmdmxvf16ger2np a4,vs0,vs1,11,0,0"
247func_check "pmdmxvf16ger2np a4,vs0,vs1,11,0,1"
248func_check "pmdmxvf16ger2np a4,vs0,vs1,11,13,0"
249func_check "pmdmxvf16ger2np a4,vs0,vs1,11,13,1"
250func_check "pmdmxvf16ger2pn a4,vs0,vs1,0,0,0"
251func_check "pmdmxvf16ger2pn a4,vs0,vs1,0,0,1"
252func_check "pmdmxvf16ger2pn a4,vs0,vs1,0,13,0"
253func_check "pmdmxvf16ger2pn a4,vs0,vs1,0,13,1"
254func_check "pmdmxvf16ger2pn a4,vs0,vs1,11,0,0"
255func_check "pmdmxvf16ger2pn a4,vs0,vs1,11,0,1"
256func_check "pmdmxvf16ger2pn a4,vs0,vs1,11,13,0"
257func_check "pmdmxvf16ger2pn a4,vs0,vs1,11,13,1"
258func_check "pmdmxvf16ger2pp a4,vs0,vs1,0,0,0"
259func_check "pmdmxvf16ger2pp a4,vs0,vs1,0,0,1"
260func_check "pmdmxvf16ger2pp a4,vs0,vs1,0,13,0"
261func_check "pmdmxvf16ger2pp a4,vs0,vs1,0,13,1"
262func_check "pmdmxvf16ger2pp a4,vs0,vs1,11,0,0"
263func_check "pmdmxvf16ger2pp a4,vs0,vs1,11,0,1"
264func_check "pmdmxvf16ger2pp a4,vs0,vs1,11,13,0"
265func_check "pmdmxvf16ger2pp a4,vs0,vs1,11,13,1"
266func_check "pmdmxvf32ger a4,vs0,vs1,0,0"
267func_check "pmdmxvf32ger a4,vs0,vs1,0,13"
268func_check "pmdmxvf32ger a4,vs0,vs1,11,0"
269func_check "pmdmxvf32ger a4,vs0,vs1,11,13"
270func_check "pmdmxvf32gernn a4,vs0,vs1,0,0"
271func_check "pmdmxvf32gernn a4,vs0,vs1,0,13"
272func_check "pmdmxvf32gernn a4,vs0,vs1,11,0"
273func_check "pmdmxvf32gernn a4,vs0,vs1,11,13"
274func_check "pmdmxvf32gernp a4,vs0,vs1,0,0"
275func_check "pmdmxvf32gernp a4,vs0,vs1,0,13"
276func_check "pmdmxvf32gernp a4,vs0,vs1,11,0"
277func_check "pmdmxvf32gernp a4,vs0,vs1,11,13"
278func_check "pmdmxvf32gerpn a4,vs0,vs1,0,0"
279func_check "pmdmxvf32gerpn a4,vs0,vs1,0,13"
280func_check "pmdmxvf32gerpn a4,vs0,vs1,11,0"
281func_check "pmdmxvf32gerpn a4,vs0,vs1,11,13"
282func_check "pmdmxvf32gerpp a4,vs0,vs1,0,0"
283func_check "pmdmxvf32gerpp a4,vs0,vs1,0,13"
284func_check "pmdmxvf32gerpp a4,vs0,vs1,11,0"
285func_check "pmdmxvf32gerpp a4,vs0,vs1,11,13"
286func_check "pmdmxvf64ger a4,vs22,vs0,0,0"
287func_check "pmdmxvf64ger a4,vs22,vs0,0,1"
288func_check "pmdmxvf64ger a4,vs22,vs0,11,0"
289func_check "pmdmxvf64ger a4,vs22,vs0,11,1"
290func_check "pmdmxvf64gernn a4,vs22,vs0,0,0"
291func_check "pmdmxvf64gernn a4,vs22,vs0,0,1"
292func_check "pmdmxvf64gernn a4,vs22,vs0,11,0"
293func_check "pmdmxvf64gernn a4,vs22,vs0,11,1"
294func_check "pmdmxvf64gernp a4,vs22,vs0,0,0"
295func_check "pmdmxvf64gernp a4,vs22,vs0,0,1"
296func_check "pmdmxvf64gernp a4,vs22,vs0,11,0"
297func_check "pmdmxvf64gernp a4,vs22,vs0,11,1"
298func_check "pmdmxvf64gerpn a4,vs22,vs0,0,0"
299func_check "pmdmxvf64gerpn a4,vs22,vs0,0,1"
300func_check "pmdmxvf64gerpn a4,vs22,vs0,11,0"
301func_check "pmdmxvf64gerpn a4,vs22,vs0,11,1"
302func_check "pmdmxvf64gerpp a4,vs22,vs0,0,0"
303func_check "pmdmxvf64gerpp a4,vs22,vs0,0,1"
304func_check "pmdmxvf64gerpp a4,vs22,vs0,11,0"
305func_check "pmdmxvf64gerpp a4,vs22,vs0,11,1"
306func_check "pmdmxvi16ger2 a4,vs0,vs1,0,0,0"
307func_check "pmdmxvi16ger2 a4,vs0,vs1,0,0,1"
308func_check "pmdmxvi16ger2 a4,vs0,vs1,0,13,0"
309func_check "pmdmxvi16ger2 a4,vs0,vs1,0,13,1"
310func_check "pmdmxvi16ger2 a4,vs0,vs1,11,0,0"
311func_check "pmdmxvi16ger2 a4,vs0,vs1,11,0,1"
312func_check "pmdmxvi16ger2 a4,vs0,vs1,11,13,0"
313func_check "pmdmxvi16ger2 a4,vs0,vs1,11,13,1"
314func_check "pmdmxvi16ger2pp a4,vs0,vs1,0,0,0"
315func_check "pmdmxvi16ger2pp a4,vs0,vs1,0,0,1"
316func_check "pmdmxvi16ger2pp a4,vs0,vs1,0,13,0"
317func_check "pmdmxvi16ger2pp a4,vs0,vs1,0,13,1"
318func_check "pmdmxvi16ger2pp a4,vs0,vs1,11,0,0"
319func_check "pmdmxvi16ger2pp a4,vs0,vs1,11,0,1"
320func_check "pmdmxvi16ger2pp a4,vs0,vs1,11,13,0"
321func_check "pmdmxvi16ger2pp a4,vs0,vs1,11,13,1"
322func_check "pmdmxvi16ger2s a4,vs0,vs1,0,0,0"
323func_check "pmdmxvi16ger2s a4,vs0,vs1,0,0,1"
324func_check "pmdmxvi16ger2s a4,vs0,vs1,0,13,0"
325func_check "pmdmxvi16ger2s a4,vs0,vs1,0,13,1"
326func_check "pmdmxvi16ger2s a4,vs0,vs1,11,0,0"
327func_check "pmdmxvi16ger2s a4,vs0,vs1,11,0,1"
328func_check "pmdmxvi16ger2s a4,vs0,vs1,11,13,0"
329func_check "pmdmxvi16ger2s a4,vs0,vs1,11,13,1"
330func_check "pmdmxvi16ger2spp a4,vs0,vs1,0,0,0"
331func_check "pmdmxvi16ger2spp a4,vs0,vs1,0,0,1"
332func_check "pmdmxvi16ger2spp a4,vs0,vs1,0,13,0"
333func_check "pmdmxvi16ger2spp a4,vs0,vs1,0,13,1"
334func_check "pmdmxvi16ger2spp a4,vs0,vs1,11,0,0"
335func_check "pmdmxvi16ger2spp a4,vs0,vs1,11,0,1"
336func_check "pmdmxvi16ger2spp a4,vs0,vs1,11,13,0"
337func_check "pmdmxvi16ger2spp a4,vs0,vs1,11,13,1"
338func_check "pmdmxvi4ger8 a4,vs0,vs1,0,0,0"
339func_check "pmdmxvi4ger8 a4,vs0,vs1,0,0,45"
340func_check "pmdmxvi4ger8 a4,vs0,vs1,0,1,0"
341func_check "pmdmxvi4ger8 a4,vs0,vs1,0,1,45"
342func_check "pmdmxvi4ger8 a4,vs0,vs1,11,0,0"
343func_check "pmdmxvi4ger8 a4,vs0,vs1,11,0,45"
344func_check "pmdmxvi4ger8 a4,vs0,vs1,11,1,0"
345func_check "pmdmxvi4ger8 a4,vs0,vs1,11,1,45"
346func_check "pmdmxvi4ger8pp a4,vs0,vs1,0,0,0"
347func_check "pmdmxvi4ger8pp a4,vs0,vs1,0,0,45"
348func_check "pmdmxvi4ger8pp a4,vs0,vs1,0,1,0"
349func_check "pmdmxvi4ger8pp a4,vs0,vs1,0,1,45"
350func_check "pmdmxvi4ger8pp a4,vs0,vs1,11,0,0"
351func_check "pmdmxvi4ger8pp a4,vs0,vs1,11,0,45"
352func_check "pmdmxvi4ger8pp a4,vs0,vs1,11,1,0"
353func_check "pmdmxvi4ger8pp a4,vs0,vs1,11,1,45"
354func_check "pmdmxvi8ger4 a4,vs0,vs1,0,0,0"
355func_check "pmdmxvi8ger4 a4,vs0,vs1,0,0,5"
356func_check "pmdmxvi8ger4 a4,vs0,vs1,0,13,0"
357func_check "pmdmxvi8ger4 a4,vs0,vs1,0,13,5"
358func_check "pmdmxvi8ger4 a4,vs0,vs1,11,0,0"
359func_check "pmdmxvi8ger4 a4,vs0,vs1,11,0,5"
360func_check "pmdmxvi8ger4 a4,vs0,vs1,11,13,0"
361func_check "pmdmxvi8ger4 a4,vs0,vs1,11,13,5"
362func_check "pmdmxvi8ger4pp a4,vs0,vs1,0,0,0"
363func_check "pmdmxvi8ger4pp a4,vs0,vs1,0,0,5"
364func_check "pmdmxvi8ger4pp a4,vs0,vs1,0,13,0"
365func_check "pmdmxvi8ger4pp a4,vs0,vs1,0,13,5"
366func_check "pmdmxvi8ger4pp a4,vs0,vs1,11,0,0"
367func_check "pmdmxvi8ger4pp a4,vs0,vs1,11,0,5"
368func_check "pmdmxvi8ger4pp a4,vs0,vs1,11,13,0"
369func_check "pmdmxvi8ger4pp a4,vs0,vs1,11,13,5"
370func_check "pmdmxvi8ger4spp a4,vs0,vs1,0,0,0"
371func_check "pmdmxvi8ger4spp a4,vs0,vs1,0,0,5"
372func_check "pmdmxvi8ger4spp a4,vs0,vs1,0,13,0"
373func_check "pmdmxvi8ger4spp a4,vs0,vs1,0,13,5"
374func_check "pmdmxvi8ger4spp a4,vs0,vs1,11,0,0"
375func_check "pmdmxvi8ger4spp a4,vs0,vs1,11,0,5"
376func_check "pmdmxvi8ger4spp a4,vs0,vs1,11,13,0"
377func_check "pmdmxvi8ger4spp a4,vs0,vs1,11,13,5"
82d9b280
WS
378#/* pstb extended mnemonics can suppress (r1) or the trailing ,0 or ,1, see ISA.
379func_check "pstb r0,0(r1)"
380func_check "pstb r0,16(r1)"
381func_check "pstb r0,32(r1)"
382func_check "pstb r0,8(r1)"
383func_check "pstd r0,0(r1)"
384func_check "pstd r0,16(r1)"
385func_check "pstd r0,32(r1)"
386func_check "pstd r0,8(r1)"
387func_check "pstfd f26,0(0)"
388func_check "pstfd f26,16(0)"
389func_check "pstfd f26,32(0)"
390func_check "pstfd f26,4(0)"
391func_check "pstfd f26,8(0)"
392func_check "pstfs f26,0(0)"
393func_check "pstfs f26,16(0)"
394func_check "pstfs f26,32(0)"
395func_check "pstfs f26,4(0)"
396func_check "pstfs f26,8(0)"
397func_check "psth r0,0(r1)"
398func_check "psth r0,16(r1)"
399func_check "psth r0,32(r1)"
400func_check "psth r0,8(r1)"
401func_check "pstq r24,0(0)"
402func_check "pstq r24,16(0)"
403func_check "pstq r24,32(0)"
404func_check "pstq r24,64(0)"
405func_check "pstq r24,8(0)"
406func_check "pstw r0,0(r1)"
407func_check "pstw r0,16(r1)"
408func_check "pstw r0,32(r1)"
409func_check "pstw r0,8(r1)"
410func_check "pstxsd v22,0(0)"
411func_check "pstxsd v22,16(0)"
412func_check "pstxsd v22,32(0)"
413func_check "pstxsd v22,4(0)"
414func_check "pstxsd v22,64(0)"
415func_check "pstxsd v22,8(0)"
416func_check "pstxssp v22,0(0)"
417func_check "pstxssp v22,16(0)"
418func_check "pstxssp v22,32(0)"
419func_check "pstxssp v22,4(0)"
420func_check "pstxssp v22,64(0)"
421func_check "pstxssp v22,8(0)"
422func_check "pstxv vs0,0(r1)"
423func_check "pstxv vs0,16(r1)"
424func_check "pstxv vs0,4(r1)"
425func_check "pstxv vs0,8(r1)"
426func_check "pstxvp vs20,0(0)"
427func_check "pstxvp vs20,16(0)"
428func_check "pstxvp vs20,32(0)"
429func_check "pstxvp vs20,48(0)"
430# lt,gt,eq,so map to cr0 0,1,2,3 ; cr1,cr2 extend from there. lt=0 ; gt=1 ; eq=2 ; so=3
431func_check "setbc r26,lt"
432func_check "setbc r26,gt"
433func_check "setbc r26,eq"
434func_check "setbc r26,so"
435func_check "setbc r26,4*cr1+so"
436func_check "setbc r26,4*cr2+lt"
437func_check "setbc r26,4*cr7+so"
438
439func_check "setbcr r26,4*cr7+so"
440func_check "setbcr r26,4*cr1+so"
441func_check "setbcr r26,4*cr2+lt"
442
443func_check "setnbc r26,lt"
444func_check "setnbc r26,so"
445func_check "setnbc r26,4*cr7+so"
446func_check "setnbc r26,4*cr1+so"
447func_check "setnbc r26,4*cr2+lt"
448
449func_check "setnbcr r26,lt"
450func_check "setnbcr r26,so"
451func_check "setnbcr r26,4*cr7+so"
452func_check "setnbcr r26,4*cr1+so"
453func_check "setnbcr r26,4*cr2+lt"
454
455func_check "stxvp vs20,0(0)"
456func_check "stxvp vs20,16(0)"
457func_check "stxvp vs20,32(0)"
458func_check "stxvp vs20,48(0)"
459func_check "stxvpx vs20,0,r1"
460func_check "stxvrbx vs0,r1,r2"
461func_check "stxvrdx vs0,r1,r2"
462func_check "stxvrhx vs0,r1,r2"
463func_check "stxvrwx vs0,r1,r2"
464func_check "vcfuged v0,v1,v2"
465func_check "vclrlb v0,v1,r2"
466func_check "vclrrb v0,v1,r2"
467func_check "vclzdm v0,v1,v2"
468func_check "vcmpequq v0,v1,v2"
469func_check "vcmpgtsq v0,v1,v2"
470func_check "vcmpgtuq v0,v1,v2"
471func_check "vcmpsq cr3,v0,v1"
472func_check "vcmpuq cr3,v0,v1"
473func_check "vcntmbb r0,v1,0"
474func_check "vcntmbb r0,v1,1"
475func_check "vcntmbd r0,v1,0"
476func_check "vcntmbd r0,v1,1"
477func_check "vcntmbh r0,v1,0"
478func_check "vcntmbh r0,v1,1"
479func_check "vcntmbw r0,v1,0"
480func_check "vcntmbw r0,v1,1"
481func_check "vctzdm v0,v1,v2"
482func_check "vdivesd v0,v1,v2"
483func_check "vdivesq v0,v1,v2"
484func_check "vdivesw v0,v1,v2"
485func_check "vdiveud v0,v1,v2"
486func_check "vdiveuq v0,v1,v2"
487func_check "vdiveuw v0,v1,v2"
488func_check "vdivsd v0,v1,v2"
489func_check "vdivsq v0,v1,v2"
490func_check "vdivsw v0,v1,v2"
491func_check "vdivud v0,v1,v2"
492func_check "vdivuq v0,v1,v2"
493func_check "vdivuw v0,v1,v2"
494func_check "vexpandbm v0,v1"
495func_check "vexpanddm v0,v1"
496func_check "vexpandhm v0,v1"
497func_check "vexpandqm v0,v1"
498func_check "vexpandwm v0,v1"
499func_check "vextddvlx v0,v1,v2,r3"
500func_check "vextddvrx v0,v1,v2,r3"
501func_check "vextdubvlx v0,v1,v2,r3"
502func_check "vextdubvrx v0,v1,v2,r3"
503func_check "vextduhvlx v0,v1,v2,r3"
504func_check "vextduhvrx v0,v1,v2,r3"
505func_check "vextduwvlx v0,v1,v2,r3"
506func_check "vextduwvrx v0,v1,v2,r3"
507func_check "vextractbm r0,v1"
508func_check "vextractdm r0,v1"
509func_check "vextracthm r0,v1"
510func_check "vextractqm r0,v1"
511func_check "vextractwm r0,v1"
512func_check "vextsd2q v0,v1"
513func_check "vgnb r0,v1,2"
514func_check "vgnb r0,v1,3"
515func_check "vgnb r0,v1,4"
516func_check "vgnb r0,v1,5"
517func_check "vgnb r0,v1,6"
518func_check "vgnb r0,v1,7"
519func_check "vinsblx v0,r1,r2"
520func_check "vinsbrx v0,r1,r2"
521func_check "vinsbvlx v0,r1,v2"
522func_check "vinsbvrx v0,r1,v2"
523func_check "vinsd v0,r1,3"
524func_check "vinsd v0,r1,7"
525func_check "vinsdlx v0,r1,r2"
526func_check "vinsdrx v0,r1,r2"
527func_check "vinshlx v0,r1,r2"
528func_check "vinshrx v0,r1,r2"
529func_check "vinshvlx v0,r1,v2"
530func_check "vinshvrx v0,r1,v2"
531func_check "vinsw v0,r1,3"
532func_check "vinsw v0,r1,7"
533func_check "vinswlx v0,r1,r2"
534func_check "vinswrx v0,r1,r2"
535func_check "vinswvlx v0,r1,v2"
536func_check "vinswvrx v0,r1,v2"
537func_check "vmodsd v0,v1,v2"
538func_check "vmodsq v0,v1,v2"
539func_check "vmodsw v0,v1,v2"
540func_check "vmodud v0,v1,v2"
541func_check "vmoduq v0,v1,v2"
542func_check "vmoduw v0,v1,v2"
543func_check "vmsumcud v0,v1,v2,v3"
544func_check "vmulesd v0,v1,v2"
545func_check "vmuleud v0,v1,v2"
546func_check "vmulhsd v0,v1,v2"
547func_check "vmulhsw v0,v1,v2"
548func_check "vmulhud v0,v1,v2"
549func_check "vmulhuw v0,v1,v2"
550func_check "vmulld v0,v1,v2"
551func_check "vmulosd v0,v1,v2"
552func_check "vmuloud v0,v1,v2"
553func_check "vpdepd v0,v1,v2"
554func_check "vpextd v0,v1,v2"
555func_check "vrlq v0,v1,v2"
556func_check "vrlqmi v0,v1,v2"
557func_check "vrlqnm v0,v1,v2"
558func_check "vsldbi v0,v1,v2,0"
559func_check "vsldbi v0,v1,v2,4"
560func_check "vslq v0,v1,v2"
561func_check "vsraq v0,v1,v2"
562func_check "vsrdbi v0,v1,v2,0"
563func_check "vsrdbi v0,v1,v2,4"
564func_check "vsrq v0,v1,v2"
565func_check "vstribl v0,v1"
566func_check "vstribl. v0,v1"
567func_check "vstribr v0,v1"
568func_check "vstribr. v0,v1"
569func_check "vstrihl v0,v1"
570func_check "vstrihl. v0,v1"
571func_check "vstrihr v0,v1"
572func_check "vstrihr. v0,v1"
573func_check "xscmpeqqp v0,v1,v2"
574func_check "xscmpgeqp v0,v1,v2"
575func_check "xscmpgtqp v0,v1,v2"
576func_check "xscvqpsqz v0,v1"
577func_check "xscvqpuqz v0,v1"
578func_check "xscvsqqp v0,v1"
579func_check "xscvuqqp v0,v1"
580func_check "xsmaxcqp v0,v1,v2"
581func_check "xsmincqp v0,v1,v2"
49977100
CL
582func_check "dmxvbf16ger2 a4,vs0,vs1"
583func_check "dmxvbf16ger2nn a4,vs0,vs1"
584func_check "dmxvbf16ger2np a4,vs0,vs1"
585func_check "dmxvbf16ger2pn a4,vs0,vs1"
586func_check "dmxvbf16ger2pp a4,vs0,vs1"
82d9b280
WS
587func_check "xvcvbf16spn vs0,vs1"
588func_check "xvcvspbf16 vs0,vs1"
49977100
CL
589func_check "dmxvf16ger2 a4,vs0,vs1"
590func_check "dmxvf16ger2nn a4,vs0,vs1"
591func_check "dmxvf16ger2np a4,vs0,vs1"
592func_check "dmxvf16ger2pn a4,vs0,vs1"
593func_check "dmxvf16ger2pp a4,vs0,vs1"
594func_check "dmxvf32ger a4,vs0,vs1"
595func_check "dmxvf32gernn a4,vs0,vs1"
596func_check "dmxvf32gernp a4,vs0,vs1"
597func_check "dmxvf32gerpn a4,vs0,vs1"
598func_check "dmxvf32gerpp a4,vs0,vs1"
599func_check "dmxvf64ger a4,vs22,vs0"
600func_check "dmxvf64gernn a4,vs22,vs0"
601func_check "dmxvf64gernp a4,vs22,vs0"
602func_check "dmxvf64gerpn a4,vs22,vs0"
603func_check "dmxvf64gerpp a4,vs22,vs0"
604func_check "dmxvi16ger2 a4,vs0,vs1"
605func_check "dmxvi16ger2pp a4,vs0,vs1"
606func_check "dmxvi16ger2s a4,vs0,vs1"
607func_check "dmxvi16ger2spp a4,vs0,vs1"
608func_check "dmxvi4ger8 a4,vs0,vs1"
609func_check "dmxvi4ger8pp a4,vs0,vs1"
610func_check "dmxvi8ger4 a4,vs0,vs1"
611func_check "dmxvi8ger4pp a4,vs0,vs1"
612func_check "dmxvi8ger4spp a4,vs0,vs1"
82d9b280
WS
613func_check "xvtlsbb cr3,vs0"
614func_check "xxblendvb vs0,vs1,vs2,vs3"
615func_check "xxblendvd vs0,vs1,vs2,vs3"
616func_check "xxblendvh vs0,vs1,vs2,vs3"
617func_check "xxblendvw vs0,vs1,vs2,vs3"
618func_check "xxeval vs0,vs1,vs2,vs3,0"
619func_check "xxeval vs0,vs1,vs2,vs3,3"
620func_check "xxgenpcvbm vs0,v1,0"
621func_check "xxgenpcvbm vs0,v1,1"
622func_check "xxgenpcvbm vs0,v1,2"
623func_check "xxgenpcvbm vs0,v1,3"
624func_check "xxgenpcvdm vs0,v1,0"
625func_check "xxgenpcvdm vs0,v1,1"
626func_check "xxgenpcvdm vs0,v1,2"
627func_check "xxgenpcvdm vs0,v1,3"
628func_check "xxgenpcvhm vs0,v1,0"
629func_check "xxgenpcvhm vs0,v1,1"
630func_check "xxgenpcvhm vs0,v1,2"
631func_check "xxgenpcvhm vs0,v1,3"
632func_check "xxgenpcvwm vs0,v1,0"
633func_check "xxgenpcvwm vs0,v1,1"
634func_check "xxgenpcvwm vs0,v1,2"
635func_check "xxgenpcvwm vs0,v1,3"
49977100
CL
636func_check "dmxxmfacc a4"
637func_check "dmxxmtacc a4"
82d9b280
WS
638func_check "xxpermx vs0,vs1,vs2,vs3,0"
639func_check "xxpermx vs0,vs1,vs2,vs3,3"
49977100 640func_check "dmsetaccz a4"
82d9b280
WS
641func_check "xxsplti32dx vs0,0,2779096485"
642func_check "xxsplti32dx vs0,0,4294967295"
643func_check "xxsplti32dx vs0,0,127"
644func_check "xxsplti32dx vs0,0,15"
645func_check "xxsplti32dx vs0,0,3"
646func_check "xxsplti32dx vs0,0,31"
647func_check "xxsplti32dx vs0,0,32768"
648func_check "xxsplti32dx vs0,0,63"
649func_check "xxsplti32dx vs0,0,66535"
650func_check "xxsplti32dx vs0,0,7"
651func_check "xxsplti32dx vs0,1,2779096485"
652func_check "xxsplti32dx vs0,1,4294967295"
653func_check "xxsplti32dx vs0,1,127"
654func_check "xxsplti32dx vs0,1,15"
655func_check "xxsplti32dx vs0,1,3"
656func_check "xxsplti32dx vs0,1,31"
657func_check "xxsplti32dx vs0,1,32768"
658func_check "xxsplti32dx vs0,1,63"
659func_check "xxsplti32dx vs0,1,66535"
660func_check "xxsplti32dx vs0,1,7"
661func_check "xxspltidp vs0,0"
662func_check "xxspltidp vs0,8388608"
663func_check "xxspltidp vs0,8388609"
664func_check "xxspltidp vs0,8594245"
665func_check "xxspltidp vs0,16777215"
666func_check "xxspltidp vs0,838860800"
667func_check "xxspltidp vs0,2139095040"
668func_check "xxspltidp vs0,2139095041"
669func_check "xxspltidp vs0,2139300677"
670func_check "xxspltidp vs0,2147483647"
671func_check "xxspltidp vs0,2147483648"
672func_check "xxspltidp vs0,2155872256"
673func_check "xxspltidp vs0,2155872257"
674func_check "xxspltidp vs0,2156077893"
675func_check "xxspltidp vs0,2164260863"
676func_check "xxspltidp vs0,4286578688"
677func_check "xxspltidp vs0,4286578689"
678func_check "xxspltidp vs0,4286784325"
679func_check "xxspltidp vs0,4294967295"
680func_check "xxspltiw vs0,0"
681func_check "xxspltiw vs0,1"
682func_check "xxspltiw vs0,3"
683func_check "xxspltiw vs0,8"