np1.h revision 296373
125401Sjb/* Print GOULD NPL instructions for GDB, the GNU debugger.
250476Speter   Copyright 1986, 1987, 1989, 1991 Free Software Foundation, Inc.
31573Srgrimes
41573SrgrimesThis file is part of GDB.
533668Sjb
61573SrgrimesGDB is free software; you can redistribute it and/or modify
7101267Stjrit under the terms of the GNU General Public License as published by
872321Sphantomthe Free Software Foundation; either version 1, or (at your option)
972170Sphantomany later version.
1072170Sphantom
1138333SphkGDB is distributed in the hope that it will be useful,
12101267Stjrbut WITHOUT ANY WARRANTY; without even the implied warranty of
131573SrgrimesMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1425401SjbGNU General Public License for more details.
15101267Stjr
1694616SdesYou should have received a copy of the GNU General Public License
1730447Sbdealong with GDB; see the file COPYING.  If not, write to
1876248Sphantomthe Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
19101253Stjr
2074870Srustruct gld_opcode
2130624Sbde{
2289255Sbde  char *name;
2389255Sbde  unsigned long opcode;
2430624Sbde  unsigned long mask;
2530624Sbde  char *args;
2630624Sbde  int length;
2730624Sbde};
2830624Sbde
2930624Sbde/* We store four bytes of opcode for all opcodes because that
3030624Sbde   is the most any of them need.  The actual length of an instruction
31101253Stjr   is always at least 2 bytes, and at most four.  The length of the
32101267Stjr   instruction is based on the opcode.
3325401Sjb
34   The mask component is a mask saying which bits must match
35   particular opcode in order for an instruction to be an instance
36   of that opcode.
37
38   The args component is a string containing characters
39   that are used to format the arguments to the instruction. */
40
41/* Kinds of operands:
42   r  Register in first field
43   R  Register in second field
44   b  Base register in first field
45   B  Base register in second field
46   v  Vector register in first field
47   V  Vector register in first field
48   A  Optional address register (base register)
49   X  Optional index register
50   I  Immediate data (16bits signed)
51   O  Offset field (16bits signed)
52   h  Offset field (15bits signed)
53   d  Offset field (14bits signed)
54   S  Shift count field
55
56   any other characters are printed as is...
57*/
58
59/* The assembler requires that this array be sorted as follows:
60   all instances of the same mnemonic must be consecutive.
61   All instances of the same mnemonic with the same number of operands
62   must be consecutive.
63 */
64struct gld_opcode gld_opcodes[] =
65{
66{ "lb",		0xb4080000,	0xfc080000,	"r,xOA,X",	4 },
67{ "lnb",	0xb8080000,	0xfc080000,	"r,xOA,X",	4 },
68{ "lbs",	0xec080000,	0xfc080000,	"r,xOA,X",	4 },
69{ "lh",		0xb4000001,	0xfc080001,	"r,xOA,X",	4 },
70{ "lnh",	0xb8000001,	0xfc080001,	"r,xOA,X",	4 },
71{ "lw",		0xb4000000,	0xfc080000,	"r,xOA,X",	4 },
72{ "lnw",	0xb8000000,	0xfc080000,	"r,xOA,X",	4 },
73{ "ld",		0xb4000002,	0xfc080002,	"r,xOA,X",	4 },
74{ "lnd",	0xb8000002,	0xfc080002,	"r,xOA,X",	4 },
75{ "li",		0xf8000000,	0xfc7f0000,	"r,I",		4 },
76{ "lpa",	0x50080000,	0xfc080000,	"r,xOA,X",	4 },
77{ "la",		0x50000000,	0xfc080000,	"r,xOA,X",	4 },
78{ "labr",	0x58080000,	0xfc080000,	"b,xOA,X",	4 },
79{ "lbp",	0x90080000,	0xfc080000,	"r,xOA,X",	4 },
80{ "lhp",	0x90000001,	0xfc080001,	"r,xOA,X",	4 },
81{ "lwp",	0x90000000,	0xfc080000,	"r,xOA,X",	4 },
82{ "ldp",	0x90000002,	0xfc080002,	"r,xOA,X",	4 },
83{ "suabr",	0x58000000,	0xfc080000,	"b,xOA,X",	4 },
84{ "lf",		0xbc000000,	0xfc080000,	"r,xOA,X",	4 },
85{ "lfbr",	0xbc080000,	0xfc080000,	"b,xOA,X",	4 },
86{ "lwbr",	0x5c000000,	0xfc080000,	"b,xOA,X",	4 },
87{ "stb",	0xd4080000,	0xfc080000,	"r,xOA,X",	4 },
88{ "sth",	0xd4000001,	0xfc080001,	"r,xOA,X",	4 },
89{ "stw",	0xd4000000,	0xfc080000,	"r,xOA,X",	4 },
90{ "std",	0xd4000002,	0xfc080002,	"r,xOA,X",	4 },
91{ "stf",	0xdc000000,	0xfc080000,	"r,xOA,X",	4 },
92{ "stfbr",	0xdc080000,	0xfc080000,	"b,xOA,X",	4 },
93{ "stwbr",	0x54000000,	0xfc080000,	"b,xOA,X",	4 },
94{ "zmb",	0xd8080000,	0xfc080000,	"r,xOA,X",	4 },
95{ "zmh",	0xd8000001,	0xfc080001,	"r,xOA,X",	4 },
96{ "zmw",	0xd8000000,	0xfc080000,	"r,xOA,X",	4 },
97{ "zmd",	0xd8000002,	0xfc080002,	"r,xOA,X",	4 },
98{ "stbp",	0x94080000,	0xfc080000,	"r,xOA,X",	4 },
99{ "sthp",	0x94000001,	0xfc080001,	"r,xOA,X",	4 },
100{ "stwp",	0x94000000,	0xfc080000,	"r,xOA,X",	4 },
101{ "stdp",	0x94000002,	0xfc080002,	"r,xOA,X",	4 },
102{ "lil",	0xf80b0000,	0xfc7f0000,	"r,D",		4 },
103{ "lwsl1",	0xec000000,	0xfc080000,	"r,xOA,X",	4 },
104{ "lwsl2",	0xfc000000,	0xfc080000,	"r,xOA,X",	4 },
105{ "lwsl3",	0xfc080000,	0xfc080000,	"r,xOA,X",	4 },
106
107{ "lvb",	0xb0080000,	0xfc080000,	"v,xOA,X",	4 },
108{ "lvh",	0xb0000001,	0xfc080001,	"v,xOA,X",	4 },
109{ "lvw",	0xb0000000,	0xfc080000,	"v,xOA,X",	4 },
110{ "lvd",	0xb0000002,	0xfc080002,	"v,xOA,X",	4 },
111{ "liv",	0x3c040000,	0xfc0f0000,	"v,R",		2 },
112{ "livf",	0x3c080000,	0xfc0f0000,	"v,R",		2 },
113{ "stvb",	0xd0080000,	0xfc080000,	"v,xOA,X",	4 },
114{ "stvh",	0xd0000001,	0xfc080001,	"v,xOA,X",	4 },
115{ "stvw",	0xd0000000,	0xfc080000,	"v,xOA,X",	4 },
116{ "stvd",	0xd0000002,	0xfc080002,	"v,xOA,X",	4 },
117
118{ "trr",	0x2c000000,	0xfc0f0000,	"r,R",		2 },
119{ "trn",	0x2c040000,	0xfc0f0000,	"r,R",		2 },
120{ "trnd",	0x2c0c0000,	0xfc0f0000,	"r,R",		2 },
121{ "trabs",	0x2c010000,	0xfc0f0000,	"r,R",		2 },
122{ "trabsd",	0x2c090000,	0xfc0f0000,	"r,R",		2 },
123{ "trc",	0x2c030000,	0xfc0f0000,	"r,R",		2 },
124{ "xcr",	0x28040000,	0xfc0f0000,	"r,R",		2 },
125{ "cxcr",	0x2c060000,	0xfc0f0000,	"r,R",		2 },
126{ "cxcrd",	0x2c0e0000,	0xfc0f0000,	"r,R",		2 },
127{ "tbrr",	0x2c020000,	0xfc0f0000,	"r,B",		2 },
128{ "trbr",	0x28030000,	0xfc0f0000,	"b,R",		2 },
129{ "xcbr",	0x28020000,	0xfc0f0000,	"b,B",		2 },
130{ "tbrbr",	0x28010000,	0xfc0f0000,	"b,B",		2 },
131
132{ "trvv",	0x28050000,	0xfc0f0000,	"v,V",		2 },
133{ "trvvn",	0x2c050000,	0xfc0f0000,	"v,V",		2 },
134{ "trvvnd",	0x2c0d0000,	0xfc0f0000,	"v,V",		2 },
135{ "trvab",	0x2c070000,	0xfc0f0000,	"v,V",		2 },
136{ "trvabd",	0x2c0f0000,	0xfc0f0000,	"v,V",		2 },
137{ "cmpv",	0x14060000,	0xfc0f0000,	"v,V",		2 },
138{ "expv",	0x14070000,	0xfc0f0000,	"v,V",		2 },
139{ "mrvvlt",	0x10030000,	0xfc0f0000,	"v,V",		2 },
140{ "mrvvle",	0x10040000,	0xfc0f0000,	"v,V",		2 },
141{ "mrvvgt",	0x14030000,	0xfc0f0000,	"v,V",		2 },
142{ "mrvvge",	0x14040000,	0xfc0f0000,	"v,V",		2 },
143{ "mrvveq",	0x10050000,	0xfc0f0000,	"v,V",		2 },
144{ "mrvvne",	0x10050000,	0xfc0f0000,	"v,V",		2 },
145{ "mrvrlt",	0x100d0000,	0xfc0f0000,	"v,R",		2 },
146{ "mrvrle",	0x100e0000,	0xfc0f0000,	"v,R",		2 },
147{ "mrvrgt",	0x140d0000,	0xfc0f0000,	"v,R",		2 },
148{ "mrvrge",	0x140e0000,	0xfc0f0000,	"v,R",		2 },
149{ "mrvreq",	0x100f0000,	0xfc0f0000,	"v,R",		2 },
150{ "mrvrne",	0x140f0000,	0xfc0f0000,	"v,R",		2 },
151{ "trvr",	0x140b0000,	0xfc0f0000,	"r,V",		2 },
152{ "trrv",	0x140c0000,	0xfc0f0000,	"v,R",		2 },
153
154{ "bu",		0x40000000,	0xff880000,	"xOA,X",	4 },
155{ "bns",	0x70080000,	0xff880000,	"xOA,X",	4 },
156{ "bnco",	0x70880000,	0xff880000,	"xOA,X",	4 },
157{ "bge",	0x71080000,	0xff880000,	"xOA,X",	4 },
158{ "bne",	0x71880000,	0xff880000,	"xOA,X",	4 },
159{ "bunge",	0x72080000,	0xff880000,	"xOA,X",	4 },
160{ "bunle",	0x72880000,	0xff880000,	"xOA,X",	4 },
161{ "bgt",	0x73080000,	0xff880000,	"xOA,X",	4 },
162{ "bnany",	0x73880000,	0xff880000,	"xOA,X",	4 },
163{ "bs"	,	0x70000000,	0xff880000,	"xOA,X",	4 },
164{ "bco",	0x70800000,	0xff880000,	"xOA,X",	4 },
165{ "blt",	0x71000000,	0xff880000,	"xOA,X",	4 },
166{ "beq",	0x71800000,	0xff880000,	"xOA,X",	4 },
167{ "buge",	0x72000000,	0xff880000,	"xOA,X",	4 },
168{ "bult",	0x72800000,	0xff880000,	"xOA,X",	4 },
169{ "ble",	0x73000000,	0xff880000,	"xOA,X",	4 },
170{ "bany",	0x73800000,	0xff880000,	"xOA,X",	4 },
171{ "brlnk",	0x44000000,	0xfc080000,	"r,xOA,X",	4 },
172{ "bib",	0x48000000,	0xfc080000,	"r,xOA,X",	4 },
173{ "bih",	0x48080000,	0xfc080000,	"r,xOA,X",	4 },
174{ "biw",	0x4c000000,	0xfc080000,	"r,xOA,X",	4 },
175{ "bid",	0x4c080000,	0xfc080000,	"r,xOA,X",	4 },
176{ "bivb",	0x60000000,	0xfc080000,	"r,xOA,X",	4 },
177{ "bivh",	0x60080000,	0xfc080000,	"r,xOA,X",	4 },
178{ "bivw",	0x64000000,	0xfc080000,	"r,xOA,X",	4 },
179{ "bivd",	0x64080000,	0xfc080000,	"r,xOA,X",	4 },
180{ "bvsb",	0x68000000,	0xfc080000,	"r,xOA,X",	4 },
181{ "bvsh",	0x68080000,	0xfc080000,	"r,xOA,X",	4 },
182{ "bvsw",	0x6c000000,	0xfc080000,	"r,xOA,X",	4 },
183{ "bvsd",	0x6c080000,	0xfc080000,	"r,xOA,X",	4 },
184
185{ "camb",	0x80080000,	0xfc080000,	"r,xOA,X",	4 },
186{ "camh",	0x80000001,	0xfc080001,	"r,xOA,X",	4 },
187{ "camw",	0x80000000,	0xfc080000,	"r,xOA,X",	4 },
188{ "camd",	0x80000002,	0xfc080002,	"r,xOA,X",	4 },
189{ "car",	0x10000000,	0xfc0f0000,	"r,R",		2 },
190{ "card",	0x14000000,	0xfc0f0000,	"r,R",		2 },
191{ "ci",		0xf8050000,	0xfc7f0000,	"r,I",		4 },
192{ "chkbnd",	0x5c080000,	0xfc080000,	"r,xOA,X",	4 },
193
194{ "cavv",	0x10010000,	0xfc0f0000,	"v,V",		2 },
195{ "cavr",	0x10020000,	0xfc0f0000,	"v,R",		2 },
196{ "cavvd",	0x10090000,	0xfc0f0000,	"v,V",		2 },
197{ "cavrd",	0x100b0000,	0xfc0f0000,	"v,R",		2 },
198
199{ "anmb",	0x84080000,	0xfc080000,	"r,xOA,X",	4 },
200{ "anmh",	0x84000001,	0xfc080001,	"r,xOA,X",	4 },
201{ "anmw",	0x84000000,	0xfc080000,	"r,xOA,X",	4 },
202{ "anmd",	0x84000002,	0xfc080002,	"r,xOA,X",	4 },
203{ "anr",	0x04000000,	0xfc0f0000,	"r,R",		2 },
204{ "ani",	0xf8080000,	0xfc7f0000,	"r,I",		4 },
205{ "ormb",	0xb8080000,	0xfc080000,	"r,xOA,X",	4 },
206{ "ormh",	0xb8000001,	0xfc080001,	"r,xOA,X",	4 },
207{ "ormw",	0xb8000000,	0xfc080000,	"r,xOA,X",	4 },
208{ "ormd",	0xb8000002,	0xfc080002,	"r,xOA,X",	4 },
209{ "orr",	0x08000000,	0xfc0f0000,	"r,R",		2 },
210{ "oi",		0xf8090000,	0xfc7f0000,	"r,I",		4 },
211{ "eomb",	0x8c080000,	0xfc080000,	"r,xOA,X",	4 },
212{ "eomh",	0x8c000001,	0xfc080001,	"r,xOA,X",	4 },
213{ "eomw",	0x8c000000,	0xfc080000,	"r,xOA,X",	4 },
214{ "eomd",	0x8c000002,	0xfc080002,	"r,xOA,X",	4 },
215{ "eor",	0x0c000000,	0xfc0f0000,	"r,R",		2 },
216{ "eoi",	0xf80a0000,	0xfc7f0000,	"r,I",		4 },
217
218{ "anvv",	0x04010000,	0xfc0f0000,	"v,V",		2 },
219{ "anvr",	0x04020000,	0xfc0f0000,	"v,R",		2 },
220{ "orvv",	0x08010000,	0xfc0f0000,	"v,V",		2 },
221{ "orvr",	0x08020000,	0xfc0f0000,	"v,R",		2 },
222{ "eovv",	0x0c010000,	0xfc0f0000,	"v,V",		2 },
223{ "eovr",	0x0c020000,	0xfc0f0000,	"v,R",		2 },
224
225{ "sacz",	0x100c0000,	0xfc0f0000,	"r,R",		2 },
226{ "sla",	0x1c400000,	0xfc600000,	"r,S",		2 },
227{ "sll",	0x1c600000,	0xfc600000,	"r,S",		2 },
228{ "slc",	0x24400000,	0xfc600000,	"r,S",		2 },
229{ "slad",	0x20400000,	0xfc600000,	"r,S",		2 },
230{ "slld",	0x20600000,	0xfc600000,	"r,S",		2 },
231{ "sra",	0x1c000000,	0xfc600000,	"r,S",		2 },
232{ "srl",	0x1c200000,	0xfc600000,	"r,S",		2 },
233{ "src",	0x24000000,	0xfc600000,	"r,S",		2 },
234{ "srad",	0x20000000,	0xfc600000,	"r,S",		2 },
235{ "srld",	0x20200000,	0xfc600000,	"r,S",		2 },
236{ "sda",	0x3c030000,	0xfc0f0000,	"r,R",		2 },
237{ "sdl",	0x3c020000,	0xfc0f0000,	"r,R",		2 },
238{ "sdc",	0x3c010000,	0xfc0f0000,	"r,R",		2 },
239{ "sdad",	0x3c0b0000,	0xfc0f0000,	"r,R",		2 },
240{ "sdld",	0x3c0a0000,	0xfc0f0000,	"r,R",		2 },
241
242{ "svda",	0x3c070000,	0xfc0f0000,	"v,R",		2 },
243{ "svdl",	0x3c060000,	0xfc0f0000,	"v,R",		2 },
244{ "svdc",	0x3c050000,	0xfc0f0000,	"v,R",		2 },
245{ "svdad",	0x3c0e0000,	0xfc0f0000,	"v,R",		2 },
246{ "svdld",	0x3c0d0000,	0xfc0f0000,	"v,R",		2 },
247
248{ "sbm",	0xac080000,	0xfc080000,	"f,xOA,X",	4 },
249{ "zbm",	0xac000000,	0xfc080000,	"f,xOA,X",	4 },
250{ "tbm",	0xa8080000,	0xfc080000,	"f,xOA,X",	4 },
251{ "incmb",	0xa0000000,	0xfc080000,	"xOA,X",	4 },
252{ "incmh",	0xa0080000,	0xfc080000,	"xOA,X",	4 },
253{ "incmw",	0xa4000000,	0xfc080000,	"xOA,X",	4 },
254{ "incmd",	0xa4080000,	0xfc080000,	"xOA,X",	4 },
255{ "sbmd",	0x7c080000,	0xfc080000,	"r,xOA,X",	4 },
256{ "zbmd",	0x7c000000,	0xfc080000,	"r,xOA,X",	4 },
257{ "tbmd",	0x78080000,	0xfc080000,	"r,xOA,X",	4 },
258
259{ "ssm",	0x9c080000,	0xfc080000,	"f,xOA,X",	4 },
260{ "zsm",	0x9c000000,	0xfc080000,	"f,xOA,X",	4 },
261{ "tsm",	0x98080000,	0xfc080000,	"f,xOA,X",	4 },
262
263{ "admb",	0xc8080000,	0xfc080000,	"r,xOA,X",	4 },
264{ "admh",	0xc8000001,	0xfc080001,	"r,xOA,X",	4 },
265{ "admw",	0xc8000000,	0xfc080000,	"r,xOA,X",	4 },
266{ "admd",	0xc8000002,	0xfc080002,	"r,xOA,X",	4 },
267{ "adr",	0x38000000,	0xfc0f0000,	"r,R",		2 },
268{ "armb",	0xe8080000,	0xfc080000,	"r,xOA,X",	4 },
269{ "armh",	0xe8000001,	0xfc080001,	"r,xOA,X",	4 },
270{ "armw",	0xe8000000,	0xfc080000,	"r,xOA,X",	4 },
271{ "armd",	0xe8000002,	0xfc080002,	"r,xOA,X",	4 },
272{ "adi",	0xf8010000,	0xfc0f0000,	"r,I",		4 },
273{ "sumb",	0xcc080000,	0xfc080000,	"r,xOA,X",	4 },
274{ "sumh",	0xcc000001,	0xfc080001,	"r,xOA,X",	4 },
275{ "sumw",	0xcc000000,	0xfc080000,	"r,xOA,X",	4 },
276{ "sumd",	0xcc000002,	0xfc080002,	"r,xOA,X",	4 },
277{ "sur",	0x3c000000,	0xfc0f0000,	"r,R",		2 },
278{ "sui",	0xf8020000,	0xfc0f0000,	"r,I",		4 },
279{ "mpmb",	0xc0080000,	0xfc080000,	"r,xOA,X",	4 },
280{ "mpmh",	0xc0000001,	0xfc080001,	"r,xOA,X",	4 },
281{ "mpmw",	0xc0000000,	0xfc080000,	"r,xOA,X",	4 },
282{ "mpr",	0x38020000,	0xfc0f0000,	"r,R",		2 },
283{ "mprd",	0x3c0f0000,	0xfc0f0000,	"r,R",		2 },
284{ "mpi",	0xf8030000,	0xfc0f0000,	"r,I",		4 },
285{ "dvmb",	0xc4080000,	0xfc080000,	"r,xOA,X",	4 },
286{ "dvmh",	0xc4000001,	0xfc080001,	"r,xOA,X",	4 },
287{ "dvmw",	0xc4000000,	0xfc080000,	"r,xOA,X",	4 },
288{ "dvr",	0x380a0000,	0xfc0f0000,	"r,R",		2 },
289{ "dvi",	0xf8040000,	0xfc0f0000,	"r,I",		4 },
290{ "exs",	0x38080000,	0xfc0f0000,	"r,R",		2 },
291
292{ "advv",	0x30000000,	0xfc0f0000,	"v,V",		2 },
293{ "advvd",	0x30080000,	0xfc0f0000,	"v,V",		2 },
294{ "adrv",	0x34000000,	0xfc0f0000,	"v,R",		2 },
295{ "adrvd",	0x34080000,	0xfc0f0000,	"v,R",		2 },
296{ "suvv",	0x30010000,	0xfc0f0000,	"v,V",		2 },
297{ "suvvd",	0x30090000,	0xfc0f0000,	"v,V",		2 },
298{ "surv",	0x34010000,	0xfc0f0000,	"v,R",		2 },
299{ "survd",	0x34090000,	0xfc0f0000,	"v,R",		2 },
300{ "mpvv",	0x30020000,	0xfc0f0000,	"v,V",		2 },
301{ "mprv",	0x34020000,	0xfc0f0000,	"v,R",		2 },
302
303{ "adfw",	0xe0080000,	0xfc080000,	"r,xOA,X",	4 },
304{ "adfd",	0xe0080002,	0xfc080002,	"r,xOA,X",	4 },
305{ "adrfw",	0x38010000,	0xfc0f0000,	"r,R",		2 },
306{ "adrfd",	0x38090000,	0xfc0f0000,	"r,R",		2 },
307{ "surfw",	0xe0000000,	0xfc080000,	"r,xOA,X",	4 },
308{ "surfd",	0xe0000002,	0xfc080002,	"r,xOA,X",	4 },
309{ "surfw",	0x38030000,	0xfc0f0000,	"r,R",		2 },
310{ "surfd",	0x380b0000,	0xfc0f0000,	"r,R",		2 },
311{ "mpfw",	0xe4080000,	0xfc080000,	"r,xOA,X",	4 },
312{ "mpfd",	0xe4080002,	0xfc080002,	"r,xOA,X",	4 },
313{ "mprfw",	0x38060000,	0xfc0f0000,	"r,R",		2 },
314{ "mprfd",	0x380e0000,	0xfc0f0000,	"r,R",		2 },
315{ "rfw",	0xe4000000,	0xfc080000,	"r,xOA,X",	4 },
316{ "rfd",	0xe4000002,	0xfc080002,	"r,xOA,X",	4 },
317{ "rrfw",	0x0c0e0000,	0xfc0f0000,	"r",		2 },
318{ "rrfd",	0x0c0f0000,	0xfc0f0000,	"r",		2 },
319
320{ "advvfw",	0x30040000,	0xfc0f0000,	"v,V",		2 },
321{ "advvfd",	0x300c0000,	0xfc0f0000,	"v,V",		2 },
322{ "adrvfw",	0x34040000,	0xfc0f0000,	"v,R",		2 },
323{ "adrvfd",	0x340c0000,	0xfc0f0000,	"v,R",		2 },
324{ "suvvfw",	0x30050000,	0xfc0f0000,	"v,V",		2 },
325{ "suvvfd",	0x300d0000,	0xfc0f0000,	"v,V",		2 },
326{ "survfw",	0x34050000,	0xfc0f0000,	"v,R",		2 },
327{ "survfd",	0x340d0000,	0xfc0f0000,	"v,R",		2 },
328{ "mpvvfw",	0x30060000,	0xfc0f0000,	"v,V",		2 },
329{ "mpvvfd",	0x300e0000,	0xfc0f0000,	"v,V",		2 },
330{ "mprvfw",	0x34060000,	0xfc0f0000,	"v,R",		2 },
331{ "mprvfd",	0x340e0000,	0xfc0f0000,	"v,R",		2 },
332{ "rvfw",	0x30070000,	0xfc0f0000,	"v",		2 },
333{ "rvfd",	0x300f0000,	0xfc0f0000,	"v",		2 },
334
335{ "fltw",	0x38070000,	0xfc0f0000,	"r,R",		2 },
336{ "fltd",	0x380f0000,	0xfc0f0000,	"r,R",		2 },
337{ "fixw",	0x38050000,	0xfc0f0000,	"r,R",		2 },
338{ "fixd",	0x380d0000,	0xfc0f0000,	"r,R",		2 },
339{ "cfpds",	0x3c090000,	0xfc0f0000,	"r,R",		2 },
340
341{ "fltvw",	0x080d0000,	0xfc0f0000,	"v,V",		2 },
342{ "fltvd",	0x080f0000,	0xfc0f0000,	"v,V",		2 },
343{ "fixvw",	0x080c0000,	0xfc0f0000,	"v,V",		2 },
344{ "fixvd",	0x080e0000,	0xfc0f0000,	"v,V",		2 },
345{ "cfpvds",	0x0c0d0000,	0xfc0f0000,	"v,V",		2 },
346
347{ "orvrn",	0x000a0000,	0xfc0f0000,	"r,V",		2 },
348{ "andvrn",	0x00080000,	0xfc0f0000,	"r,V",		2 },
349{ "frsteq",	0x04090000,	0xfc0f0000,	"r,V",		2 },
350{ "sigma",	0x0c080000,	0xfc0f0000,	"r,V",		2 },
351{ "sigmad",	0x0c0a0000,	0xfc0f0000,	"r,V",		2 },
352{ "sigmf",	0x08080000,	0xfc0f0000,	"r,V",		2 },
353{ "sigmfd",	0x080a0000,	0xfc0f0000,	"r,V",		2 },
354{ "prodf",	0x04080000,	0xfc0f0000,	"r,V",		2 },
355{ "prodfd",	0x040a0000,	0xfc0f0000,	"r,V",		2 },
356{ "maxv",	0x10080000,	0xfc0f0000,	"r,V",		2 },
357{ "maxvd",	0x100a0000,	0xfc0f0000,	"r,V",		2 },
358{ "minv",	0x14080000,	0xfc0f0000,	"r,V",		2 },
359{ "minvd",	0x140a0000,	0xfc0f0000,	"r,V",		2 },
360
361{ "lpsd",	0xf0000000,	0xfc080000,	"xOA,X",	4 },
362{ "ldc",	0xf0080000,	0xfc080000,	"xOA,X",	4 },
363{ "spm",	0x040c0000,	0xfc0f0000,	"r",		2 },
364{ "rpm",	0x040d0000,	0xfc0f0000,	"r",		2 },
365{ "tritr",	0x00070000,	0xfc0f0000,	"r",		2 },
366{ "trrit",	0x00060000,	0xfc0f0000,	"r",		2 },
367{ "rpswt",	0x04080000,	0xfc0f0000,	"r",		2 },
368{ "exr",	0xf8070000,	0xfc0f0000,	"",		4 },
369{ "halt",	0x00000000,	0xfc0f0000,	"",		2 },
370{ "wait",	0x00010000,	0xfc0f0000,	"",		2 },
371{ "nop",	0x00020000,	0xfc0f0000,	"",		2 },
372{ "eiae",	0x00030000,	0xfc0f0000,	"",		2 },
373{ "efae",	0x000d0000,	0xfc0f0000,	"",		2 },
374{ "diae",	0x000e0000,	0xfc0f0000,	"",		2 },
375{ "dfae",	0x000f0000,	0xfc0f0000,	"",		2 },
376{ "spvc",	0xf8060000,	0xfc0f0000,	"r,T,N",	4 },
377{ "rdsts",	0x00090000,	0xfc0f0000,	"r",		2 },
378{ "setcpu",	0x000c0000,	0xfc0f0000,	"r",		2 },
379{ "cmc",	0x000b0000,	0xfc0f0000,	"r",		2 },
380{ "trrcu",	0x00040000,	0xfc0f0000,	"r",		2 },
381{ "attnio",	0x00050000,	0xfc0f0000,	"",		2 },
382{ "fudit",	0x28080000,	0xfc0f0000,	"",		2 },
383{ "break",	0x28090000,	0xfc0f0000,	"",		2 },
384{ "frzss",	0x280a0000,	0xfc0f0000,	"",		2 },
385{ "ripi",	0x04040000,	0xfc0f0000,	"r,R",		2 },
386{ "xcp",	0x04050000,	0xfc0f0000,	"r",		2 },
387{ "block",	0x04060000,	0xfc0f0000,	"",		2 },
388{ "unblock",	0x04070000,	0xfc0f0000,	"",		2 },
389{ "trsc",	0x08060000,	0xfc0f0000,	"r,R",		2 },
390{ "tscr",	0x08070000,	0xfc0f0000,	"r,R",		2 },
391{ "fq",		0x04080000,	0xfc0f0000,	"r",		2 },
392{ "flupte",	0x2c080000,	0xfc0f0000,	"r",		2 },
393{ "rviu",	0x040f0000,	0xfc0f0000,	"",		2 },
394{ "ldel",	0x280c0000,	0xfc0f0000,	"r,R",		2 },
395{ "ldu",	0x280d0000,	0xfc0f0000,	"r,R",		2 },
396{ "stdecc",	0x280b0000,	0xfc0f0000,	"r,R",		2 },
397{ "trpc",	0x08040000,	0xfc0f0000,	"r",		2 },
398{ "tpcr",	0x08050000,	0xfc0f0000,	"r",		2 },
399{ "ghalt",	0x0c050000,	0xfc0f0000,	"r",		2 },
400{ "grun",	0x0c040000,	0xfc0f0000,	"",		2 },
401{ "tmpr",	0x2c0a0000,	0xfc0f0000,	"r,R",		2 },
402{ "trmp",	0x2c0b0000,	0xfc0f0000,	"r,R",		2 },
403
404{ "trrve",	0x28060000,	0xfc0f0000,	"r",		2 },
405{ "trver",	0x28070000,	0xfc0f0000,	"r",		2 },
406{ "trvlr",	0x280f0000,	0xfc0f0000,	"r",		2 },
407
408{ "linkfl",	0x18000000,	0xfc0f0000,	"r,R",		2 },
409{ "linkbl",	0x18020000,	0xfc0f0000,	"r,R",		2 },
410{ "linkfp",	0x18010000,	0xfc0f0000,	"r,R",		2 },
411{ "linkbp",	0x18030000,	0xfc0f0000,	"r,R",		2 },
412{ "linkpl",	0x18040000,	0xfc0f0000,	"r,R",		2 },
413{ "ulinkl",	0x18080000,	0xfc0f0000,	"r,R",		2 },
414{ "ulinkp",	0x18090000,	0xfc0f0000,	"r,R",		2 },
415{ "ulinktl",	0x180a0000,	0xfc0f0000,	"r,R",		2 },
416{ "ulinktp",	0x180b0000,	0xfc0f0000,	"r,R",		2 },
417};
418
419int numopcodes = sizeof(gld_opcodes) / sizeof(gld_opcodes[0]);
420
421struct gld_opcode *endop = gld_opcodes + sizeof(gld_opcodes) /
422		 		sizeof(gld_opcodes[0]);
423