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