qemu/disas/hppa.c
<<
>>
Prefs
   1/* Disassembler for the PA-RISC. Somewhat derived from sparc-pinsn.c.
   2   Copyright 1989, 1990, 1992, 1993, 1994, 1995, 1998, 1999, 2000, 2001, 2003,
   3   2005 Free Software Foundation, Inc.
   4
   5   Contributed by the Center for Software Science at the
   6   University of Utah (pa-gdb-bugs@cs.utah.edu).
   7
   8   This program is free software; you can redistribute it and/or modify
   9   it under the terms of the GNU General Public License as published by
  10   the Free Software Foundation; either version 2 of the License, or
  11   (at your option) any later version.
  12
  13   This program is distributed in the hope that it will be useful,
  14   but WITHOUT ANY WARRANTY; without even the implied warranty of
  15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16   GNU General Public License for more details.
  17
  18   You should have received a copy of the GNU General Public License
  19   along with this program; if not, see <http://www.gnu.org/licenses/>. */
  20
  21#include "disas/bfd.h"
  22
  23/* HP PA-RISC SOM object file format:  definitions internal to BFD.
  24   Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000,
  25   2003 Free Software Foundation, Inc.
  26
  27   Contributed by the Center for Software Science at the
  28   University of Utah (pa-gdb-bugs@cs.utah.edu).
  29
  30   This file is part of BFD, the Binary File Descriptor library.
  31
  32   This program is free software; you can redistribute it and/or modify
  33   it under the terms of the GNU General Public License as published by
  34   the Free Software Foundation; either version 2 of the License, or
  35   (at your option) any later version.
  36
  37   This program is distributed in the hope that it will be useful,
  38   but WITHOUT ANY WARRANTY; without even the implied warranty of
  39   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  40   GNU General Public License for more details.
  41
  42   You should have received a copy of the GNU General Public License
  43   along with this program; if not, see <http://www.gnu.org/licenses/>.  */
  44
  45#ifndef _LIBHPPA_H
  46#define _LIBHPPA_H
  47
  48#define BYTES_IN_WORD 4
  49#define PA_PAGESIZE 0x1000
  50
  51/* The PA instruction set variants.  */
  52enum pa_arch {pa10 = 10, pa11 = 11, pa20 = 20, pa20w = 25};
  53
  54/* HP PA-RISC relocation types */
  55
  56enum hppa_reloc_field_selector_type
  57  {
  58    R_HPPA_FSEL = 0x0,
  59    R_HPPA_LSSEL = 0x1,
  60    R_HPPA_RSSEL = 0x2,
  61    R_HPPA_LSEL = 0x3,
  62    R_HPPA_RSEL = 0x4,
  63    R_HPPA_LDSEL = 0x5,
  64    R_HPPA_RDSEL = 0x6,
  65    R_HPPA_LRSEL = 0x7,
  66    R_HPPA_RRSEL = 0x8,
  67    R_HPPA_NSEL  = 0x9,
  68    R_HPPA_NLSEL  = 0xa,
  69    R_HPPA_NLRSEL  = 0xb,
  70    R_HPPA_PSEL = 0xc,
  71    R_HPPA_LPSEL = 0xd,
  72    R_HPPA_RPSEL = 0xe,
  73    R_HPPA_TSEL = 0xf,
  74    R_HPPA_LTSEL = 0x10,
  75    R_HPPA_RTSEL = 0x11,
  76    R_HPPA_LTPSEL = 0x12,
  77    R_HPPA_RTPSEL = 0x13
  78  };
  79
  80/* /usr/include/reloc.h defines these to constants.  We want to use
  81   them in enums, so #undef them before we start using them.  We might
  82   be able to fix this another way by simply managing not to include
  83   /usr/include/reloc.h, but currently GDB picks up these defines
  84   somewhere.  */
  85#undef e_fsel
  86#undef e_lssel
  87#undef e_rssel
  88#undef e_lsel
  89#undef e_rsel
  90#undef e_ldsel
  91#undef e_rdsel
  92#undef e_lrsel
  93#undef e_rrsel
  94#undef e_nsel
  95#undef e_nlsel
  96#undef e_nlrsel
  97#undef e_psel
  98#undef e_lpsel
  99#undef e_rpsel
 100#undef e_tsel
 101#undef e_ltsel
 102#undef e_rtsel
 103#undef e_one
 104#undef e_two
 105#undef e_pcrel
 106#undef e_con
 107#undef e_plabel
 108#undef e_abs
 109
 110/* for compatibility */
 111enum hppa_reloc_field_selector_type_alt
 112  {
 113    e_fsel = R_HPPA_FSEL,
 114    e_lssel = R_HPPA_LSSEL,
 115    e_rssel = R_HPPA_RSSEL,
 116    e_lsel = R_HPPA_LSEL,
 117    e_rsel = R_HPPA_RSEL,
 118    e_ldsel = R_HPPA_LDSEL,
 119    e_rdsel = R_HPPA_RDSEL,
 120    e_lrsel = R_HPPA_LRSEL,
 121    e_rrsel = R_HPPA_RRSEL,
 122    e_nsel = R_HPPA_NSEL,
 123    e_nlsel = R_HPPA_NLSEL,
 124    e_nlrsel = R_HPPA_NLRSEL,
 125    e_psel = R_HPPA_PSEL,
 126    e_lpsel = R_HPPA_LPSEL,
 127    e_rpsel = R_HPPA_RPSEL,
 128    e_tsel = R_HPPA_TSEL,
 129    e_ltsel = R_HPPA_LTSEL,
 130    e_rtsel = R_HPPA_RTSEL,
 131    e_ltpsel = R_HPPA_LTPSEL,
 132    e_rtpsel = R_HPPA_RTPSEL
 133  };
 134
 135enum hppa_reloc_expr_type
 136  {
 137    R_HPPA_E_ONE = 0,
 138    R_HPPA_E_TWO = 1,
 139    R_HPPA_E_PCREL = 2,
 140    R_HPPA_E_CON = 3,
 141    R_HPPA_E_PLABEL = 7,
 142    R_HPPA_E_ABS = 18
 143  };
 144
 145/* for compatibility */
 146enum hppa_reloc_expr_type_alt
 147  {
 148    e_one = R_HPPA_E_ONE,
 149    e_two = R_HPPA_E_TWO,
 150    e_pcrel = R_HPPA_E_PCREL,
 151    e_con = R_HPPA_E_CON,
 152    e_plabel = R_HPPA_E_PLABEL,
 153    e_abs = R_HPPA_E_ABS
 154  };
 155
 156
 157/* Relocations for function calls must be accompanied by parameter
 158   relocation bits.  These bits describe exactly where the caller has
 159   placed the function's arguments and where it expects to find a return
 160   value.
 161
 162   Both ELF and SOM encode this information within the addend field
 163   of the call relocation.  (Note this could break very badly if one
 164   was to make a call like bl foo + 0x12345678).
 165
 166   The high order 10 bits contain parameter relocation information,
 167   the low order 22 bits contain the constant offset.  */
 168
 169#define HPPA_R_ARG_RELOC(a)     \
 170  (((a) >> 22) & 0x3ff)
 171#define HPPA_R_CONSTANT(a)      \
 172  ((((bfd_signed_vma)(a)) << (BFD_ARCH_SIZE-22)) >> (BFD_ARCH_SIZE-22))
 173#define HPPA_R_ADDEND(r, c)     \
 174  (((r) << 22) + ((c) & 0x3fffff))
 175
 176
 177/* Some functions to manipulate PA instructions.  */
 178
 179/* Declare the functions with the unused attribute to avoid warnings.  */
 180static inline int sign_extend (int, int) ATTRIBUTE_UNUSED;
 181static inline int low_sign_extend (int, int) ATTRIBUTE_UNUSED;
 182static inline int sign_unext (int, int) ATTRIBUTE_UNUSED;
 183static inline int low_sign_unext (int, int) ATTRIBUTE_UNUSED;
 184static inline int re_assemble_3 (int) ATTRIBUTE_UNUSED;
 185static inline int re_assemble_12 (int) ATTRIBUTE_UNUSED;
 186static inline int re_assemble_14 (int) ATTRIBUTE_UNUSED;
 187static inline int re_assemble_16 (int) ATTRIBUTE_UNUSED;
 188static inline int re_assemble_17 (int) ATTRIBUTE_UNUSED;
 189static inline int re_assemble_21 (int) ATTRIBUTE_UNUSED;
 190static inline int re_assemble_22 (int) ATTRIBUTE_UNUSED;
 191static inline bfd_signed_vma hppa_field_adjust
 192  (bfd_vma, bfd_signed_vma, enum hppa_reloc_field_selector_type_alt)
 193  ATTRIBUTE_UNUSED;
 194static inline int hppa_rebuild_insn (int, int, int) ATTRIBUTE_UNUSED;
 195
 196
 197/* The *sign_extend functions are used to assemble various bitfields
 198   taken from an instruction and return the resulting immediate
 199   value.  */
 200
 201static inline int
 202sign_extend (int x, int len)
 203{
 204  int signbit = (1 << (len - 1));
 205  int mask = (signbit << 1) - 1;
 206  return ((x & mask) ^ signbit) - signbit;
 207}
 208
 209static inline int
 210low_sign_extend (int x, int len)
 211{
 212  return (x >> 1) - ((x & 1) << (len - 1));
 213}
 214
 215
 216/* The re_assemble_* functions prepare an immediate value for
 217   insertion into an opcode. pa-risc uses all sorts of weird bitfields
 218   in the instruction to hold the value.  */
 219
 220static inline int
 221sign_unext (int x, int len)
 222{
 223  int len_ones;
 224
 225  len_ones = (1 << len) - 1;
 226
 227  return x & len_ones;
 228}
 229
 230static inline int
 231low_sign_unext (int x, int len)
 232{
 233  int temp;
 234  int sign;
 235
 236  sign = (x >> (len-1)) & 1;
 237
 238  temp = sign_unext (x, len-1);
 239
 240  return (temp << 1) | sign;
 241}
 242
 243static inline int
 244re_assemble_3 (int as3)
 245{
 246  return ((  (as3 & 4) << (13-2))
 247          | ((as3 & 3) << (13+1)));
 248}
 249
 250static inline int
 251re_assemble_12 (int as12)
 252{
 253  return ((  (as12 & 0x800) >> 11)
 254          | ((as12 & 0x400) >> (10 - 2))
 255          | ((as12 & 0x3ff) << (1 + 2)));
 256}
 257
 258static inline int
 259re_assemble_14 (int as14)
 260{
 261  return ((  (as14 & 0x1fff) << 1)
 262          | ((as14 & 0x2000) >> 13));
 263}
 264
 265static inline int
 266re_assemble_16 (int as16)
 267{
 268  int s, t;
 269
 270  /* Unusual 16-bit encoding, for wide mode only.  */
 271  t = (as16 << 1) & 0xffff;
 272  s = (as16 & 0x8000);
 273  return (t ^ s ^ (s >> 1)) | (s >> 15);
 274}
 275
 276static inline int
 277re_assemble_17 (int as17)
 278{
 279  return ((  (as17 & 0x10000) >> 16)
 280          | ((as17 & 0x0f800) << (16 - 11))
 281          | ((as17 & 0x00400) >> (10 - 2))
 282          | ((as17 & 0x003ff) << (1 + 2)));
 283}
 284
 285static inline int
 286re_assemble_21 (int as21)
 287{
 288  return ((  (as21 & 0x100000) >> 20)
 289          | ((as21 & 0x0ffe00) >> 8)
 290          | ((as21 & 0x000180) << 7)
 291          | ((as21 & 0x00007c) << 14)
 292          | ((as21 & 0x000003) << 12));
 293}
 294
 295static inline int
 296re_assemble_22 (int as22)
 297{
 298  return ((  (as22 & 0x200000) >> 21)
 299          | ((as22 & 0x1f0000) << (21 - 16))
 300          | ((as22 & 0x00f800) << (16 - 11))
 301          | ((as22 & 0x000400) >> (10 - 2))
 302          | ((as22 & 0x0003ff) << (1 + 2)));
 303}
 304
 305
 306/* Handle field selectors for PA instructions.
 307   The L and R (and LS, RS etc.) selectors are used in pairs to form a
 308   full 32 bit address.  eg.
 309
 310   LDIL L'start,%r1             ; put left part into r1
 311   LDW  R'start(%r1),%r2        ; add r1 and right part to form address
 312
 313   This function returns sign extended values in all cases.
 314*/
 315
 316static inline bfd_signed_vma
 317hppa_field_adjust (bfd_vma sym_val,
 318                   bfd_signed_vma addend,
 319                   enum hppa_reloc_field_selector_type_alt r_field)
 320{
 321  bfd_signed_vma value;
 322
 323  value = sym_val + addend;
 324  switch (r_field)
 325    {
 326    case e_fsel:
 327      /* F: No change.  */
 328      break;
 329
 330    case e_nsel:
 331      /* N: null selector.  I don't really understand what this is all
 332         about, but HP's documentation says "this indicates that zero
 333         bits are to be used for the displacement on the instruction.
 334         This fixup is used to identify three-instruction sequences to
 335         access data (for importing shared library data)."  */
 336      value = 0;
 337      break;
 338
 339    case e_lsel:
 340    case e_nlsel:
 341      /* L:  Select top 21 bits.  */
 342      value = value >> 11;
 343      break;
 344
 345    case e_rsel:
 346      /* R:  Select bottom 11 bits.  */
 347      value = value & 0x7ff;
 348      break;
 349
 350    case e_lssel:
 351      /* LS:  Round to nearest multiple of 2048 then select top 21 bits.  */
 352      value = value + 0x400;
 353      value = value >> 11;
 354      break;
 355
 356    case e_rssel:
 357      /* RS:  Select bottom 11 bits for LS.
 358         We need to return a value such that 2048 * LS'x + RS'x == x.
 359         ie. RS'x = x - ((x + 0x400) & -0x800)
 360         this is just a sign extension from bit 21.  */
 361      value = ((value & 0x7ff) ^ 0x400) - 0x400;
 362      break;
 363
 364    case e_ldsel:
 365      /* LD:  Round to next multiple of 2048 then select top 21 bits.
 366         Yes, if we are already on a multiple of 2048, we go up to the
 367         next one.  RD in this case will be -2048.  */
 368      value = value + 0x800;
 369      value = value >> 11;
 370      break;
 371
 372    case e_rdsel:
 373      /* RD:  Set bits 0-20 to one.  */
 374      value = value | -0x800;
 375      break;
 376
 377    case e_lrsel:
 378    case e_nlrsel:
 379      /* LR:  L with rounding of the addend to nearest 8k.  */
 380      value = sym_val + ((addend + 0x1000) & -0x2000);
 381      value = value >> 11;
 382      break;
 383
 384    case e_rrsel:
 385      /* RR:  R with rounding of the addend to nearest 8k.
 386         We need to return a value such that 2048 * LR'x + RR'x == x
 387         ie. RR'x = s+a - (s + (((a + 0x1000) & -0x2000) & -0x800))
 388         .        = s+a - ((s & -0x800) + ((a + 0x1000) & -0x2000))
 389         .        = (s & 0x7ff) + a - ((a + 0x1000) & -0x2000)  */
 390      value = (sym_val & 0x7ff) + (((addend & 0x1fff) ^ 0x1000) - 0x1000);
 391      break;
 392
 393    default:
 394      abort ();
 395    }
 396  return value;
 397}
 398
 399/* PA-RISC OPCODES */
 400#define get_opcode(insn)        (((insn) >> 26) & 0x3f)
 401
 402enum hppa_opcode_type
 403{
 404  /* None of the opcodes in the first group generate relocs, so we
 405     aren't too concerned about them.  */
 406  OP_SYSOP   = 0x00,
 407  OP_MEMMNG  = 0x01,
 408  OP_ALU     = 0x02,
 409  OP_NDXMEM  = 0x03,
 410  OP_SPOP    = 0x04,
 411  OP_DIAG    = 0x05,
 412  OP_FMPYADD = 0x06,
 413  OP_UNDEF07 = 0x07,
 414  OP_COPRW   = 0x09,
 415  OP_COPRDW  = 0x0b,
 416  OP_COPR    = 0x0c,
 417  OP_FLOAT   = 0x0e,
 418  OP_PRDSPEC = 0x0f,
 419  OP_UNDEF15 = 0x15,
 420  OP_UNDEF1d = 0x1d,
 421  OP_FMPYSUB = 0x26,
 422  OP_FPFUSED = 0x2e,
 423  OP_SHEXDP0 = 0x34,
 424  OP_SHEXDP1 = 0x35,
 425  OP_SHEXDP2 = 0x36,
 426  OP_UNDEF37 = 0x37,
 427  OP_SHEXDP3 = 0x3c,
 428  OP_SHEXDP4 = 0x3d,
 429  OP_MULTMED = 0x3e,
 430  OP_UNDEF3f = 0x3f,
 431
 432  OP_LDIL    = 0x08,
 433  OP_ADDIL   = 0x0a,
 434
 435  OP_LDO     = 0x0d,
 436  OP_LDB     = 0x10,
 437  OP_LDH     = 0x11,
 438  OP_LDW     = 0x12,
 439  OP_LDWM    = 0x13,
 440  OP_STB     = 0x18,
 441  OP_STH     = 0x19,
 442  OP_STW     = 0x1a,
 443  OP_STWM    = 0x1b,
 444
 445  OP_LDD     = 0x14,
 446  OP_STD     = 0x1c,
 447
 448  OP_FLDW    = 0x16,
 449  OP_LDWL    = 0x17,
 450  OP_FSTW    = 0x1e,
 451  OP_STWL    = 0x1f,
 452
 453  OP_COMBT   = 0x20,
 454  OP_COMIBT  = 0x21,
 455  OP_COMBF   = 0x22,
 456  OP_COMIBF  = 0x23,
 457  OP_CMPBDT  = 0x27,
 458  OP_ADDBT   = 0x28,
 459  OP_ADDIBT  = 0x29,
 460  OP_ADDBF   = 0x2a,
 461  OP_ADDIBF  = 0x2b,
 462  OP_CMPBDF  = 0x2f,
 463  OP_BVB     = 0x30,
 464  OP_BB      = 0x31,
 465  OP_MOVB    = 0x32,
 466  OP_MOVIB   = 0x33,
 467  OP_CMPIBD  = 0x3b,
 468
 469  OP_COMICLR = 0x24,
 470  OP_SUBI    = 0x25,
 471  OP_ADDIT   = 0x2c,
 472  OP_ADDI    = 0x2d,
 473
 474  OP_BE      = 0x38,
 475  OP_BLE     = 0x39,
 476  OP_BL      = 0x3a
 477};
 478
 479
 480/* Insert VALUE into INSN using R_FORMAT to determine exactly what
 481   bits to change.  */
 482
 483static inline int
 484hppa_rebuild_insn (int insn, int value, int r_format)
 485{
 486  switch (r_format)
 487    {
 488    case 11:
 489      return (insn & ~ 0x7ff) | low_sign_unext (value, 11);
 490
 491    case 12:
 492      return (insn & ~ 0x1ffd) | re_assemble_12 (value);
 493
 494
 495    case 10:
 496      return (insn & ~ 0x3ff1) | re_assemble_14 (value & -8);
 497
 498    case -11:
 499      return (insn & ~ 0x3ff9) | re_assemble_14 (value & -4);
 500
 501    case 14:
 502      return (insn & ~ 0x3fff) | re_assemble_14 (value);
 503
 504
 505    case -10:
 506      return (insn & ~ 0xfff1) | re_assemble_16 (value & -8);
 507
 508    case -16:
 509      return (insn & ~ 0xfff9) | re_assemble_16 (value & -4);
 510
 511    case 16:
 512      return (insn & ~ 0xffff) | re_assemble_16 (value);
 513
 514
 515    case 17:
 516      return (insn & ~ 0x1f1ffd) | re_assemble_17 (value);
 517
 518    case 21:
 519      return (insn & ~ 0x1fffff) | re_assemble_21 (value);
 520
 521    case 22:
 522      return (insn & ~ 0x3ff1ffd) | re_assemble_22 (value);
 523
 524    case 32:
 525      return value;
 526
 527    default:
 528      abort ();
 529    }
 530  return insn;
 531}
 532
 533#endif /* _LIBHPPA_H */
 534/* Table of opcodes for the PA-RISC.
 535   Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000,
 536   2001, 2002, 2003, 2004, 2005
 537   Free Software Foundation, Inc.
 538
 539   Contributed by the Center for Software Science at the
 540   University of Utah (pa-gdb-bugs@cs.utah.edu).
 541
 542This file is part of GAS, the GNU Assembler, and GDB, the GNU disassembler.
 543
 544GAS/GDB is free software; you can redistribute it and/or modify
 545it under the terms of the GNU General Public License as published by
 546the Free Software Foundation; either version 1, or (at your option)
 547any later version.
 548
 549GAS/GDB is distributed in the hope that it will be useful,
 550but WITHOUT ANY WARRANTY; without even the implied warranty of
 551MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 552GNU General Public License for more details.
 553
 554You should have received a copy of the GNU General Public License
 555along with GAS or GDB; see the file COPYING.
 556If not, see <http://www.gnu.org/licenses/>. */
 557
 558#if !defined(__STDC__) && !defined(const)
 559#define const
 560#endif
 561
 562/*
 563 * Structure of an opcode table entry.
 564 */
 565
 566/* There are two kinds of delay slot nullification: normal which is
 567 * controlled by the nullification bit, and conditional, which depends
 568 * on the direction of the branch and its success or failure.
 569 *
 570 * NONE is unfortunately #defined in the hiux system include files.
 571 * #undef it away.
 572 */
 573#undef NONE
 574struct pa_opcode
 575{
 576    const char *name;
 577    unsigned long int match;    /* Bits that must be set...  */
 578    unsigned long int mask;     /* ... in these bits. */
 579    const char *args;
 580    enum pa_arch arch;
 581    char flags;
 582};
 583
 584/* Enables strict matching.  Opcodes with match errors are skipped
 585   when this bit is set.  */
 586#define FLAG_STRICT 0x1
 587
 588/*
 589   All hppa opcodes are 32 bits.
 590
 591   The match component is a mask saying which bits must match a
 592   particular opcode in order for an instruction to be an instance
 593   of that opcode.
 594
 595   The args component is a string containing one character for each operand of
 596   the instruction.  Characters used as a prefix allow any second character to
 597   be used without conflicting with the main operand characters.
 598
 599   Bit positions in this description follow HP usage of lsb = 31,
 600   "at" is lsb of field.
 601
 602   In the args field, the following characters must match exactly:
 603
 604        '+,() '
 605
 606   In the args field, the following characters are unused:
 607
 608        '  "         -  /   34 6789:;    '
 609        '@  C         M             [\]  '
 610        '`    e g                     }  '
 611
 612   Here are all the characters:
 613
 614        ' !"#$%&'()*+-,./0123456789:;<=>?'
 615        '@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_'
 616        '`abcdefghijklmnopqrstuvwxyz{|}~ '
 617
 618Kinds of operands:
 619   x    integer register field at 15.
 620   b    integer register field at 10.
 621   t    integer register field at 31.
 622   a    integer register field at 10 and 15 (for PERMH)
 623   5    5 bit immediate at 15.
 624   s    2 bit space specifier at 17.
 625   S    3 bit space specifier at 18.
 626   V    5 bit immediate value at 31
 627   i    11 bit immediate value at 31
 628   j    14 bit immediate value at 31
 629   k    21 bit immediate value at 31
 630   l    16 bit immediate value at 31 (wide mode only, unusual encoding).
 631   n    nullification for branch instructions
 632   N    nullification for spop and copr instructions
 633   w    12 bit branch displacement
 634   W    17 bit branch displacement (PC relative)
 635   X    22 bit branch displacement (PC relative)
 636   z    17 bit branch displacement (just a number, not an address)
 637
 638Also these:
 639
 640   .    2 bit shift amount at 25
 641   *    4 bit shift amount at 25
 642   p    5 bit shift count at 26 (to support the SHD instruction) encoded as
 643        31-p
 644   ~    6 bit shift count at 20,22:26 encoded as 63-~.
 645   P    5 bit bit position at 26
 646   q    6 bit bit position at 20,22:26
 647   T    5 bit field length at 31 (encoded as 32-T)
 648   %    6 bit field length at 23,27:31 (variable extract/deposit)
 649   |    6 bit field length at 19,27:31 (fixed extract/deposit)
 650   A    13 bit immediate at 18 (to support the BREAK instruction)
 651   ^    like b, but describes a control register
 652   !    sar (cr11) register
 653   D    26 bit immediate at 31 (to support the DIAG instruction)
 654   $    9 bit immediate at 28 (to support POPBTS)
 655
 656   v    3 bit Special Function Unit identifier at 25
 657   O    20 bit Special Function Unit operation split between 15 bits at 20
 658        and 5 bits at 31
 659   o    15 bit Special Function Unit operation at 20
 660   2    22 bit Special Function Unit operation split between 17 bits at 20
 661        and 5 bits at 31
 662   1    15 bit Special Function Unit operation split between 10 bits at 20
 663        and 5 bits at 31
 664   0    10 bit Special Function Unit operation split between 5 bits at 20
 665        and 5 bits at 31
 666   u    3 bit coprocessor unit identifier at 25
 667   F    Source Floating Point Operand Format Completer encoded 2 bits at 20
 668   I    Source Floating Point Operand Format Completer encoded 1 bits at 20
 669        (for 0xe format FP instructions)
 670   G    Destination Floating Point Operand Format Completer encoded 2 bits at 18
 671   H    Floating Point Operand Format at 26 for 'fmpyadd' and 'fmpysub'
 672        (very similar to 'F')
 673
 674   r    5 bit immediate value at 31 (for the break instruction)
 675        (very similar to V above, except the value is unsigned instead of
 676        low_sign_ext)
 677   R    5 bit immediate value at 15 (for the ssm, rsm, probei instructions)
 678        (same as r above, except the value is in a different location)
 679   U    10 bit immediate value at 15 (for SSM, RSM on pa2.0)
 680   Q    5 bit immediate value at 10 (a bit position specified in
 681        the bb instruction. It's the same as r above, except the
 682        value is in a different location)
 683   B    5 bit immediate value at 10 (a bit position specified in
 684        the bb instruction. Similar to Q, but 64 bit handling is
 685        different.
 686   Z    %r1 -- implicit target of addil instruction.
 687   L    ,%r2 completer for new syntax branch
 688   {    Source format completer for fcnv
 689   _    Destination format completer for fcnv
 690   h    cbit for fcmp
 691   =    gfx tests for ftest
 692   d    14 bit offset for single precision FP long load/store.
 693   #    14 bit offset for double precision FP load long/store.
 694   J    Yet another 14 bit offset for load/store with ma,mb completers.
 695   K    Yet another 14 bit offset for load/store with ma,mb completers.
 696   y    16 bit offset for word aligned load/store (PA2.0 wide).
 697   &    16 bit offset for dword aligned load/store (PA2.0 wide).
 698   <    16 bit offset for load/store with ma,mb completers (PA2.0 wide).
 699   >    16 bit offset for load/store with ma,mb completers (PA2.0 wide).
 700   Y    %sr0,%r31 -- implicit target of be,l instruction.
 701   @    implicit immediate value of 0
 702
 703Completer operands all have 'c' as the prefix:
 704
 705   cx   indexed load and store completer.
 706   cX   indexed load and store completer.  Like cx, but emits a space
 707        after in disassembler.
 708   cm   short load and store completer.
 709   cM   short load and store completer.  Like cm, but emits a space
 710        after in disassembler.
 711   cq   long load and store completer (like cm, but inserted into a
 712        different location in the target instruction).
 713   cs   store bytes short completer.
 714   cA   store bytes short completer.  Like cs, but emits a space
 715        after in disassembler.
 716   ce   long load/store completer for LDW/STW with a different encoding
 717        than the others
 718   cc   load cache control hint
 719   cd   load and clear cache control hint
 720   cC   store cache control hint
 721   co   ordered access
 722
 723   cp   branch link and push completer
 724   cP   branch pop completer
 725   cl   branch link completer
 726   cg   branch gate completer
 727
 728   cw   read/write completer for PROBE
 729   cW   wide completer for MFCTL
 730   cL   local processor completer for cache control
 731   cZ   System Control Completer (to support LPA, LHA, etc.)
 732
 733   ci   correction completer for DCOR
 734   ca   add completer
 735   cy   32 bit add carry completer
 736   cY   64 bit add carry completer
 737   cv   signed overflow trap completer
 738   ct   trap on condition completer for ADDI, SUB
 739   cT   trap on condition completer for UADDCM
 740   cb   32 bit borrow completer for SUB
 741   cB   64 bit borrow completer for SUB
 742
 743   ch   left/right half completer
 744   cH   signed/unsigned saturation completer
 745   cS   signed/unsigned completer at 21
 746   cz   zero/sign extension completer.
 747   c*   permutation completer
 748
 749Condition operands all have '?' as the prefix:
 750
 751   ?f   Floating point compare conditions (encoded as 5 bits at 31)
 752
 753   ?a   add conditions
 754   ?A   64 bit add conditions
 755   ?@   add branch conditions followed by nullify
 756   ?d   non-negated add branch conditions
 757   ?D   negated add branch conditions
 758   ?w   wide mode non-negated add branch conditions
 759   ?W   wide mode negated add branch conditions
 760
 761   ?s   compare/subtract conditions
 762   ?S   64 bit compare/subtract conditions
 763   ?t   non-negated compare and branch conditions
 764   ?n   32 bit compare and branch conditions followed by nullify
 765   ?N   64 bit compare and branch conditions followed by nullify
 766   ?Q   64 bit compare and branch conditions for CMPIB instruction
 767
 768   ?l   logical conditions
 769   ?L   64 bit logical conditions
 770
 771   ?b   branch on bit conditions
 772   ?B   64 bit branch on bit conditions
 773
 774   ?x   shift/extract/deposit conditions
 775   ?X   64 bit shift/extract/deposit conditions
 776   ?y   shift/extract/deposit conditions followed by nullify for conditional
 777        branches
 778
 779   ?u   unit conditions
 780   ?U   64 bit unit conditions
 781
 782Floating point registers all have 'f' as a prefix:
 783
 784   ft   target register at 31
 785   fT   target register with L/R halves at 31
 786   fa   operand 1 register at 10
 787   fA   operand 1 register with L/R halves at 10
 788   fX   Same as fA, except prints a space before register during disasm
 789   fb   operand 2 register at 15
 790   fB   operand 2 register with L/R halves at 15
 791   fC   operand 3 register with L/R halves at 16:18,21:23
 792   fe   Like fT, but encoding is different.
 793   fE   Same as fe, except prints a space before register during disasm.
 794   fx   target register at 15 (only for PA 2.0 long format FLDD/FSTD).
 795
 796Float registers for fmpyadd and fmpysub:
 797
 798   fi   mult operand 1 register at 10
 799   fj   mult operand 2 register at 15
 800   fk   mult target register at 20
 801   fl   add/sub operand register at 25
 802   fm   add/sub target register at 31
 803
 804*/
 805
 806
 807#if 0
 808/* List of characters not to put a space after.  Note that
 809   "," is included, as the "spopN" operations use literal
 810   commas in their completer sections.  */
 811static const char *const completer_chars = ",CcY<>?!@+&U~FfGHINnOoZMadu|/=0123%e$m}";
 812#endif
 813
 814/* The order of the opcodes in this table is significant:
 815
 816   * The assembler requires that all instances of the same mnemonic be
 817     consecutive.  If they aren't, the assembler will bomb at runtime.
 818
 819   * Immediate fields use pa_get_absolute_expression to parse the
 820     string.  It will generate a "bad expression" error if passed
 821     a register name.  Thus, register index variants of an opcode
 822     need to precede immediate variants.
 823
 824   * The disassembler does not care about the order of the opcodes
 825     except in cases where implicit addressing is used.
 826
 827   Here are the rules for ordering the opcodes of a mnemonic:
 828
 829   1) Opcodes with FLAG_STRICT should precede opcodes without
 830      FLAG_STRICT.
 831
 832   2) Opcodes with FLAG_STRICT should be ordered as follows:
 833      register index opcodes, short immediate opcodes, and finally
 834      long immediate opcodes.  When both pa10 and pa11 variants
 835      of the same opcode are available, the pa10 opcode should
 836      come first for correct architectural promotion.
 837
 838   3) When implicit addressing is available for an opcode, the
 839      implicit opcode should precede the explicit opcode.
 840
 841   4) Opcodes without FLAG_STRICT should be ordered as follows:
 842      register index opcodes, long immediate opcodes, and finally
 843      short immediate opcodes.  */
 844
 845static const struct pa_opcode pa_opcodes[] =
 846{
 847
 848/* Pseudo-instructions.  */
 849
 850{ "ldi",        0x34000000, 0xffe00000, "l,x", pa20w, 0},/* ldo val(r0),r */
 851{ "ldi",        0x34000000, 0xffe0c000, "j,x", pa10, 0},/* ldo val(r0),r */
 852
 853{ "cmpib",      0xec000000, 0xfc000000, "?Qn5,b,w", pa20, FLAG_STRICT},
 854{ "cmpib",      0x84000000, 0xf4000000, "?nn5,b,w", pa10, FLAG_STRICT},
 855{ "comib",      0x84000000, 0xfc000000, "?nn5,b,w", pa10, 0}, /* comib{tf}*/
 856/* This entry is for the disassembler only.  It will never be used by
 857   assembler.  */
 858{ "comib",      0x8c000000, 0xfc000000, "?nn5,b,w", pa10, 0}, /* comib{tf}*/
 859{ "cmpb",       0x9c000000, 0xdc000000, "?Nnx,b,w", pa20, FLAG_STRICT},
 860{ "cmpb",       0x80000000, 0xf4000000, "?nnx,b,w", pa10, FLAG_STRICT},
 861{ "comb",       0x80000000, 0xfc000000, "?nnx,b,w", pa10, 0}, /* comb{tf} */
 862/* This entry is for the disassembler only.  It will never be used by
 863   assembler.  */
 864{ "comb",       0x88000000, 0xfc000000, "?nnx,b,w", pa10, 0}, /* comb{tf} */
 865{ "addb",       0xa0000000, 0xf4000000, "?Wnx,b,w", pa20w, FLAG_STRICT},
 866{ "addb",       0xa0000000, 0xfc000000, "?@nx,b,w", pa10, 0}, /* addb{tf} */
 867/* This entry is for the disassembler only.  It will never be used by
 868   assembler.  */
 869{ "addb",       0xa8000000, 0xfc000000, "?@nx,b,w", pa10, 0},
 870{ "addib",      0xa4000000, 0xf4000000, "?Wn5,b,w", pa20w, FLAG_STRICT},
 871{ "addib",      0xa4000000, 0xfc000000, "?@n5,b,w", pa10, 0}, /* addib{tf}*/
 872/* This entry is for the disassembler only.  It will never be used by
 873   assembler.  */
 874{ "addib",      0xac000000, 0xfc000000, "?@n5,b,w", pa10, 0}, /* addib{tf}*/
 875{ "nop",        0x08000240, 0xffffffff, "", pa10, 0},      /* or 0,0,0 */
 876{ "copy",       0x08000240, 0xffe0ffe0, "x,t", pa10, 0},   /* or r,0,t */
 877{ "mtsar",      0x01601840, 0xffe0ffff, "x", pa10, 0}, /* mtctl r,cr11 */
 878
 879/* Loads and Stores for integer registers.  */
 880
 881{ "ldd",        0x0c0000c0, 0xfc00d3c0, "cxccx(b),t", pa20, FLAG_STRICT},
 882{ "ldd",        0x0c0000c0, 0xfc0013c0, "cxccx(s,b),t", pa20, FLAG_STRICT},
 883{ "ldd",        0x0c0010e0, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
 884{ "ldd",        0x0c0010e0, 0xfc1f33e0, "cocc@(s,b),t", pa20, FLAG_STRICT},
 885{ "ldd",        0x0c0010c0, 0xfc00d3c0, "cmcc5(b),t", pa20, FLAG_STRICT},
 886{ "ldd",        0x0c0010c0, 0xfc0013c0, "cmcc5(s,b),t", pa20, FLAG_STRICT},
 887{ "ldd",        0x50000000, 0xfc000002, "cq&(b),x", pa20w, FLAG_STRICT},
 888{ "ldd",        0x50000000, 0xfc00c002, "cq#(b),x", pa20, FLAG_STRICT},
 889{ "ldd",        0x50000000, 0xfc000002, "cq#(s,b),x", pa20, FLAG_STRICT},
 890{ "ldw",        0x0c000080, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 891{ "ldw",        0x0c000080, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 892{ "ldw",        0x0c000080, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 893{ "ldw",        0x0c000080, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 894{ "ldw",        0x0c0010a0, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
 895{ "ldw",        0x0c0010a0, 0xfc1f33e0, "cocc@(s,b),t", pa20, FLAG_STRICT},
 896{ "ldw",        0x0c001080, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
 897{ "ldw",        0x0c001080, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
 898{ "ldw",        0x0c001080, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
 899{ "ldw",        0x0c001080, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
 900{ "ldw",        0x4c000000, 0xfc000000, "ce<(b),x", pa20w, FLAG_STRICT},
 901{ "ldw",        0x5c000004, 0xfc000006, "ce>(b),x", pa20w, FLAG_STRICT},
 902{ "ldw",        0x48000000, 0xfc000000, "l(b),x", pa20w, FLAG_STRICT},
 903{ "ldw",        0x5c000004, 0xfc00c006, "ceK(b),x", pa20, FLAG_STRICT},
 904{ "ldw",        0x5c000004, 0xfc000006, "ceK(s,b),x", pa20, FLAG_STRICT},
 905{ "ldw",        0x4c000000, 0xfc00c000, "ceJ(b),x", pa10, FLAG_STRICT},
 906{ "ldw",        0x4c000000, 0xfc000000, "ceJ(s,b),x", pa10, FLAG_STRICT},
 907{ "ldw",        0x48000000, 0xfc00c000, "j(b),x", pa10, 0},
 908{ "ldw",        0x48000000, 0xfc000000, "j(s,b),x", pa10, 0},
 909{ "ldh",        0x0c000040, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 910{ "ldh",        0x0c000040, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 911{ "ldh",        0x0c000040, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 912{ "ldh",        0x0c000040, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 913{ "ldh",        0x0c001060, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
 914{ "ldh",        0x0c001060, 0xfc1f33e0, "cocc@(s,b),t", pa20, FLAG_STRICT},
 915{ "ldh",        0x0c001040, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
 916{ "ldh",        0x0c001040, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
 917{ "ldh",        0x0c001040, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
 918{ "ldh",        0x0c001040, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
 919{ "ldh",        0x44000000, 0xfc000000, "l(b),x", pa20w, FLAG_STRICT},
 920{ "ldh",        0x44000000, 0xfc00c000, "j(b),x", pa10, 0},
 921{ "ldh",        0x44000000, 0xfc000000, "j(s,b),x", pa10, 0},
 922{ "ldb",        0x0c000000, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 923{ "ldb",        0x0c000000, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 924{ "ldb",        0x0c000000, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 925{ "ldb",        0x0c000000, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 926{ "ldb",        0x0c001020, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
 927{ "ldb",        0x0c001020, 0xfc1f33e0, "cocc@(s,b),t", pa20, FLAG_STRICT},
 928{ "ldb",        0x0c001000, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
 929{ "ldb",        0x0c001000, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
 930{ "ldb",        0x0c001000, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
 931{ "ldb",        0x0c001000, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
 932{ "ldb",        0x40000000, 0xfc000000, "l(b),x", pa20w, FLAG_STRICT},
 933{ "ldb",        0x40000000, 0xfc00c000, "j(b),x", pa10, 0},
 934{ "ldb",        0x40000000, 0xfc000000, "j(s,b),x", pa10, 0},
 935{ "std",        0x0c0012e0, 0xfc00f3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
 936{ "std",        0x0c0012e0, 0xfc0033ff, "cocCx,@(s,b)", pa20, FLAG_STRICT},
 937{ "std",        0x0c0012c0, 0xfc00d3c0, "cmcCx,V(b)", pa20, FLAG_STRICT},
 938{ "std",        0x0c0012c0, 0xfc0013c0, "cmcCx,V(s,b)", pa20, FLAG_STRICT},
 939{ "std",        0x70000000, 0xfc000002, "cqx,&(b)", pa20w, FLAG_STRICT},
 940{ "std",        0x70000000, 0xfc00c002, "cqx,#(b)", pa20, FLAG_STRICT},
 941{ "std",        0x70000000, 0xfc000002, "cqx,#(s,b)", pa20, FLAG_STRICT},
 942{ "stw",        0x0c0012a0, 0xfc00f3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
 943{ "stw",        0x0c0012a0, 0xfc0033ff, "cocCx,@(s,b)", pa20, FLAG_STRICT},
 944{ "stw",        0x0c001280, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
 945{ "stw",        0x0c001280, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
 946{ "stw",        0x0c001280, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
 947{ "stw",        0x0c001280, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
 948{ "stw",        0x6c000000, 0xfc000000, "cex,<(b)", pa20w, FLAG_STRICT},
 949{ "stw",        0x7c000004, 0xfc000006, "cex,>(b)", pa20w, FLAG_STRICT},
 950{ "stw",        0x68000000, 0xfc000000, "x,l(b)", pa20w, FLAG_STRICT},
 951{ "stw",        0x7c000004, 0xfc00c006, "cex,K(b)", pa20, FLAG_STRICT},
 952{ "stw",        0x7c000004, 0xfc000006, "cex,K(s,b)", pa20, FLAG_STRICT},
 953{ "stw",        0x6c000000, 0xfc00c000, "cex,J(b)", pa10, FLAG_STRICT},
 954{ "stw",        0x6c000000, 0xfc000000, "cex,J(s,b)", pa10, FLAG_STRICT},
 955{ "stw",        0x68000000, 0xfc00c000, "x,j(b)", pa10, 0},
 956{ "stw",        0x68000000, 0xfc000000, "x,j(s,b)", pa10, 0},
 957{ "sth",        0x0c001260, 0xfc00f3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
 958{ "sth",        0x0c001260, 0xfc0033ff, "cocCx,@(s,b)", pa20, FLAG_STRICT},
 959{ "sth",        0x0c001240, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
 960{ "sth",        0x0c001240, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
 961{ "sth",        0x0c001240, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
 962{ "sth",        0x0c001240, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
 963{ "sth",        0x64000000, 0xfc000000, "x,l(b)", pa20w, FLAG_STRICT},
 964{ "sth",        0x64000000, 0xfc00c000, "x,j(b)", pa10, 0},
 965{ "sth",        0x64000000, 0xfc000000, "x,j(s,b)", pa10, 0},
 966{ "stb",        0x0c001220, 0xfc00f3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
 967{ "stb",        0x0c001220, 0xfc0033ff, "cocCx,@(s,b)", pa20, FLAG_STRICT},
 968{ "stb",        0x0c001200, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
 969{ "stb",        0x0c001200, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
 970{ "stb",        0x0c001200, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
 971{ "stb",        0x0c001200, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
 972{ "stb",        0x60000000, 0xfc000000, "x,l(b)", pa20w, FLAG_STRICT},
 973{ "stb",        0x60000000, 0xfc00c000, "x,j(b)", pa10, 0},
 974{ "stb",        0x60000000, 0xfc000000, "x,j(s,b)", pa10, 0},
 975{ "ldwm",       0x4c000000, 0xfc00c000, "j(b),x", pa10, 0},
 976{ "ldwm",       0x4c000000, 0xfc000000, "j(s,b),x", pa10, 0},
 977{ "stwm",       0x6c000000, 0xfc00c000, "x,j(b)", pa10, 0},
 978{ "stwm",       0x6c000000, 0xfc000000, "x,j(s,b)", pa10, 0},
 979{ "ldwx",       0x0c000080, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 980{ "ldwx",       0x0c000080, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 981{ "ldwx",       0x0c000080, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 982{ "ldwx",       0x0c000080, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 983{ "ldwx",       0x0c000080, 0xfc00dfc0, "cXx(b),t", pa10, 0},
 984{ "ldwx",       0x0c000080, 0xfc001fc0, "cXx(s,b),t", pa10, 0},
 985{ "ldhx",       0x0c000040, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 986{ "ldhx",       0x0c000040, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 987{ "ldhx",       0x0c000040, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 988{ "ldhx",       0x0c000040, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 989{ "ldhx",       0x0c000040, 0xfc00dfc0, "cXx(b),t", pa10, 0},
 990{ "ldhx",       0x0c000040, 0xfc001fc0, "cXx(s,b),t", pa10, 0},
 991{ "ldbx",       0x0c000000, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 992{ "ldbx",       0x0c000000, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
 993{ "ldbx",       0x0c000000, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 994{ "ldbx",       0x0c000000, 0xfc0013c0, "cxccx(s,b),t", pa11, FLAG_STRICT},
 995{ "ldbx",       0x0c000000, 0xfc00dfc0, "cXx(b),t", pa10, 0},
 996{ "ldbx",       0x0c000000, 0xfc001fc0, "cXx(s,b),t", pa10, 0},
 997{ "ldwa",       0x0c000180, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
 998{ "ldwa",       0x0c000180, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
 999{ "ldwa",       0x0c0011a0, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
1000{ "ldwa",       0x0c001180, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1001{ "ldwa",       0x0c001180, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
1002{ "ldcw",       0x0c0001c0, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
1003{ "ldcw",       0x0c0001c0, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
1004{ "ldcw",       0x0c0001c0, 0xfc00d3c0, "cxcdx(b),t", pa11, FLAG_STRICT},
1005{ "ldcw",       0x0c0001c0, 0xfc0013c0, "cxcdx(s,b),t", pa11, FLAG_STRICT},
1006{ "ldcw",       0x0c0011c0, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1007{ "ldcw",       0x0c0011c0, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
1008{ "ldcw",       0x0c0011c0, 0xfc00d3c0, "cmcd5(b),t", pa11, FLAG_STRICT},
1009{ "ldcw",       0x0c0011c0, 0xfc0013c0, "cmcd5(s,b),t", pa11, FLAG_STRICT},
1010{ "stwa",       0x0c0013a0, 0xfc00d3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
1011{ "stwa",       0x0c001380, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
1012{ "stwa",       0x0c001380, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
1013{ "stby",       0x0c001300, 0xfc00dfc0, "cAx,V(b)", pa10, FLAG_STRICT},
1014{ "stby",       0x0c001300, 0xfc001fc0, "cAx,V(s,b)", pa10, FLAG_STRICT},
1015{ "stby",       0x0c001300, 0xfc00d3c0, "cscCx,V(b)", pa11, FLAG_STRICT},
1016{ "stby",       0x0c001300, 0xfc0013c0, "cscCx,V(s,b)", pa11, FLAG_STRICT},
1017{ "ldda",       0x0c000100, 0xfc00d3c0, "cxccx(b),t", pa20, FLAG_STRICT},
1018{ "ldda",       0x0c001120, 0xfc1ff3e0, "cocc@(b),t", pa20, FLAG_STRICT},
1019{ "ldda",       0x0c001100, 0xfc00d3c0, "cmcc5(b),t", pa20, FLAG_STRICT},
1020{ "ldcd",       0x0c000140, 0xfc00d3c0, "cxcdx(b),t", pa20, FLAG_STRICT},
1021{ "ldcd",       0x0c000140, 0xfc0013c0, "cxcdx(s,b),t", pa20, FLAG_STRICT},
1022{ "ldcd",       0x0c001140, 0xfc00d3c0, "cmcd5(b),t", pa20, FLAG_STRICT},
1023{ "ldcd",       0x0c001140, 0xfc0013c0, "cmcd5(s,b),t", pa20, FLAG_STRICT},
1024{ "stda",       0x0c0013e0, 0xfc00f3ff, "cocCx,@(b)", pa20, FLAG_STRICT},
1025{ "stda",       0x0c0013c0, 0xfc00d3c0, "cmcCx,V(b)", pa20, FLAG_STRICT},
1026{ "ldwax",      0x0c000180, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
1027{ "ldwax",      0x0c000180, 0xfc00d3c0, "cxccx(b),t", pa11, FLAG_STRICT},
1028{ "ldwax",      0x0c000180, 0xfc00dfc0, "cXx(b),t", pa10, 0},
1029{ "ldcwx",      0x0c0001c0, 0xfc00dfc0, "cXx(b),t", pa10, FLAG_STRICT},
1030{ "ldcwx",      0x0c0001c0, 0xfc001fc0, "cXx(s,b),t", pa10, FLAG_STRICT},
1031{ "ldcwx",      0x0c0001c0, 0xfc00d3c0, "cxcdx(b),t", pa11, FLAG_STRICT},
1032{ "ldcwx",      0x0c0001c0, 0xfc0013c0, "cxcdx(s,b),t", pa11, FLAG_STRICT},
1033{ "ldcwx",      0x0c0001c0, 0xfc00dfc0, "cXx(b),t", pa10, 0},
1034{ "ldcwx",      0x0c0001c0, 0xfc001fc0, "cXx(s,b),t", pa10, 0},
1035{ "ldws",       0x0c001080, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1036{ "ldws",       0x0c001080, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
1037{ "ldws",       0x0c001080, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
1038{ "ldws",       0x0c001080, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
1039{ "ldws",       0x0c001080, 0xfc00dfc0, "cM5(b),t", pa10, 0},
1040{ "ldws",       0x0c001080, 0xfc001fc0, "cM5(s,b),t", pa10, 0},
1041{ "ldhs",       0x0c001040, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1042{ "ldhs",       0x0c001040, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
1043{ "ldhs",       0x0c001040, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
1044{ "ldhs",       0x0c001040, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
1045{ "ldhs",       0x0c001040, 0xfc00dfc0, "cM5(b),t", pa10, 0},
1046{ "ldhs",       0x0c001040, 0xfc001fc0, "cM5(s,b),t", pa10, 0},
1047{ "ldbs",       0x0c001000, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1048{ "ldbs",       0x0c001000, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
1049{ "ldbs",       0x0c001000, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
1050{ "ldbs",       0x0c001000, 0xfc0013c0, "cmcc5(s,b),t", pa11, FLAG_STRICT},
1051{ "ldbs",       0x0c001000, 0xfc00dfc0, "cM5(b),t", pa10, 0},
1052{ "ldbs",       0x0c001000, 0xfc001fc0, "cM5(s,b),t", pa10, 0},
1053{ "ldwas",      0x0c001180, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1054{ "ldwas",      0x0c001180, 0xfc00d3c0, "cmcc5(b),t", pa11, FLAG_STRICT},
1055{ "ldwas",      0x0c001180, 0xfc00dfc0, "cM5(b),t", pa10, 0},
1056{ "ldcws",      0x0c0011c0, 0xfc00dfc0, "cM5(b),t", pa10, FLAG_STRICT},
1057{ "ldcws",      0x0c0011c0, 0xfc001fc0, "cM5(s,b),t", pa10, FLAG_STRICT},
1058{ "ldcws",      0x0c0011c0, 0xfc00d3c0, "cmcd5(b),t", pa11, FLAG_STRICT},
1059{ "ldcws",      0x0c0011c0, 0xfc0013c0, "cmcd5(s,b),t", pa11, FLAG_STRICT},
1060{ "ldcws",      0x0c0011c0, 0xfc00dfc0, "cM5(b),t", pa10, 0},
1061{ "ldcws",      0x0c0011c0, 0xfc001fc0, "cM5(s,b),t", pa10, 0},
1062{ "stws",       0x0c001280, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
1063{ "stws",       0x0c001280, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
1064{ "stws",       0x0c001280, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
1065{ "stws",       0x0c001280, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
1066{ "stws",       0x0c001280, 0xfc00dfc0, "cMx,V(b)", pa10, 0},
1067{ "stws",       0x0c001280, 0xfc001fc0, "cMx,V(s,b)", pa10, 0},
1068{ "sths",       0x0c001240, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
1069{ "sths",       0x0c001240, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
1070{ "sths",       0x0c001240, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
1071{ "sths",       0x0c001240, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
1072{ "sths",       0x0c001240, 0xfc00dfc0, "cMx,V(b)", pa10, 0},
1073{ "sths",       0x0c001240, 0xfc001fc0, "cMx,V(s,b)", pa10, 0},
1074{ "stbs",       0x0c001200, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
1075{ "stbs",       0x0c001200, 0xfc001fc0, "cMx,V(s,b)", pa10, FLAG_STRICT},
1076{ "stbs",       0x0c001200, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
1077{ "stbs",       0x0c001200, 0xfc0013c0, "cmcCx,V(s,b)", pa11, FLAG_STRICT},
1078{ "stbs",       0x0c001200, 0xfc00dfc0, "cMx,V(b)", pa10, 0},
1079{ "stbs",       0x0c001200, 0xfc001fc0, "cMx,V(s,b)", pa10, 0},
1080{ "stwas",      0x0c001380, 0xfc00dfc0, "cMx,V(b)", pa10, FLAG_STRICT},
1081{ "stwas",      0x0c001380, 0xfc00d3c0, "cmcCx,V(b)", pa11, FLAG_STRICT},
1082{ "stwas",      0x0c001380, 0xfc00dfc0, "cMx,V(b)", pa10, 0},
1083{ "stdby",      0x0c001340, 0xfc00d3c0, "cscCx,V(b)", pa20, FLAG_STRICT},
1084{ "stdby",      0x0c001340, 0xfc0013c0, "cscCx,V(s,b)", pa20, FLAG_STRICT},
1085{ "stbys",      0x0c001300, 0xfc00dfc0, "cAx,V(b)", pa10, FLAG_STRICT},
1086{ "stbys",      0x0c001300, 0xfc001fc0, "cAx,V(s,b)", pa10, FLAG_STRICT},
1087{ "stbys",      0x0c001300, 0xfc00d3c0, "cscCx,V(b)", pa11, FLAG_STRICT},
1088{ "stbys",      0x0c001300, 0xfc0013c0, "cscCx,V(s,b)", pa11, FLAG_STRICT},
1089{ "stbys",      0x0c001300, 0xfc00dfc0, "cAx,V(b)", pa10, 0},
1090{ "stbys",      0x0c001300, 0xfc001fc0, "cAx,V(s,b)", pa10, 0},
1091
1092/* Immediate instructions.  */
1093{ "ldo",        0x34000000, 0xfc000000, "l(b),x", pa20w, 0},
1094{ "ldo",        0x34000000, 0xfc00c000, "j(b),x", pa10, 0},
1095{ "ldil",       0x20000000, 0xfc000000, "k,b", pa10, 0},
1096{ "addil",      0x28000000, 0xfc000000, "k,b,Z", pa10, 0},
1097{ "addil",      0x28000000, 0xfc000000, "k,b", pa10, 0},
1098
1099/* Branching instructions.  */
1100{ "b",          0xe8008000, 0xfc00e000, "cpnXL", pa20, FLAG_STRICT},
1101{ "b",          0xe800a000, 0xfc00e000, "clnXL", pa20, FLAG_STRICT},
1102{ "b",          0xe8000000, 0xfc00e000, "clnW,b", pa10, FLAG_STRICT},
1103{ "b",          0xe8002000, 0xfc00e000, "cgnW,b", pa10, FLAG_STRICT},
1104{ "b",          0xe8000000, 0xffe0e000, "nW", pa10, 0},  /* b,l foo,r0 */
1105{ "bl",         0xe8000000, 0xfc00e000, "nW,b", pa10, 0},
1106{ "gate",       0xe8002000, 0xfc00e000, "nW,b", pa10, 0},
1107{ "blr",        0xe8004000, 0xfc00e001, "nx,b", pa10, 0},
1108{ "bv",         0xe800c000, 0xfc00fffd, "nx(b)", pa10, 0},
1109{ "bv",         0xe800c000, 0xfc00fffd, "n(b)", pa10, 0},
1110{ "bve",        0xe800f001, 0xfc1ffffd, "cpn(b)L", pa20, FLAG_STRICT},
1111{ "bve",        0xe800f000, 0xfc1ffffd, "cln(b)L", pa20, FLAG_STRICT},
1112{ "bve",        0xe800d001, 0xfc1ffffd, "cPn(b)", pa20, FLAG_STRICT},
1113{ "bve",        0xe800d000, 0xfc1ffffd, "n(b)", pa20, FLAG_STRICT},
1114{ "be",         0xe4000000, 0xfc000000, "clnz(S,b),Y", pa10, FLAG_STRICT},
1115{ "be",         0xe4000000, 0xfc000000, "clnz(b),Y", pa10, FLAG_STRICT},
1116{ "be",         0xe0000000, 0xfc000000, "nz(S,b)", pa10, 0},
1117{ "be",         0xe0000000, 0xfc000000, "nz(b)", pa10, 0},
1118{ "ble",        0xe4000000, 0xfc000000, "nz(S,b)", pa10, 0},
1119{ "movb",       0xc8000000, 0xfc000000, "?ynx,b,w", pa10, 0},
1120{ "movib",      0xcc000000, 0xfc000000, "?yn5,b,w", pa10, 0},
1121{ "combt",      0x80000000, 0xfc000000, "?tnx,b,w", pa10, 0},
1122{ "combf",      0x88000000, 0xfc000000, "?tnx,b,w", pa10, 0},
1123{ "comibt",     0x84000000, 0xfc000000, "?tn5,b,w", pa10, 0},
1124{ "comibf",     0x8c000000, 0xfc000000, "?tn5,b,w", pa10, 0},
1125{ "addbt",      0xa0000000, 0xfc000000, "?dnx,b,w", pa10, 0},
1126{ "addbf",      0xa8000000, 0xfc000000, "?dnx,b,w", pa10, 0},
1127{ "addibt",     0xa4000000, 0xfc000000, "?dn5,b,w", pa10, 0},
1128{ "addibf",     0xac000000, 0xfc000000, "?dn5,b,w", pa10, 0},
1129{ "bb",         0xc0004000, 0xffe06000, "?bnx,!,w", pa10, FLAG_STRICT},
1130{ "bb",         0xc0006000, 0xffe06000, "?Bnx,!,w", pa20, FLAG_STRICT},
1131{ "bb",         0xc4004000, 0xfc006000, "?bnx,Q,w", pa10, FLAG_STRICT},
1132{ "bb",         0xc4004000, 0xfc004000, "?Bnx,B,w", pa20, FLAG_STRICT},
1133{ "bvb",        0xc0004000, 0xffe04000, "?bnx,w", pa10, 0},
1134{ "clrbts",     0xe8004005, 0xffffffff, "", pa20, FLAG_STRICT},
1135{ "popbts",     0xe8004005, 0xfffff007, "$", pa20, FLAG_STRICT},
1136{ "pushnom",    0xe8004001, 0xffffffff, "", pa20, FLAG_STRICT},
1137{ "pushbts",    0xe8004001, 0xffe0ffff, "x", pa20, FLAG_STRICT},
1138
1139/* Computation Instructions.  */
1140
1141{ "cmpclr",     0x080008a0, 0xfc000fe0, "?Sx,b,t", pa20, FLAG_STRICT},
1142{ "cmpclr",     0x08000880, 0xfc000fe0, "?sx,b,t", pa10, FLAG_STRICT},
1143{ "comclr",     0x08000880, 0xfc000fe0, "?sx,b,t", pa10, 0},
1144{ "or",         0x08000260, 0xfc000fe0, "?Lx,b,t", pa20, FLAG_STRICT},
1145{ "or",         0x08000240, 0xfc000fe0, "?lx,b,t", pa10, 0},
1146{ "xor",        0x080002a0, 0xfc000fe0, "?Lx,b,t", pa20, FLAG_STRICT},
1147{ "xor",        0x08000280, 0xfc000fe0, "?lx,b,t", pa10, 0},
1148{ "and",        0x08000220, 0xfc000fe0, "?Lx,b,t", pa20, FLAG_STRICT},
1149{ "and",        0x08000200, 0xfc000fe0, "?lx,b,t", pa10, 0},
1150{ "andcm",      0x08000020, 0xfc000fe0, "?Lx,b,t", pa20, FLAG_STRICT},
1151{ "andcm",      0x08000000, 0xfc000fe0, "?lx,b,t", pa10, 0},
1152{ "uxor",       0x080003a0, 0xfc000fe0, "?Ux,b,t", pa20, FLAG_STRICT},
1153{ "uxor",       0x08000380, 0xfc000fe0, "?ux,b,t", pa10, 0},
1154{ "uaddcm",     0x080009a0, 0xfc000fa0, "cT?Ux,b,t", pa20, FLAG_STRICT},
1155{ "uaddcm",     0x08000980, 0xfc000fa0, "cT?ux,b,t", pa10, FLAG_STRICT},
1156{ "uaddcm",     0x08000980, 0xfc000fe0, "?ux,b,t", pa10, 0},
1157{ "uaddcmt",    0x080009c0, 0xfc000fe0, "?ux,b,t", pa10, 0},
1158{ "dcor",       0x08000ba0, 0xfc1f0fa0, "ci?Ub,t", pa20, FLAG_STRICT},
1159{ "dcor",       0x08000b80, 0xfc1f0fa0, "ci?ub,t", pa10, FLAG_STRICT},
1160{ "dcor",       0x08000b80, 0xfc1f0fe0, "?ub,t",   pa10, 0},
1161{ "idcor",      0x08000bc0, 0xfc1f0fe0, "?ub,t",   pa10, 0},
1162{ "addi",       0xb0000000, 0xfc000000, "ct?ai,b,x", pa10, FLAG_STRICT},
1163{ "addi",       0xb4000000, 0xfc000000, "cv?ai,b,x", pa10, FLAG_STRICT},
1164{ "addi",       0xb4000000, 0xfc000800, "?ai,b,x", pa10, 0},
1165{ "addio",      0xb4000800, 0xfc000800, "?ai,b,x", pa10, 0},
1166{ "addit",      0xb0000000, 0xfc000800, "?ai,b,x", pa10, 0},
1167{ "addito",     0xb0000800, 0xfc000800, "?ai,b,x", pa10, 0},
1168{ "add",        0x08000720, 0xfc0007e0, "cY?Ax,b,t", pa20, FLAG_STRICT},
1169{ "add",        0x08000700, 0xfc0007e0, "cy?ax,b,t", pa10, FLAG_STRICT},
1170{ "add",        0x08000220, 0xfc0003e0, "ca?Ax,b,t", pa20, FLAG_STRICT},
1171{ "add",        0x08000200, 0xfc0003e0, "ca?ax,b,t", pa10, FLAG_STRICT},
1172{ "add",        0x08000600, 0xfc000fe0, "?ax,b,t", pa10, 0},
1173{ "addl",       0x08000a00, 0xfc000fe0, "?ax,b,t", pa10, 0},
1174{ "addo",       0x08000e00, 0xfc000fe0, "?ax,b,t", pa10, 0},
1175{ "addc",       0x08000700, 0xfc000fe0, "?ax,b,t", pa10, 0},
1176{ "addco",      0x08000f00, 0xfc000fe0, "?ax,b,t", pa10, 0},
1177{ "sub",        0x080004e0, 0xfc0007e0, "ct?Sx,b,t", pa20, FLAG_STRICT},
1178{ "sub",        0x080004c0, 0xfc0007e0, "ct?sx,b,t", pa10, FLAG_STRICT},
1179{ "sub",        0x08000520, 0xfc0007e0, "cB?Sx,b,t", pa20, FLAG_STRICT},
1180{ "sub",        0x08000500, 0xfc0007e0, "cb?sx,b,t", pa10, FLAG_STRICT},
1181{ "sub",        0x08000420, 0xfc0007e0, "cv?Sx,b,t", pa20, FLAG_STRICT},
1182{ "sub",        0x08000400, 0xfc0007e0, "cv?sx,b,t", pa10, FLAG_STRICT},
1183{ "sub",        0x08000400, 0xfc000fe0, "?sx,b,t", pa10, 0},
1184{ "subo",       0x08000c00, 0xfc000fe0, "?sx,b,t", pa10, 0},
1185{ "subb",       0x08000500, 0xfc000fe0, "?sx,b,t", pa10, 0},
1186{ "subbo",      0x08000d00, 0xfc000fe0, "?sx,b,t", pa10, 0},
1187{ "subt",       0x080004c0, 0xfc000fe0, "?sx,b,t", pa10, 0},
1188{ "subto",      0x08000cc0, 0xfc000fe0, "?sx,b,t", pa10, 0},
1189{ "ds",         0x08000440, 0xfc000fe0, "?sx,b,t", pa10, 0},
1190{ "subi",       0x94000000, 0xfc000000, "cv?si,b,x", pa10, FLAG_STRICT},
1191{ "subi",       0x94000000, 0xfc000800, "?si,b,x", pa10, 0},
1192{ "subio",      0x94000800, 0xfc000800, "?si,b,x", pa10, 0},
1193{ "cmpiclr",    0x90000800, 0xfc000800, "?Si,b,x", pa20, FLAG_STRICT},
1194{ "cmpiclr",    0x90000000, 0xfc000800, "?si,b,x", pa10, FLAG_STRICT},
1195{ "comiclr",    0x90000000, 0xfc000800, "?si,b,x", pa10, 0},
1196{ "shladd",     0x08000220, 0xfc000320, "ca?Ax,.,b,t", pa20, FLAG_STRICT},
1197{ "shladd",     0x08000200, 0xfc000320, "ca?ax,.,b,t", pa10, FLAG_STRICT},
1198{ "sh1add",     0x08000640, 0xfc000fe0, "?ax,b,t", pa10, 0},
1199{ "sh1addl",    0x08000a40, 0xfc000fe0, "?ax,b,t", pa10, 0},
1200{ "sh1addo",    0x08000e40, 0xfc000fe0, "?ax,b,t", pa10, 0},
1201{ "sh2add",     0x08000680, 0xfc000fe0, "?ax,b,t", pa10, 0},
1202{ "sh2addl",    0x08000a80, 0xfc000fe0, "?ax,b,t", pa10, 0},
1203{ "sh2addo",    0x08000e80, 0xfc000fe0, "?ax,b,t", pa10, 0},
1204{ "sh3add",     0x080006c0, 0xfc000fe0, "?ax,b,t", pa10, 0},
1205{ "sh3addl",    0x08000ac0, 0xfc000fe0, "?ax,b,t", pa10, 0},
1206{ "sh3addo",    0x08000ec0, 0xfc000fe0, "?ax,b,t", pa10, 0},
1207
1208/* Subword Operation Instructions.  */
1209
1210{ "hadd",       0x08000300, 0xfc00ff20, "cHx,b,t", pa20, FLAG_STRICT},
1211{ "havg",       0x080002c0, 0xfc00ffe0, "x,b,t", pa20, FLAG_STRICT},
1212{ "hshl",       0xf8008800, 0xffe0fc20, "x,*,t", pa20, FLAG_STRICT},
1213{ "hshladd",    0x08000700, 0xfc00ff20, "x,.,b,t", pa20, FLAG_STRICT},
1214{ "hshr",       0xf800c800, 0xfc1ff820, "cSb,*,t", pa20, FLAG_STRICT},
1215{ "hshradd",    0x08000500, 0xfc00ff20, "x,.,b,t", pa20, FLAG_STRICT},
1216{ "hsub",       0x08000100, 0xfc00ff20, "cHx,b,t", pa20, FLAG_STRICT},
1217{ "mixh",       0xf8008400, 0xfc009fe0, "chx,b,t", pa20, FLAG_STRICT},
1218{ "mixw",       0xf8008000, 0xfc009fe0, "chx,b,t", pa20, FLAG_STRICT},
1219{ "permh",      0xf8000000, 0xfc009020, "c*a,t", pa20, FLAG_STRICT},
1220
1221
1222/* Extract and Deposit Instructions.  */
1223
1224{ "shrpd",      0xd0000200, 0xfc001fe0, "?Xx,b,!,t", pa20, FLAG_STRICT},
1225{ "shrpd",      0xd0000400, 0xfc001400, "?Xx,b,~,t", pa20, FLAG_STRICT},
1226{ "shrpw",      0xd0000000, 0xfc001fe0, "?xx,b,!,t", pa10, FLAG_STRICT},
1227{ "shrpw",      0xd0000800, 0xfc001c00, "?xx,b,p,t", pa10, FLAG_STRICT},
1228{ "vshd",       0xd0000000, 0xfc001fe0, "?xx,b,t", pa10, 0},
1229{ "shd",        0xd0000800, 0xfc001c00, "?xx,b,p,t", pa10, 0},
1230{ "extrd",      0xd0001200, 0xfc001ae0, "cS?Xb,!,%,x", pa20, FLAG_STRICT},
1231{ "extrd",      0xd8000000, 0xfc000000, "cS?Xb,q,|,x", pa20, FLAG_STRICT},
1232{ "extrw",      0xd0001000, 0xfc001be0, "cS?xb,!,T,x", pa10, FLAG_STRICT},
1233{ "extrw",      0xd0001800, 0xfc001800, "cS?xb,P,T,x", pa10, FLAG_STRICT},
1234{ "vextru",     0xd0001000, 0xfc001fe0, "?xb,T,x", pa10, 0},
1235{ "vextrs",     0xd0001400, 0xfc001fe0, "?xb,T,x", pa10, 0},
1236{ "extru",      0xd0001800, 0xfc001c00, "?xb,P,T,x", pa10, 0},
1237{ "extrs",      0xd0001c00, 0xfc001c00, "?xb,P,T,x", pa10, 0},
1238{ "depd",       0xd4000200, 0xfc001ae0, "cz?Xx,!,%,b", pa20, FLAG_STRICT},
1239{ "depd",       0xf0000000, 0xfc000000, "cz?Xx,~,|,b", pa20, FLAG_STRICT},
1240{ "depdi",      0xd4001200, 0xfc001ae0, "cz?X5,!,%,b", pa20, FLAG_STRICT},
1241{ "depdi",      0xf4000000, 0xfc000000, "cz?X5,~,|,b", pa20, FLAG_STRICT},
1242{ "depw",       0xd4000000, 0xfc001be0, "cz?xx,!,T,b", pa10, FLAG_STRICT},
1243{ "depw",       0xd4000800, 0xfc001800, "cz?xx,p,T,b", pa10, FLAG_STRICT},
1244{ "depwi",      0xd4001000, 0xfc001be0, "cz?x5,!,T,b", pa10, FLAG_STRICT},
1245{ "depwi",      0xd4001800, 0xfc001800, "cz?x5,p,T,b", pa10, FLAG_STRICT},
1246{ "zvdep",      0xd4000000, 0xfc001fe0, "?xx,T,b", pa10, 0},
1247{ "vdep",       0xd4000400, 0xfc001fe0, "?xx,T,b", pa10, 0},
1248{ "zdep",       0xd4000800, 0xfc001c00, "?xx,p,T,b", pa10, 0},
1249{ "dep",        0xd4000c00, 0xfc001c00, "?xx,p,T,b", pa10, 0},
1250{ "zvdepi",     0xd4001000, 0xfc001fe0, "?x5,T,b", pa10, 0},
1251{ "vdepi",      0xd4001400, 0xfc001fe0, "?x5,T,b", pa10, 0},
1252{ "zdepi",      0xd4001800, 0xfc001c00, "?x5,p,T,b", pa10, 0},
1253{ "depi",       0xd4001c00, 0xfc001c00, "?x5,p,T,b", pa10, 0},
1254
1255/* System Control Instructions.  */
1256
1257{ "break",      0x00000000, 0xfc001fe0, "r,A", pa10, 0},
1258{ "rfi",        0x00000c00, 0xffffff1f, "cr", pa10, FLAG_STRICT},
1259{ "rfi",        0x00000c00, 0xffffffff, "", pa10, 0},
1260{ "rfir",       0x00000ca0, 0xffffffff, "", pa11, 0},
1261{ "ssm",        0x00000d60, 0xfc00ffe0, "U,t", pa20, FLAG_STRICT},
1262{ "ssm",        0x00000d60, 0xffe0ffe0, "R,t", pa10, 0},
1263{ "rsm",        0x00000e60, 0xfc00ffe0, "U,t", pa20, FLAG_STRICT},
1264{ "rsm",        0x00000e60, 0xffe0ffe0, "R,t", pa10, 0},
1265{ "mtsm",       0x00001860, 0xffe0ffff, "x", pa10, 0},
1266{ "ldsid",      0x000010a0, 0xfc1fffe0, "(b),t", pa10, 0},
1267{ "ldsid",      0x000010a0, 0xfc1f3fe0, "(s,b),t", pa10, 0},
1268{ "mtsp",       0x00001820, 0xffe01fff, "x,S", pa10, 0},
1269{ "mtctl",      0x00001840, 0xfc00ffff, "x,^", pa10, 0},
1270{ "mtsarcm",    0x016018C0, 0xffe0ffff, "x", pa20, FLAG_STRICT},
1271{ "mfia",       0x000014A0, 0xffffffe0, "t", pa20, FLAG_STRICT},
1272{ "mfsp",       0x000004a0, 0xffff1fe0, "S,t", pa10, 0},
1273{ "mfctl",      0x016048a0, 0xffffffe0, "cW!,t", pa20, FLAG_STRICT},
1274{ "mfctl",      0x000008a0, 0xfc1fffe0, "^,t", pa10, 0},
1275{ "sync",       0x00000400, 0xffffffff, "", pa10, 0},
1276{ "syncdma",    0x00100400, 0xffffffff, "", pa10, 0},
1277{ "probe",      0x04001180, 0xfc00ffa0, "cw(b),x,t", pa10, FLAG_STRICT},
1278{ "probe",      0x04001180, 0xfc003fa0, "cw(s,b),x,t", pa10, FLAG_STRICT},
1279{ "probei",     0x04003180, 0xfc00ffa0, "cw(b),R,t", pa10, FLAG_STRICT},
1280{ "probei",     0x04003180, 0xfc003fa0, "cw(s,b),R,t", pa10, FLAG_STRICT},
1281{ "prober",     0x04001180, 0xfc00ffe0, "(b),x,t", pa10, 0},
1282{ "prober",     0x04001180, 0xfc003fe0, "(s,b),x,t", pa10, 0},
1283{ "proberi",    0x04003180, 0xfc00ffe0, "(b),R,t", pa10, 0},
1284{ "proberi",    0x04003180, 0xfc003fe0, "(s,b),R,t", pa10, 0},
1285{ "probew",     0x040011c0, 0xfc00ffe0, "(b),x,t", pa10, 0},
1286{ "probew",     0x040011c0, 0xfc003fe0, "(s,b),x,t", pa10, 0},
1287{ "probewi",    0x040031c0, 0xfc00ffe0, "(b),R,t", pa10, 0},
1288{ "probewi",    0x040031c0, 0xfc003fe0, "(s,b),R,t", pa10, 0},
1289{ "lpa",        0x04001340, 0xfc00ffc0, "cZx(b),t", pa10, 0},
1290{ "lpa",        0x04001340, 0xfc003fc0, "cZx(s,b),t", pa10, 0},
1291{ "lci",        0x04001300, 0xfc00ffe0, "x(b),t", pa11, 0},
1292{ "lci",        0x04001300, 0xfc003fe0, "x(s,b),t", pa11, 0},
1293{ "pdtlb",      0x04001600, 0xfc00ffdf, "cLcZx(b)", pa20, FLAG_STRICT},
1294{ "pdtlb",      0x04001600, 0xfc003fdf, "cLcZx(s,b)", pa20, FLAG_STRICT},
1295{ "pdtlb",      0x04001600, 0xfc1fffdf, "cLcZ@(b)", pa20, FLAG_STRICT},
1296{ "pdtlb",      0x04001600, 0xfc1f3fdf, "cLcZ@(s,b)", pa20, FLAG_STRICT},
1297{ "pdtlb",      0x04001200, 0xfc00ffdf, "cZx(b)", pa10, 0},
1298{ "pdtlb",      0x04001200, 0xfc003fdf, "cZx(s,b)", pa10, 0},
1299{ "pitlb",      0x04000600, 0xfc001fdf, "cLcZx(S,b)", pa20, FLAG_STRICT},
1300{ "pitlb",      0x04000600, 0xfc1f1fdf, "cLcZ@(S,b)", pa20, FLAG_STRICT},
1301{ "pitlb",      0x04000200, 0xfc001fdf, "cZx(S,b)", pa10, 0},
1302{ "pdtlbe",     0x04001240, 0xfc00ffdf, "cZx(b)", pa10, 0},
1303{ "pdtlbe",     0x04001240, 0xfc003fdf, "cZx(s,b)", pa10, 0},
1304{ "pitlbe",     0x04000240, 0xfc001fdf, "cZx(S,b)", pa10, 0},
1305{ "idtlba",     0x04001040, 0xfc00ffff, "x,(b)", pa10, 0},
1306{ "idtlba",     0x04001040, 0xfc003fff, "x,(s,b)", pa10, 0},
1307{ "iitlba",     0x04000040, 0xfc001fff, "x,(S,b)", pa10, 0},
1308{ "idtlbp",     0x04001000, 0xfc00ffff, "x,(b)", pa10, 0},
1309{ "idtlbp",     0x04001000, 0xfc003fff, "x,(s,b)", pa10, 0},
1310{ "iitlbp",     0x04000000, 0xfc001fff, "x,(S,b)", pa10, 0},
1311{ "pdc",        0x04001380, 0xfc00ffdf, "cZx(b)", pa10, 0},
1312{ "pdc",        0x04001380, 0xfc003fdf, "cZx(s,b)", pa10, 0},
1313{ "fdc",        0x04001280, 0xfc00ffdf, "cZx(b)", pa10, FLAG_STRICT},
1314{ "fdc",        0x04001280, 0xfc003fdf, "cZx(s,b)", pa10, FLAG_STRICT},
1315{ "fdc",        0x04003280, 0xfc00ffff, "5(b)", pa20, FLAG_STRICT},
1316{ "fdc",        0x04003280, 0xfc003fff, "5(s,b)", pa20, FLAG_STRICT},
1317{ "fdc",        0x04001280, 0xfc00ffdf, "cZx(b)", pa10, 0},
1318{ "fdc",        0x04001280, 0xfc003fdf, "cZx(s,b)", pa10, 0},
1319{ "fic",        0x040013c0, 0xfc00dfdf, "cZx(b)", pa20, FLAG_STRICT},
1320{ "fic",        0x04000280, 0xfc001fdf, "cZx(S,b)", pa10, 0},
1321{ "fdce",       0x040012c0, 0xfc00ffdf, "cZx(b)", pa10, 0},
1322{ "fdce",       0x040012c0, 0xfc003fdf, "cZx(s,b)", pa10, 0},
1323{ "fice",       0x040002c0, 0xfc001fdf, "cZx(S,b)", pa10, 0},
1324{ "diag",       0x14000000, 0xfc000000, "D", pa10, 0},
1325{ "idtlbt",     0x04001800, 0xfc00ffff, "x,b", pa20, FLAG_STRICT},
1326{ "iitlbt",     0x04000800, 0xfc00ffff, "x,b", pa20, FLAG_STRICT},
1327
1328/* These may be specific to certain versions of the PA.  Joel claimed
1329   they were 72000 (7200?) specific.  However, I'm almost certain the
1330   mtcpu/mfcpu were undocumented, but available in the older 700 machines.  */
1331{ "mtcpu",      0x14001600, 0xfc00ffff, "x,^", pa10, 0},
1332{ "mfcpu",      0x14001A00, 0xfc00ffff, "^,x", pa10, 0},
1333{ "tocen",      0x14403600, 0xffffffff, "", pa10, 0},
1334{ "tocdis",     0x14401620, 0xffffffff, "", pa10, 0},
1335{ "shdwgr",     0x14402600, 0xffffffff, "", pa10, 0},
1336{ "grshdw",     0x14400620, 0xffffffff, "", pa10, 0},
1337
1338/* gfw and gfr are not in the HP PA 1.1 manual, but they are in either
1339   the Timex FPU or the Mustang ERS (not sure which) manual.  */
1340{ "gfw",        0x04001680, 0xfc00ffdf, "cZx(b)", pa11, 0},
1341{ "gfw",        0x04001680, 0xfc003fdf, "cZx(s,b)", pa11, 0},
1342{ "gfr",        0x04001a80, 0xfc00ffdf, "cZx(b)", pa11, 0},
1343{ "gfr",        0x04001a80, 0xfc003fdf, "cZx(s,b)", pa11, 0},
1344
1345/* Floating Point Coprocessor Instructions.  */
1346
1347{ "fldw",       0x24000000, 0xfc00df80, "cXx(b),fT", pa10, FLAG_STRICT},
1348{ "fldw",       0x24000000, 0xfc001f80, "cXx(s,b),fT", pa10, FLAG_STRICT},
1349{ "fldw",       0x24000000, 0xfc00d380, "cxccx(b),fT", pa11, FLAG_STRICT},
1350{ "fldw",       0x24000000, 0xfc001380, "cxccx(s,b),fT", pa11, FLAG_STRICT},
1351{ "fldw",       0x24001020, 0xfc1ff3a0, "cocc@(b),fT", pa20, FLAG_STRICT},
1352{ "fldw",       0x24001020, 0xfc1f33a0, "cocc@(s,b),fT", pa20, FLAG_STRICT},
1353{ "fldw",       0x24001000, 0xfc00df80, "cM5(b),fT", pa10, FLAG_STRICT},
1354{ "fldw",       0x24001000, 0xfc001f80, "cM5(s,b),fT", pa10, FLAG_STRICT},
1355{ "fldw",       0x24001000, 0xfc00d380, "cmcc5(b),fT", pa11, FLAG_STRICT},
1356{ "fldw",       0x24001000, 0xfc001380, "cmcc5(s,b),fT", pa11, FLAG_STRICT},
1357{ "fldw",       0x5c000000, 0xfc000004, "y(b),fe", pa20w, FLAG_STRICT},
1358{ "fldw",       0x58000000, 0xfc000000, "cJy(b),fe", pa20w, FLAG_STRICT},
1359{ "fldw",       0x5c000000, 0xfc00c004, "d(b),fe", pa20, FLAG_STRICT},
1360{ "fldw",       0x5c000000, 0xfc000004, "d(s,b),fe", pa20, FLAG_STRICT},
1361{ "fldw",       0x58000000, 0xfc00c000, "cJd(b),fe", pa20, FLAG_STRICT},
1362{ "fldw",       0x58000000, 0xfc000000, "cJd(s,b),fe", pa20, FLAG_STRICT},
1363{ "fldd",       0x2c000000, 0xfc00dfc0, "cXx(b),ft", pa10, FLAG_STRICT},
1364{ "fldd",       0x2c000000, 0xfc001fc0, "cXx(s,b),ft", pa10, FLAG_STRICT},
1365{ "fldd",       0x2c000000, 0xfc00d3c0, "cxccx(b),ft", pa11, FLAG_STRICT},
1366{ "fldd",       0x2c000000, 0xfc0013c0, "cxccx(s,b),ft", pa11, FLAG_STRICT},
1367{ "fldd",       0x2c001020, 0xfc1ff3e0, "cocc@(b),ft", pa20, FLAG_STRICT},
1368{ "fldd",       0x2c001020, 0xfc1f33e0, "cocc@(s,b),ft", pa20, FLAG_STRICT},
1369{ "fldd",       0x2c001000, 0xfc00dfc0, "cM5(b),ft", pa10, FLAG_STRICT},
1370{ "fldd",       0x2c001000, 0xfc001fc0, "cM5(s,b),ft", pa10, FLAG_STRICT},
1371{ "fldd",       0x2c001000, 0xfc00d3c0, "cmcc5(b),ft", pa11, FLAG_STRICT},
1372{ "fldd",       0x2c001000, 0xfc0013c0, "cmcc5(s,b),ft", pa11, FLAG_STRICT},
1373{ "fldd",       0x50000002, 0xfc000002, "cq&(b),fx", pa20w, FLAG_STRICT},
1374{ "fldd",       0x50000002, 0xfc00c002, "cq#(b),fx", pa20, FLAG_STRICT},
1375{ "fldd",       0x50000002, 0xfc000002, "cq#(s,b),fx", pa20, FLAG_STRICT},
1376{ "fstw",       0x24000200, 0xfc00df80, "cXfT,x(b)", pa10, FLAG_STRICT},
1377{ "fstw",       0x24000200, 0xfc001f80, "cXfT,x(s,b)", pa10, FLAG_STRICT},
1378{ "fstw",       0x24000200, 0xfc00d380, "cxcCfT,x(b)", pa11, FLAG_STRICT},
1379{ "fstw",       0x24000200, 0xfc001380, "cxcCfT,x(s,b)", pa11, FLAG_STRICT},
1380{ "fstw",       0x24001220, 0xfc1ff3a0, "cocCfT,@(b)", pa20, FLAG_STRICT},
1381{ "fstw",       0x24001220, 0xfc1f33a0, "cocCfT,@(s,b)", pa20, FLAG_STRICT},
1382{ "fstw",       0x24001200, 0xfc00df80, "cMfT,5(b)", pa10, FLAG_STRICT},
1383{ "fstw",       0x24001200, 0xfc001f80, "cMfT,5(s,b)", pa10, FLAG_STRICT},
1384{ "fstw",       0x24001200, 0xfc00df80, "cMfT,5(b)", pa10, FLAG_STRICT},
1385{ "fstw",       0x24001200, 0xfc001f80, "cMfT,5(s,b)", pa10, FLAG_STRICT},
1386{ "fstw",       0x7c000000, 0xfc000004, "fE,y(b)", pa20w, FLAG_STRICT},
1387{ "fstw",       0x78000000, 0xfc000000, "cJfE,y(b)", pa20w, FLAG_STRICT},
1388{ "fstw",       0x7c000000, 0xfc00c004, "fE,d(b)", pa20, FLAG_STRICT},
1389{ "fstw",       0x7c000000, 0xfc000004, "fE,d(s,b)", pa20, FLAG_STRICT},
1390{ "fstw",       0x78000000, 0xfc00c000, "cJfE,d(b)", pa20, FLAG_STRICT},
1391{ "fstw",       0x78000000, 0xfc000000, "cJfE,d(s,b)", pa20, FLAG_STRICT},
1392{ "fstd",       0x2c000200, 0xfc00dfc0, "cXft,x(b)", pa10, FLAG_STRICT},
1393{ "fstd",       0x2c000200, 0xfc001fc0, "cXft,x(s,b)", pa10, FLAG_STRICT},
1394{ "fstd",       0x2c000200, 0xfc00d3c0, "cxcCft,x(b)", pa11, FLAG_STRICT},
1395{ "fstd",       0x2c000200, 0xfc0013c0, "cxcCft,x(s,b)", pa11, FLAG_STRICT},
1396{ "fstd",       0x2c001220, 0xfc1ff3e0, "cocCft,@(b)", pa20, FLAG_STRICT},
1397{ "fstd",       0x2c001220, 0xfc1f33e0, "cocCft,@(s,b)", pa20, FLAG_STRICT},
1398{ "fstd",       0x2c001200, 0xfc00dfc0, "cMft,5(b)", pa10, FLAG_STRICT},
1399{ "fstd",       0x2c001200, 0xfc001fc0, "cMft,5(s,b)", pa10, FLAG_STRICT},
1400{ "fstd",       0x2c001200, 0xfc00d3c0, "cmcCft,5(b)", pa11, FLAG_STRICT},
1401{ "fstd",       0x2c001200, 0xfc0013c0, "cmcCft,5(s,b)", pa11, FLAG_STRICT},
1402{ "fstd",       0x70000002, 0xfc000002, "cqfx,&(b)", pa20w, FLAG_STRICT},
1403{ "fstd",       0x70000002, 0xfc00c002, "cqfx,#(b)", pa20, FLAG_STRICT},
1404{ "fstd",       0x70000002, 0xfc000002, "cqfx,#(s,b)", pa20, FLAG_STRICT},
1405{ "fldwx",      0x24000000, 0xfc00df80, "cXx(b),fT", pa10, FLAG_STRICT},
1406{ "fldwx",      0x24000000, 0xfc001f80, "cXx(s,b),fT", pa10, FLAG_STRICT},
1407{ "fldwx",      0x24000000, 0xfc00d380, "cxccx(b),fT", pa11, FLAG_STRICT},
1408{ "fldwx",      0x24000000, 0xfc001380, "cxccx(s,b),fT", pa11, FLAG_STRICT},
1409{ "fldwx",      0x24000000, 0xfc00df80, "cXx(b),fT", pa10, 0},
1410{ "fldwx",      0x24000000, 0xfc001f80, "cXx(s,b),fT", pa10, 0},
1411{ "flddx",      0x2c000000, 0xfc00dfc0, "cXx(b),ft", pa10, FLAG_STRICT},
1412{ "flddx",      0x2c000000, 0xfc001fc0, "cXx(s,b),ft", pa10, FLAG_STRICT},
1413{ "flddx",      0x2c000000, 0xfc00d3c0, "cxccx(b),ft", pa11, FLAG_STRICT},
1414{ "flddx",      0x2c000000, 0xfc0013c0, "cxccx(s,b),ft", pa11, FLAG_STRICT},
1415{ "flddx",      0x2c000000, 0xfc00dfc0, "cXx(b),ft", pa10, 0},
1416{ "flddx",      0x2c000000, 0xfc001fc0, "cXx(s,b),ft", pa10, 0},
1417{ "fstwx",      0x24000200, 0xfc00df80, "cxfT,x(b)", pa10, FLAG_STRICT},
1418{ "fstwx",      0x24000200, 0xfc001f80, "cxfT,x(s,b)", pa10, FLAG_STRICT},
1419{ "fstwx",      0x24000200, 0xfc00d380, "cxcCfT,x(b)", pa11, FLAG_STRICT},
1420{ "fstwx",      0x24000200, 0xfc001380, "cxcCfT,x(s,b)", pa11, FLAG_STRICT},
1421{ "fstwx",      0x24000200, 0xfc00df80, "cxfT,x(b)", pa10, 0},
1422{ "fstwx",      0x24000200, 0xfc001f80, "cxfT,x(s,b)", pa10, 0},
1423{ "fstdx",      0x2c000200, 0xfc00dfc0, "cxft,x(b)", pa10, FLAG_STRICT},
1424{ "fstdx",      0x2c000200, 0xfc001fc0, "cxft,x(s,b)", pa10, FLAG_STRICT},
1425{ "fstdx",      0x2c000200, 0xfc00d3c0, "cxcCft,x(b)", pa11, FLAG_STRICT},
1426{ "fstdx",      0x2c000200, 0xfc0013c0, "cxcCft,x(s,b)", pa11, FLAG_STRICT},
1427{ "fstdx",      0x2c000200, 0xfc00dfc0, "cxft,x(b)", pa10, 0},
1428{ "fstdx",      0x2c000200, 0xfc001fc0, "cxft,x(s,b)", pa10, 0},
1429{ "fstqx",      0x3c000200, 0xfc00dfc0, "cxft,x(b)", pa10, 0},
1430{ "fstqx",      0x3c000200, 0xfc001fc0, "cxft,x(s,b)", pa10, 0},
1431{ "fldws",      0x24001000, 0xfc00df80, "cm5(b),fT", pa10, FLAG_STRICT},
1432{ "fldws",      0x24001000, 0xfc001f80, "cm5(s,b),fT", pa10, FLAG_STRICT},
1433{ "fldws",      0x24001000, 0xfc00d380, "cmcc5(b),fT", pa11, FLAG_STRICT},
1434{ "fldws",      0x24001000, 0xfc001380, "cmcc5(s,b),fT", pa11, FLAG_STRICT},
1435{ "fldws",      0x24001000, 0xfc00df80, "cm5(b),fT", pa10, 0},
1436{ "fldws",      0x24001000, 0xfc001f80, "cm5(s,b),fT", pa10, 0},
1437{ "fldds",      0x2c001000, 0xfc00dfc0, "cm5(b),ft", pa10, FLAG_STRICT},
1438{ "fldds",      0x2c001000, 0xfc001fc0, "cm5(s,b),ft", pa10, FLAG_STRICT},
1439{ "fldds",      0x2c001000, 0xfc00d3c0, "cmcc5(b),ft", pa11, FLAG_STRICT},
1440{ "fldds",      0x2c001000, 0xfc0013c0, "cmcc5(s,b),ft", pa11, FLAG_STRICT},
1441{ "fldds",      0x2c001000, 0xfc00dfc0, "cm5(b),ft", pa10, 0},
1442{ "fldds",      0x2c001000, 0xfc001fc0, "cm5(s,b),ft", pa10, 0},
1443{ "fstws",      0x24001200, 0xfc00df80, "cmfT,5(b)", pa10, FLAG_STRICT},
1444{ "fstws",      0x24001200, 0xfc001f80, "cmfT,5(s,b)", pa10, FLAG_STRICT},
1445{ "fstws",      0x24001200, 0xfc00d380, "cmcCfT,5(b)", pa11, FLAG_STRICT},
1446{ "fstws",      0x24001200, 0xfc001380, "cmcCfT,5(s,b)", pa11, FLAG_STRICT},
1447{ "fstws",      0x24001200, 0xfc00df80, "cmfT,5(b)", pa10, 0},
1448{ "fstws",      0x24001200, 0xfc001f80, "cmfT,5(s,b)", pa10, 0},
1449{ "fstds",      0x2c001200, 0xfc00dfc0, "cmft,5(b)", pa10, FLAG_STRICT},
1450{ "fstds",      0x2c001200, 0xfc001fc0, "cmft,5(s,b)", pa10, FLAG_STRICT},
1451{ "fstds",      0x2c001200, 0xfc00d3c0, "cmcCft,5(b)", pa11, FLAG_STRICT},
1452{ "fstds",      0x2c001200, 0xfc0013c0, "cmcCft,5(s,b)", pa11, FLAG_STRICT},
1453{ "fstds",      0x2c001200, 0xfc00dfc0, "cmft,5(b)", pa10, 0},
1454{ "fstds",      0x2c001200, 0xfc001fc0, "cmft,5(s,b)", pa10, 0},
1455{ "fstqs",      0x3c001200, 0xfc00dfc0, "cmft,5(b)", pa10, 0},
1456{ "fstqs",      0x3c001200, 0xfc001fc0, "cmft,5(s,b)", pa10, 0},
1457{ "fadd",       0x30000600, 0xfc00e7e0, "Ffa,fb,fT", pa10, 0},
1458{ "fadd",       0x38000600, 0xfc00e720, "IfA,fB,fT", pa10, 0},
1459{ "fsub",       0x30002600, 0xfc00e7e0, "Ffa,fb,fT", pa10, 0},
1460{ "fsub",       0x38002600, 0xfc00e720, "IfA,fB,fT", pa10, 0},
1461{ "fmpy",       0x30004600, 0xfc00e7e0, "Ffa,fb,fT", pa10, 0},
1462{ "fmpy",       0x38004600, 0xfc00e720, "IfA,fB,fT", pa10, 0},
1463{ "fdiv",       0x30006600, 0xfc00e7e0, "Ffa,fb,fT", pa10, 0},
1464{ "fdiv",       0x38006600, 0xfc00e720, "IfA,fB,fT", pa10, 0},
1465{ "fsqrt",      0x30008000, 0xfc1fe7e0, "Ffa,fT", pa10, 0},
1466{ "fsqrt",      0x38008000, 0xfc1fe720, "FfA,fT", pa10, 0},
1467{ "fabs",       0x30006000, 0xfc1fe7e0, "Ffa,fT", pa10, 0},
1468{ "fabs",       0x38006000, 0xfc1fe720, "FfA,fT", pa10, 0},
1469{ "frem",       0x30008600, 0xfc00e7e0, "Ffa,fb,fT", pa10, 0},
1470{ "frem",       0x38008600, 0xfc00e720, "FfA,fB,fT", pa10, 0},
1471{ "frnd",       0x3000a000, 0xfc1fe7e0, "Ffa,fT", pa10, 0},
1472{ "frnd",       0x3800a000, 0xfc1fe720, "FfA,fT", pa10, 0},
1473{ "fcpy",       0x30004000, 0xfc1fe7e0, "Ffa,fT", pa10, 0},
1474{ "fcpy",       0x38004000, 0xfc1fe720, "FfA,fT", pa10, 0},
1475{ "fcnvff",     0x30000200, 0xfc1f87e0, "FGfa,fT", pa10, 0},
1476{ "fcnvff",     0x38000200, 0xfc1f8720, "FGfA,fT", pa10, 0},
1477{ "fcnvxf",     0x30008200, 0xfc1f87e0, "FGfa,fT", pa10, 0},
1478{ "fcnvxf",     0x38008200, 0xfc1f8720, "FGfA,fT", pa10, 0},
1479{ "fcnvfx",     0x30010200, 0xfc1f87e0, "FGfa,fT", pa10, 0},
1480{ "fcnvfx",     0x38010200, 0xfc1f8720, "FGfA,fT", pa10, 0},
1481{ "fcnvfxt",    0x30018200, 0xfc1f87e0, "FGfa,fT", pa10, 0},
1482{ "fcnvfxt",    0x38018200, 0xfc1f8720, "FGfA,fT", pa10, 0},
1483{ "fmpyfadd",   0xb8000000, 0xfc000020, "IfA,fB,fC,fT", pa20, FLAG_STRICT},
1484{ "fmpynfadd",  0xb8000020, 0xfc000020, "IfA,fB,fC,fT", pa20, FLAG_STRICT},
1485{ "fneg",       0x3000c000, 0xfc1fe7e0, "Ffa,fT", pa20, FLAG_STRICT},
1486{ "fneg",       0x3800c000, 0xfc1fe720, "IfA,fT", pa20, FLAG_STRICT},
1487{ "fnegabs",    0x3000e000, 0xfc1fe7e0, "Ffa,fT", pa20, FLAG_STRICT},
1488{ "fnegabs",    0x3800e000, 0xfc1fe720, "IfA,fT", pa20, FLAG_STRICT},
1489{ "fcnv",       0x30000200, 0xfc1c0720, "{_fa,fT", pa20, FLAG_STRICT},
1490{ "fcnv",       0x38000200, 0xfc1c0720, "FGfA,fT", pa20, FLAG_STRICT},
1491{ "fcmp",       0x30000400, 0xfc00e7e0, "F?ffa,fb", pa10, FLAG_STRICT},
1492{ "fcmp",       0x38000400, 0xfc00e720, "I?ffA,fB", pa10, FLAG_STRICT},
1493{ "fcmp",       0x30000400, 0xfc0007e0, "F?ffa,fb,h", pa20, FLAG_STRICT},
1494{ "fcmp",       0x38000400, 0xfc000720, "I?ffA,fB,h", pa20, FLAG_STRICT},
1495{ "fcmp",       0x30000400, 0xfc00e7e0, "F?ffa,fb", pa10, 0},
1496{ "fcmp",       0x38000400, 0xfc00e720, "I?ffA,fB", pa10, 0},
1497{ "xmpyu",      0x38004700, 0xfc00e720, "fX,fB,fT", pa11, 0},
1498{ "fmpyadd",    0x18000000, 0xfc000000, "Hfi,fj,fk,fl,fm", pa11, 0},
1499{ "fmpysub",    0x98000000, 0xfc000000, "Hfi,fj,fk,fl,fm", pa11, 0},
1500{ "ftest",      0x30002420, 0xffffffff, "", pa10, FLAG_STRICT},
1501{ "ftest",      0x30002420, 0xffffffe0, ",=", pa20, FLAG_STRICT},
1502{ "ftest",      0x30000420, 0xffff1fff, "m", pa20, FLAG_STRICT},
1503{ "fid",        0x30000000, 0xffffffff, "", pa11, 0},
1504
1505/* Performance Monitor Instructions.  */
1506
1507{ "pmdis",      0x30000280, 0xffffffdf, "N", pa20, FLAG_STRICT},
1508{ "pmenb",      0x30000680, 0xffffffff, "", pa20, FLAG_STRICT},
1509
1510/* Assist Instructions.  */
1511
1512{ "spop0",      0x10000000, 0xfc000600, "v,ON", pa10, 0},
1513{ "spop1",      0x10000200, 0xfc000600, "v,oNt", pa10, 0},
1514{ "spop2",      0x10000400, 0xfc000600, "v,1Nb", pa10, 0},
1515{ "spop3",      0x10000600, 0xfc000600, "v,0Nx,b", pa10, 0},
1516{ "copr",       0x30000000, 0xfc000000, "u,2N", pa10, 0},
1517{ "cldw",       0x24000000, 0xfc00de00, "ucXx(b),t", pa10, FLAG_STRICT},
1518{ "cldw",       0x24000000, 0xfc001e00, "ucXx(s,b),t", pa10, FLAG_STRICT},
1519{ "cldw",       0x24000000, 0xfc00d200, "ucxccx(b),t", pa11, FLAG_STRICT},
1520{ "cldw",       0x24000000, 0xfc001200, "ucxccx(s,b),t", pa11, FLAG_STRICT},
1521{ "cldw",       0x24001000, 0xfc00d200, "ucocc@(b),t", pa20, FLAG_STRICT},
1522{ "cldw",       0x24001000, 0xfc001200, "ucocc@(s,b),t", pa20, FLAG_STRICT},
1523{ "cldw",       0x24001000, 0xfc00de00, "ucM5(b),t", pa10, FLAG_STRICT},
1524{ "cldw",       0x24001000, 0xfc001e00, "ucM5(s,b),t", pa10, FLAG_STRICT},
1525{ "cldw",       0x24001000, 0xfc00d200, "ucmcc5(b),t", pa11, FLAG_STRICT},
1526{ "cldw",       0x24001000, 0xfc001200, "ucmcc5(s,b),t", pa11, FLAG_STRICT},
1527{ "cldd",       0x2c000000, 0xfc00de00, "ucXx(b),t", pa10, FLAG_STRICT},
1528{ "cldd",       0x2c000000, 0xfc001e00, "ucXx(s,b),t", pa10, FLAG_STRICT},
1529{ "cldd",       0x2c000000, 0xfc00d200, "ucxccx(b),t", pa11, FLAG_STRICT},
1530{ "cldd",       0x2c000000, 0xfc001200, "ucxccx(s,b),t", pa11, FLAG_STRICT},
1531{ "cldd",       0x2c001000, 0xfc00d200, "ucocc@(b),t", pa20, FLAG_STRICT},
1532{ "cldd",       0x2c001000, 0xfc001200, "ucocc@(s,b),t", pa20, FLAG_STRICT},
1533{ "cldd",       0x2c001000, 0xfc00de00, "ucM5(b),t", pa10, FLAG_STRICT},
1534{ "cldd",       0x2c001000, 0xfc001e00, "ucM5(s,b),t", pa10, FLAG_STRICT},
1535{ "cldd",       0x2c001000, 0xfc00d200, "ucmcc5(b),t", pa11, FLAG_STRICT},
1536{ "cldd",       0x2c001000, 0xfc001200, "ucmcc5(s,b),t", pa11, FLAG_STRICT},
1537{ "cstw",       0x24000200, 0xfc00de00, "ucXt,x(b)", pa10, FLAG_STRICT},
1538{ "cstw",       0x24000200, 0xfc001e00, "ucXt,x(s,b)", pa10, FLAG_STRICT},
1539{ "cstw",       0x24000200, 0xfc00d200, "ucxcCt,x(b)", pa11, FLAG_STRICT},
1540{ "cstw",       0x24000200, 0xfc001200, "ucxcCt,x(s,b)", pa11, FLAG_STRICT},
1541{ "cstw",       0x24001200, 0xfc00d200, "ucocCt,@(b)", pa20, FLAG_STRICT},
1542{ "cstw",       0x24001200, 0xfc001200, "ucocCt,@(s,b)", pa20, FLAG_STRICT},
1543{ "cstw",       0x24001200, 0xfc00de00, "ucMt,5(b)", pa10, FLAG_STRICT},
1544{ "cstw",       0x24001200, 0xfc001e00, "ucMt,5(s,b)", pa10, FLAG_STRICT},
1545{ "cstw",       0x24001200, 0xfc00d200, "ucmcCt,5(b)", pa11, FLAG_STRICT},
1546{ "cstw",       0x24001200, 0xfc001200, "ucmcCt,5(s,b)", pa11, FLAG_STRICT},
1547{ "cstd",       0x2c000200, 0xfc00de00, "ucXt,x(b)", pa10, FLAG_STRICT},
1548{ "cstd",       0x2c000200, 0xfc001e00, "ucXt,x(s,b)", pa10, FLAG_STRICT},
1549{ "cstd",       0x2c000200, 0xfc00d200, "ucxcCt,x(b)", pa11, FLAG_STRICT},
1550{ "cstd",       0x2c000200, 0xfc001200, "ucxcCt,x(s,b)", pa11, FLAG_STRICT},
1551{ "cstd",       0x2c001200, 0xfc00d200, "ucocCt,@(b)", pa20, FLAG_STRICT},
1552{ "cstd",       0x2c001200, 0xfc001200, "ucocCt,@(s,b)", pa20, FLAG_STRICT},
1553{ "cstd",       0x2c001200, 0xfc00de00, "ucMt,5(b)", pa10, FLAG_STRICT},
1554{ "cstd",       0x2c001200, 0xfc001e00, "ucMt,5(s,b)", pa10, FLAG_STRICT},
1555{ "cstd",       0x2c001200, 0xfc00d200, "ucmcCt,5(b)", pa11, FLAG_STRICT},
1556{ "cstd",       0x2c001200, 0xfc001200, "ucmcCt,5(s,b)", pa11, FLAG_STRICT},
1557{ "cldwx",      0x24000000, 0xfc00de00, "ucXx(b),t", pa10, FLAG_STRICT},
1558{ "cldwx",      0x24000000, 0xfc001e00, "ucXx(s,b),t", pa10, FLAG_STRICT},
1559{ "cldwx",      0x24000000, 0xfc00d200, "ucxccx(b),t", pa11, FLAG_STRICT},
1560{ "cldwx",      0x24000000, 0xfc001200, "ucxccx(s,b),t", pa11, FLAG_STRICT},
1561{ "cldwx",      0x24000000, 0xfc00de00, "ucXx(b),t", pa10, 0},
1562{ "cldwx",      0x24000000, 0xfc001e00, "ucXx(s,b),t", pa10, 0},
1563{ "clddx",      0x2c000000, 0xfc00de00, "ucXx(b),t", pa10, FLAG_STRICT},
1564{ "clddx",      0x2c000000, 0xfc001e00, "ucXx(s,b),t", pa10, FLAG_STRICT},
1565{ "clddx",      0x2c000000, 0xfc00d200, "ucxccx(b),t", pa11, FLAG_STRICT},
1566{ "clddx",      0x2c000000, 0xfc001200, "ucxccx(s,b),t", pa11, FLAG_STRICT},
1567{ "clddx",      0x2c000000, 0xfc00de00, "ucXx(b),t", pa10, 0},
1568{ "clddx",      0x2c000000, 0xfc001e00, "ucXx(s,b),t", pa10, 0},
1569{ "cstwx",      0x24000200, 0xfc00de00, "ucXt,x(b)", pa10, FLAG_STRICT},
1570{ "cstwx",      0x24000200, 0xfc001e00, "ucXt,x(s,b)", pa10, FLAG_STRICT},
1571{ "cstwx",      0x24000200, 0xfc00d200, "ucxcCt,x(b)", pa11, FLAG_STRICT},
1572{ "cstwx",      0x24000200, 0xfc001200, "ucxcCt,x(s,b)", pa11, FLAG_STRICT},
1573{ "cstwx",      0x24000200, 0xfc00de00, "ucXt,x(b)", pa10, 0},
1574{ "cstwx",      0x24000200, 0xfc001e00, "ucXt,x(s,b)", pa10, 0},
1575{ "cstdx",      0x2c000200, 0xfc00de00, "ucXt,x(b)", pa10, FLAG_STRICT},
1576{ "cstdx",      0x2c000200, 0xfc001e00, "ucXt,x(s,b)", pa10, FLAG_STRICT},
1577{ "cstdx",      0x2c000200, 0xfc00d200, "ucxcCt,x(b)", pa11, FLAG_STRICT},
1578{ "cstdx",      0x2c000200, 0xfc001200, "ucxcCt,x(s,b)", pa11, FLAG_STRICT},
1579{ "cstdx",      0x2c000200, 0xfc00de00, "ucXt,x(b)", pa10, 0},
1580{ "cstdx",      0x2c000200, 0xfc001e00, "ucXt,x(s,b)", pa10, 0},
1581{ "cldws",      0x24001000, 0xfc00de00, "ucM5(b),t", pa10, FLAG_STRICT},
1582{ "cldws",      0x24001000, 0xfc001e00, "ucM5(s,b),t", pa10, FLAG_STRICT},
1583{ "cldws",      0x24001000, 0xfc00d200, "ucmcc5(b),t", pa11, FLAG_STRICT},
1584{ "cldws",      0x24001000, 0xfc001200, "ucmcc5(s,b),t", pa11, FLAG_STRICT},
1585{ "cldws",      0x24001000, 0xfc00de00, "ucM5(b),t", pa10, 0},
1586{ "cldws",      0x24001000, 0xfc001e00, "ucM5(s,b),t", pa10, 0},
1587{ "cldds",      0x2c001000, 0xfc00de00, "ucM5(b),t", pa10, FLAG_STRICT},
1588{ "cldds",      0x2c001000, 0xfc001e00, "ucM5(s,b),t", pa10, FLAG_STRICT},
1589{ "cldds",      0x2c001000, 0xfc00d200, "ucmcc5(b),t", pa11, FLAG_STRICT},
1590{ "cldds",      0x2c001000, 0xfc001200, "ucmcc5(s,b),t", pa11, FLAG_STRICT},
1591{ "cldds",      0x2c001000, 0xfc00de00, "ucM5(b),t", pa10, 0},
1592{ "cldds",      0x2c001000, 0xfc001e00, "ucM5(s,b),t", pa10, 0},
1593{ "cstws",      0x24001200, 0xfc00de00, "ucMt,5(b)", pa10, FLAG_STRICT},
1594{ "cstws",      0x24001200, 0xfc001e00, "ucMt,5(s,b)", pa10, FLAG_STRICT},
1595{ "cstws",      0x24001200, 0xfc00d200, "ucmcCt,5(b)", pa11, FLAG_STRICT},
1596{ "cstws",      0x24001200, 0xfc001200, "ucmcCt,5(s,b)", pa11, FLAG_STRICT},
1597{ "cstws",      0x24001200, 0xfc00de00, "ucMt,5(b)", pa10, 0},
1598{ "cstws",      0x24001200, 0xfc001e00, "ucMt,5(s,b)", pa10, 0},
1599{ "cstds",      0x2c001200, 0xfc00de00, "ucMt,5(b)", pa10, FLAG_STRICT},
1600{ "cstds",      0x2c001200, 0xfc001e00, "ucMt,5(s,b)", pa10, FLAG_STRICT},
1601{ "cstds",      0x2c001200, 0xfc00d200, "ucmcCt,5(b)", pa11, FLAG_STRICT},
1602{ "cstds",      0x2c001200, 0xfc001200, "ucmcCt,5(s,b)", pa11, FLAG_STRICT},
1603{ "cstds",      0x2c001200, 0xfc00de00, "ucMt,5(b)", pa10, 0},
1604{ "cstds",      0x2c001200, 0xfc001e00, "ucMt,5(s,b)", pa10, 0},
1605
1606/* More pseudo instructions which must follow the main table.  */
1607{ "call",       0xe800f000, 0xfc1ffffd, "n(b)", pa20, FLAG_STRICT},
1608{ "call",       0xe800a000, 0xffe0e000, "nW", pa10, FLAG_STRICT},
1609{ "ret",        0xe840d000, 0xfffffffd, "n", pa20, FLAG_STRICT},
1610
1611};
1612
1613#define NUMOPCODES ((sizeof pa_opcodes)/(sizeof pa_opcodes[0]))
1614
1615/* SKV 12/18/92. Added some denotations for various operands.  */
1616
1617#define PA_IMM11_AT_31 'i'
1618#define PA_IMM14_AT_31 'j'
1619#define PA_IMM21_AT_31 'k'
1620#define PA_DISP12 'w'
1621#define PA_DISP17 'W'
1622
1623#define N_HPPA_OPERAND_FORMATS 5
1624
1625/* Integer register names, indexed by the numbers which appear in the
1626   opcodes.  */
1627static const char *const reg_names[] =
1628{
1629  "flags", "r1", "rp", "r3", "r4", "r5", "r6", "r7", "r8", "r9",
1630  "r10", "r11", "r12", "r13", "r14", "r15", "r16", "r17", "r18", "r19",
1631  "r20", "r21", "r22", "r23", "r24", "r25", "r26", "dp", "ret0", "ret1",
1632  "sp", "r31"
1633};
1634
1635/* Floating point register names, indexed by the numbers which appear in the
1636   opcodes.  */
1637static const char *const fp_reg_names[] =
1638{
1639  "fpsr", "fpe2", "fpe4", "fpe6",
1640  "fr4", "fr5", "fr6", "fr7", "fr8",
1641  "fr9", "fr10", "fr11", "fr12", "fr13", "fr14", "fr15",
1642  "fr16", "fr17", "fr18", "fr19", "fr20", "fr21", "fr22", "fr23",
1643  "fr24", "fr25", "fr26", "fr27", "fr28", "fr29", "fr30", "fr31"
1644};
1645
1646typedef unsigned int CORE_ADDR;
1647
1648/* Get at various relevant fields of an instruction word.  */
1649
1650#define MASK_5  0x1f
1651#define MASK_10 0x3ff
1652#define MASK_11 0x7ff
1653#define MASK_14 0x3fff
1654#define MASK_16 0xffff
1655#define MASK_21 0x1fffff
1656
1657/* These macros get bit fields using HP's numbering (MSB = 0).  */
1658
1659#define GET_FIELD(X, FROM, TO) \
1660  ((X) >> (31 - (TO)) & ((1 << ((TO) - (FROM) + 1)) - 1))
1661
1662#define GET_BIT(X, WHICH) \
1663  GET_FIELD (X, WHICH, WHICH)
1664
1665/* Some of these have been converted to 2-d arrays because they
1666   consume less storage this way.  If the maintenance becomes a
1667   problem, convert them back to const 1-d pointer arrays.  */
1668static const char *const control_reg[] =
1669{
1670  "rctr", "cr1", "cr2", "cr3", "cr4", "cr5", "cr6", "cr7",
1671  "pidr1", "pidr2", "ccr", "sar", "pidr3", "pidr4",
1672  "iva", "eiem", "itmr", "pcsq", "pcoq", "iir", "isr",
1673  "ior", "ipsw", "eirr", "tr0", "tr1", "tr2", "tr3",
1674  "tr4", "tr5", "tr6", "tr7"
1675};
1676
1677static const char *const compare_cond_names[] =
1678{
1679  "", ",=", ",<", ",<=", ",<<", ",<<=", ",sv", ",od",
1680  ",tr", ",<>", ",>=", ",>", ",>>=", ",>>", ",nsv", ",ev"
1681};
1682static const char *const compare_cond_64_names[] =
1683{
1684  "", ",*=", ",*<", ",*<=", ",*<<", ",*<<=", ",*sv", ",*od",
1685  ",*tr", ",*<>", ",*>=", ",*>", ",*>>=", ",*>>", ",*nsv", ",*ev"
1686};
1687static const char *const cmpib_cond_64_names[] =
1688{
1689  ",*<<", ",*=", ",*<", ",*<=", ",*>>=", ",*<>", ",*>=", ",*>"
1690};
1691static const char *const add_cond_names[] =
1692{
1693  "", ",=", ",<", ",<=", ",nuv", ",znv", ",sv", ",od",
1694  ",tr", ",<>", ",>=", ",>", ",uv", ",vnz", ",nsv", ",ev"
1695};
1696static const char *const add_cond_64_names[] =
1697{
1698  "", ",*=", ",*<", ",*<=", ",*nuv", ",*znv", ",*sv", ",*od",
1699  ",*tr", ",*<>", ",*>=", ",*>", ",*uv", ",*vnz", ",*nsv", ",*ev"
1700};
1701static const char *const wide_add_cond_names[] =
1702{
1703  "", ",=", ",<", ",<=", ",nuv", ",*=", ",*<", ",*<=",
1704  ",tr", ",<>", ",>=", ",>", ",uv", ",*<>", ",*>=", ",*>"
1705};
1706static const char *const logical_cond_names[] =
1707{
1708  "", ",=", ",<", ",<=", 0, 0, 0, ",od",
1709  ",tr", ",<>", ",>=", ",>", 0, 0, 0, ",ev"};
1710static const char *const logical_cond_64_names[] =
1711{
1712  "", ",*=", ",*<", ",*<=", 0, 0, 0, ",*od",
1713  ",*tr", ",*<>", ",*>=", ",*>", 0, 0, 0, ",*ev"};
1714static const char *const unit_cond_names[] =
1715{
1716  "", ",swz", ",sbz", ",shz", ",sdc", ",swc", ",sbc", ",shc",
1717  ",tr", ",nwz", ",nbz", ",nhz", ",ndc", ",nwc", ",nbc", ",nhc"
1718};
1719static const char *const unit_cond_64_names[] =
1720{
1721  "", ",*swz", ",*sbz", ",*shz", ",*sdc", ",*swc", ",*sbc", ",*shc",
1722  ",*tr", ",*nwz", ",*nbz", ",*nhz", ",*ndc", ",*nwc", ",*nbc", ",*nhc"
1723};
1724static const char *const shift_cond_names[] =
1725{
1726  "", ",=", ",<", ",od", ",tr", ",<>", ",>=", ",ev"
1727};
1728static const char *const shift_cond_64_names[] =
1729{
1730  "", ",*=", ",*<", ",*od", ",*tr", ",*<>", ",*>=", ",*ev"
1731};
1732static const char *const bb_cond_64_names[] =
1733{
1734  ",*<", ",*>="
1735};
1736static const char *const index_compl_names[] = {"", ",m", ",s", ",sm"};
1737static const char *const short_ldst_compl_names[] = {"", ",ma", "", ",mb"};
1738static const char *const short_bytes_compl_names[] =
1739{
1740  "", ",b,m", ",e", ",e,m"
1741};
1742static const char *const float_format_names[] = {",sgl", ",dbl", "", ",quad"};
1743static const char *const fcnv_fixed_names[] = {",w", ",dw", "", ",qw"};
1744static const char *const fcnv_ufixed_names[] = {",uw", ",udw", "", ",uqw"};
1745static const char *const float_comp_names[] =
1746{
1747  ",false?", ",false", ",?", ",!<=>", ",=", ",=t", ",?=", ",!<>",
1748  ",!?>=", ",<", ",?<", ",!>=", ",!?>", ",<=", ",?<=", ",!>",
1749  ",!?<=", ",>", ",?>", ",!<=", ",!?<", ",>=", ",?>=", ",!<",
1750  ",!?=", ",<>", ",!=", ",!=t", ",!?", ",<=>", ",true?", ",true"
1751};
1752static const char *const signed_unsigned_names[] = {",u", ",s"};
1753static const char *const mix_half_names[] = {",l", ",r"};
1754static const char *const saturation_names[] = {",us", ",ss", 0, ""};
1755static const char *const read_write_names[] = {",r", ",w"};
1756static const char *const add_compl_names[] = { 0, "", ",l", ",tsv" };
1757
1758/* For a bunch of different instructions form an index into a
1759   completer name table.  */
1760#define GET_COMPL(insn) (GET_FIELD (insn, 26, 26) | \
1761                         GET_FIELD (insn, 18, 18) << 1)
1762
1763#define GET_COND(insn) (GET_FIELD ((insn), 16, 18) + \
1764                        (GET_FIELD ((insn), 19, 19) ? 8 : 0))
1765
1766/* Utility function to print registers.  Put these first, so gcc's function
1767   inlining can do its stuff.  */
1768
1769#define fputs_filtered(STR,F)   (*info->fprintf_func) (info->stream, "%s", STR)
1770
1771static void
1772fput_reg (unsigned reg, disassemble_info *info)
1773{
1774  (*info->fprintf_func) (info->stream, "%s", reg ? reg_names[reg] : "r0");
1775}
1776
1777static void
1778fput_fp_reg (unsigned reg, disassemble_info *info)
1779{
1780  (*info->fprintf_func) (info->stream, "%s", reg ? fp_reg_names[reg] : "fr0");
1781}
1782
1783static void
1784fput_fp_reg_r (unsigned reg, disassemble_info *info)
1785{
1786  /* Special case floating point exception registers.  */
1787  if (reg < 4)
1788    (*info->fprintf_func) (info->stream, "fpe%d", reg * 2 + 1);
1789  else
1790    (*info->fprintf_func) (info->stream, "%sR",
1791                           reg ? fp_reg_names[reg] : "fr0");
1792}
1793
1794static void
1795fput_creg (unsigned reg, disassemble_info *info)
1796{
1797  (*info->fprintf_func) (info->stream, "%s", control_reg[reg]);
1798}
1799
1800/* Print constants with sign.  */
1801
1802static void
1803fput_const (unsigned num, disassemble_info *info)
1804{
1805  if ((int) num < 0)
1806    (*info->fprintf_func) (info->stream, "-%x", - (int) num);
1807  else
1808    (*info->fprintf_func) (info->stream, "%x", num);
1809}
1810
1811/* Routines to extract various sized constants out of hppa
1812   instructions.  */
1813
1814/* Extract a 3-bit space register number from a be, ble, mtsp or mfsp.  */
1815static int
1816extract_3 (unsigned word)
1817{
1818  return GET_FIELD (word, 18, 18) << 2 | GET_FIELD (word, 16, 17);
1819}
1820
1821static int
1822extract_5_load (unsigned word)
1823{
1824  return low_sign_extend (word >> 16 & MASK_5, 5);
1825}
1826
1827/* Extract the immediate field from a st{bhw}s instruction.  */
1828
1829static int
1830extract_5_store (unsigned word)
1831{
1832  return low_sign_extend (word & MASK_5, 5);
1833}
1834
1835/* Extract the immediate field from a break instruction.  */
1836
1837static unsigned
1838extract_5r_store (unsigned word)
1839{
1840  return (word & MASK_5);
1841}
1842
1843/* Extract the immediate field from a {sr}sm instruction.  */
1844
1845static unsigned
1846extract_5R_store (unsigned word)
1847{
1848  return (word >> 16 & MASK_5);
1849}
1850
1851/* Extract the 10 bit immediate field from a {sr}sm instruction.  */
1852
1853static unsigned
1854extract_10U_store (unsigned word)
1855{
1856  return (word >> 16 & MASK_10);
1857}
1858
1859/* Extract the immediate field from a bb instruction.  */
1860
1861static unsigned
1862extract_5Q_store (unsigned word)
1863{
1864  return (word >> 21 & MASK_5);
1865}
1866
1867/* Extract an 11 bit immediate field.  */
1868
1869static int
1870extract_11 (unsigned word)
1871{
1872  return low_sign_extend (word & MASK_11, 11);
1873}
1874
1875/* Extract a 14 bit immediate field.  */
1876
1877static int
1878extract_14 (unsigned word)
1879{
1880  return low_sign_extend (word & MASK_14, 14);
1881}
1882
1883/* Extract a 16 bit immediate field (PA2.0 wide only).  */
1884
1885static int
1886extract_16 (unsigned word)
1887{
1888  int m15, m0, m1;
1889
1890  m0 = GET_BIT (word, 16);
1891  m1 = GET_BIT (word, 17);
1892  m15 = GET_BIT (word, 31);
1893  word = (word >> 1) & 0x1fff;
1894  word = word | (m15 << 15) | ((m15 ^ m0) << 14) | ((m15 ^ m1) << 13);
1895  return sign_extend (word, 16);
1896}
1897
1898/* Extract a 21 bit constant.  */
1899
1900static int
1901extract_21 (unsigned word)
1902{
1903  int val;
1904
1905  word &= MASK_21;
1906  word <<= 11;
1907  val = GET_FIELD (word, 20, 20);
1908  val <<= 11;
1909  val |= GET_FIELD (word, 9, 19);
1910  val <<= 2;
1911  val |= GET_FIELD (word, 5, 6);
1912  val <<= 5;
1913  val |= GET_FIELD (word, 0, 4);
1914  val <<= 2;
1915  val |= GET_FIELD (word, 7, 8);
1916  return sign_extend (val, 21) << 11;
1917}
1918
1919/* Extract a 12 bit constant from branch instructions.  */
1920
1921static int
1922extract_12 (unsigned word)
1923{
1924  return sign_extend (GET_FIELD (word, 19, 28)
1925                      | GET_FIELD (word, 29, 29) << 10
1926                      | (word & 0x1) << 11, 12) << 2;
1927}
1928
1929/* Extract a 17 bit constant from branch instructions, returning the
1930   19 bit signed value.  */
1931
1932static int
1933extract_17 (unsigned word)
1934{
1935  return sign_extend (GET_FIELD (word, 19, 28)
1936                      | GET_FIELD (word, 29, 29) << 10
1937                      | GET_FIELD (word, 11, 15) << 11
1938                      | (word & 0x1) << 16, 17) << 2;
1939}
1940
1941static int
1942extract_22 (unsigned word)
1943{
1944  return sign_extend (GET_FIELD (word, 19, 28)
1945                      | GET_FIELD (word, 29, 29) << 10
1946                      | GET_FIELD (word, 11, 15) << 11
1947                      | GET_FIELD (word, 6, 10) << 16
1948                      | (word & 0x1) << 21, 22) << 2;
1949}
1950
1951/* Print one instruction.  */
1952
1953int
1954print_insn_hppa (bfd_vma memaddr, disassemble_info *info)
1955{
1956  bfd_byte buffer[4];
1957  unsigned int insn, i;
1958
1959  {
1960    int status =
1961      (*info->read_memory_func) (memaddr, buffer, sizeof (buffer), info);
1962    if (status != 0)
1963      {
1964        (*info->memory_error_func) (status, memaddr, info);
1965        return -1;
1966      }
1967  }
1968
1969  insn = bfd_getb32 (buffer);
1970
1971  for (i = 0; i < NUMOPCODES; ++i)
1972    {
1973      const struct pa_opcode *opcode = &pa_opcodes[i];
1974
1975      if ((insn & opcode->mask) == opcode->match)
1976        {
1977          const char *s;
1978#ifndef BFD64
1979          if (opcode->arch == pa20w)
1980            continue;
1981#endif
1982          (*info->fprintf_func) (info->stream, "%s", opcode->name);
1983
1984          if (!strchr ("cfCY?-+nHNZFIuv{", opcode->args[0]))
1985            (*info->fprintf_func) (info->stream, " ");
1986          for (s = opcode->args; *s != '\0'; ++s)
1987            {
1988              switch (*s)
1989                {
1990                case 'x':
1991                  fput_reg (GET_FIELD (insn, 11, 15), info);
1992                  break;
1993                case 'a':
1994                case 'b':
1995                  fput_reg (GET_FIELD (insn, 6, 10), info);
1996                  break;
1997                case '^':
1998                  fput_creg (GET_FIELD (insn, 6, 10), info);
1999                  break;
2000                case 't':
2001                  fput_reg (GET_FIELD (insn, 27, 31), info);
2002                  break;
2003
2004                  /* Handle floating point registers.  */
2005                case 'f':
2006                  switch (*++s)
2007                    {
2008                    case 't':
2009                      fput_fp_reg (GET_FIELD (insn, 27, 31), info);
2010                      break;
2011                    case 'T':
2012                      if (GET_FIELD (insn, 25, 25))
2013                        fput_fp_reg_r (GET_FIELD (insn, 27, 31), info);
2014                      else
2015                        fput_fp_reg (GET_FIELD (insn, 27, 31), info);
2016                      break;
2017                    case 'a':
2018                      if (GET_FIELD (insn, 25, 25))
2019                        fput_fp_reg_r (GET_FIELD (insn, 6, 10), info);
2020                      else
2021                        fput_fp_reg (GET_FIELD (insn, 6, 10), info);
2022                      break;
2023
2024                      /* 'fA' will not generate a space before the regsiter
2025                         name.  Normally that is fine.  Except that it
2026                         causes problems with xmpyu which has no FP format
2027                         completer.  */
2028                    case 'X':
2029                      fputs_filtered (" ", info);
2030                      /* FALLTHRU */
2031
2032                    case 'A':
2033                      if (GET_FIELD (insn, 24, 24))
2034                        fput_fp_reg_r (GET_FIELD (insn, 6, 10), info);
2035                      else
2036                        fput_fp_reg (GET_FIELD (insn, 6, 10), info);
2037                      break;
2038                    case 'b':
2039                      if (GET_FIELD (insn, 25, 25))
2040                        fput_fp_reg_r (GET_FIELD (insn, 11, 15), info);
2041                      else
2042                        fput_fp_reg (GET_FIELD (insn, 11, 15), info);
2043                      break;
2044                    case 'B':
2045                      if (GET_FIELD (insn, 19, 19))
2046                        fput_fp_reg_r (GET_FIELD (insn, 11, 15), info);
2047                      else
2048                        fput_fp_reg (GET_FIELD (insn, 11, 15), info);
2049                      break;
2050                    case 'C':
2051                      {
2052                        int reg = GET_FIELD (insn, 21, 22);
2053                        reg |= GET_FIELD (insn, 16, 18) << 2;
2054                        if (GET_FIELD (insn, 23, 23) != 0)
2055                          fput_fp_reg_r (reg, info);
2056                        else
2057                          fput_fp_reg (reg, info);
2058                        break;
2059                      }
2060                    case 'i':
2061                      {
2062                        int reg = GET_FIELD (insn, 6, 10);
2063
2064                        reg |= (GET_FIELD (insn, 26, 26) << 4);
2065                        fput_fp_reg (reg, info);
2066                        break;
2067                      }
2068                    case 'j':
2069                      {
2070                        int reg = GET_FIELD (insn, 11, 15);
2071
2072                        reg |= (GET_FIELD (insn, 26, 26) << 4);
2073                        fput_fp_reg (reg, info);
2074                        break;
2075                      }
2076                    case 'k':
2077                      {
2078                        int reg = GET_FIELD (insn, 27, 31);
2079
2080                        reg |= (GET_FIELD (insn, 26, 26) << 4);
2081                        fput_fp_reg (reg, info);
2082                        break;
2083                      }
2084                    case 'l':
2085                      {
2086                        int reg = GET_FIELD (insn, 21, 25);
2087
2088                        reg |= (GET_FIELD (insn, 26, 26) << 4);
2089                        fput_fp_reg (reg, info);
2090                        break;
2091                      }
2092                    case 'm':
2093                      {
2094                        int reg = GET_FIELD (insn, 16, 20);
2095
2096                        reg |= (GET_FIELD (insn, 26, 26) << 4);
2097                        fput_fp_reg (reg, info);
2098                        break;
2099                      }
2100
2101                      /* 'fe' will not generate a space before the register
2102                         name.  Normally that is fine.  Except that it
2103                         causes problems with fstw fe,y(b) which has no FP
2104                         format completer.  */
2105                    case 'E':
2106                      fputs_filtered (" ", info);
2107                      /* FALLTHRU */
2108
2109                    case 'e':
2110                      if (GET_FIELD (insn, 30, 30))
2111                        fput_fp_reg_r (GET_FIELD (insn, 11, 15), info);
2112                      else
2113                        fput_fp_reg (GET_FIELD (insn, 11, 15), info);
2114                      break;
2115                    case 'x':
2116                      fput_fp_reg (GET_FIELD (insn, 11, 15), info);
2117                      break;
2118                    }
2119                  break;
2120
2121                case '5':
2122                  fput_const (extract_5_load (insn), info);
2123                  break;
2124                case 's':
2125                  {
2126                    int space = GET_FIELD (insn, 16, 17);
2127                    /* Zero means implicit addressing, not use of sr0.  */
2128                    if (space != 0)
2129                      (*info->fprintf_func) (info->stream, "sr%d", space);
2130                  }
2131                  break;
2132
2133                case 'S':
2134                  (*info->fprintf_func) (info->stream, "sr%d",
2135                                         extract_3 (insn));
2136                  break;
2137
2138                  /* Handle completers.  */
2139                case 'c':
2140                  switch (*++s)
2141                    {
2142                    case 'x':
2143                      (*info->fprintf_func)
2144                        (info->stream, "%s",
2145                         index_compl_names[GET_COMPL (insn)]);
2146                      break;
2147                    case 'X':
2148                      (*info->fprintf_func)
2149                        (info->stream, "%s ",
2150                         index_compl_names[GET_COMPL (insn)]);
2151                      break;
2152                    case 'm':
2153                      (*info->fprintf_func)
2154                        (info->stream, "%s",
2155                         short_ldst_compl_names[GET_COMPL (insn)]);
2156                      break;
2157                    case 'M':
2158                      (*info->fprintf_func)
2159                        (info->stream, "%s ",
2160                         short_ldst_compl_names[GET_COMPL (insn)]);
2161                      break;
2162                    case 'A':
2163                      (*info->fprintf_func)
2164                        (info->stream, "%s ",
2165                         short_bytes_compl_names[GET_COMPL (insn)]);
2166                      break;
2167                    case 's':
2168                      (*info->fprintf_func)
2169                        (info->stream, "%s",
2170                         short_bytes_compl_names[GET_COMPL (insn)]);
2171                      break;
2172                    case 'c':
2173                    case 'C':
2174                      switch (GET_FIELD (insn, 20, 21))
2175                        {
2176                        case 1:
2177                          (*info->fprintf_func) (info->stream, ",bc ");
2178                          break;
2179                        case 2:
2180                          (*info->fprintf_func) (info->stream, ",sl ");
2181                          break;
2182                        default:
2183                          (*info->fprintf_func) (info->stream, " ");
2184                        }
2185                      break;
2186                    case 'd':
2187                      switch (GET_FIELD (insn, 20, 21))
2188                        {
2189                        case 1:
2190                          (*info->fprintf_func) (info->stream, ",co ");
2191                          break;
2192                        default:
2193                          (*info->fprintf_func) (info->stream, " ");
2194                        }
2195                      break;
2196                    case 'o':
2197                      (*info->fprintf_func) (info->stream, ",o");
2198                      break;
2199                    case 'g':
2200                      (*info->fprintf_func) (info->stream, ",gate");
2201                      break;
2202                    case 'p':
2203                      (*info->fprintf_func) (info->stream, ",l,push");
2204                      break;
2205                    case 'P':
2206                      (*info->fprintf_func) (info->stream, ",pop");
2207                      break;
2208                    case 'l':
2209                    case 'L':
2210                      (*info->fprintf_func) (info->stream, ",l");
2211                      break;
2212                    case 'w':
2213                      (*info->fprintf_func)
2214                        (info->stream, "%s ",
2215                         read_write_names[GET_FIELD (insn, 25, 25)]);
2216                      break;
2217                    case 'W':
2218                      (*info->fprintf_func) (info->stream, ",w ");
2219                      break;
2220                    case 'r':
2221                      if (GET_FIELD (insn, 23, 26) == 5)
2222                        (*info->fprintf_func) (info->stream, ",r");
2223                      break;
2224                    case 'Z':
2225                      if (GET_FIELD (insn, 26, 26))
2226                        (*info->fprintf_func) (info->stream, ",m ");
2227                      else
2228                        (*info->fprintf_func) (info->stream, " ");
2229                      break;
2230                    case 'i':
2231                      if (GET_FIELD (insn, 25, 25))
2232                        (*info->fprintf_func) (info->stream, ",i");
2233                      break;
2234                    case 'z':
2235                      if (!GET_FIELD (insn, 21, 21))
2236                        (*info->fprintf_func) (info->stream, ",z");
2237                      break;
2238                    case 'a':
2239                      (*info->fprintf_func)
2240                        (info->stream, "%s",
2241                         add_compl_names[GET_FIELD (insn, 20, 21)]);
2242                      break;
2243                    case 'Y':
2244                      (*info->fprintf_func)
2245                        (info->stream, ",dc%s",
2246                         add_compl_names[GET_FIELD (insn, 20, 21)]);
2247                      break;
2248                    case 'y':
2249                      (*info->fprintf_func)
2250                        (info->stream, ",c%s",
2251                         add_compl_names[GET_FIELD (insn, 20, 21)]);
2252                      break;
2253                    case 'v':
2254                      if (GET_FIELD (insn, 20, 20))
2255                        (*info->fprintf_func) (info->stream, ",tsv");
2256                      break;
2257                    case 't':
2258                      (*info->fprintf_func) (info->stream, ",tc");
2259                      if (GET_FIELD (insn, 20, 20))
2260                        (*info->fprintf_func) (info->stream, ",tsv");
2261                      break;
2262                    case 'B':
2263                      (*info->fprintf_func) (info->stream, ",db");
2264                      if (GET_FIELD (insn, 20, 20))
2265                        (*info->fprintf_func) (info->stream, ",tsv");
2266                      break;
2267                    case 'b':
2268                      (*info->fprintf_func) (info->stream, ",b");
2269                      if (GET_FIELD (insn, 20, 20))
2270                        (*info->fprintf_func) (info->stream, ",tsv");
2271                      break;
2272                    case 'T':
2273                      if (GET_FIELD (insn, 25, 25))
2274                        (*info->fprintf_func) (info->stream, ",tc");
2275                      break;
2276                    case 'S':
2277                      /* EXTRD/W has a following condition.  */
2278                      if (*(s + 1) == '?')
2279                        (*info->fprintf_func)
2280                          (info->stream, "%s",
2281                           signed_unsigned_names[GET_FIELD (insn, 21, 21)]);
2282                      else
2283                        (*info->fprintf_func)
2284                          (info->stream, "%s ",
2285                           signed_unsigned_names[GET_FIELD (insn, 21, 21)]);
2286                      break;
2287                    case 'h':
2288                      (*info->fprintf_func)
2289                        (info->stream, "%s",
2290                         mix_half_names[GET_FIELD (insn, 17, 17)]);
2291                      break;
2292                    case 'H':
2293                      (*info->fprintf_func)
2294                        (info->stream, "%s ",
2295                         saturation_names[GET_FIELD (insn, 24, 25)]);
2296                      break;
2297                    case '*':
2298                      (*info->fprintf_func)
2299                        (info->stream, ",%d%d%d%d ",
2300                         GET_FIELD (insn, 17, 18), GET_FIELD (insn, 20, 21),
2301                         GET_FIELD (insn, 22, 23), GET_FIELD (insn, 24, 25));
2302                      break;
2303
2304                    case 'q':
2305                      {
2306                        int m, a;
2307
2308                        m = GET_FIELD (insn, 28, 28);
2309                        a = GET_FIELD (insn, 29, 29);
2310
2311                        if (m && !a)
2312                          fputs_filtered (",ma ", info);
2313                        else if (m && a)
2314                          fputs_filtered (",mb ", info);
2315                        else
2316                          fputs_filtered (" ", info);
2317                        break;
2318                      }
2319
2320                    case 'J':
2321                      {
2322                        int opc = GET_FIELD (insn, 0, 5);
2323
2324                        if (opc == 0x16 || opc == 0x1e)
2325                          {
2326                            if (GET_FIELD (insn, 29, 29) == 0)
2327                              fputs_filtered (",ma ", info);
2328                            else
2329                              fputs_filtered (",mb ", info);
2330                          }
2331                        else
2332                          fputs_filtered (" ", info);
2333                        break;
2334                      }
2335
2336                    case 'e':
2337                      {
2338                        int opc = GET_FIELD (insn, 0, 5);
2339
2340                        if (opc == 0x13 || opc == 0x1b)
2341                          {
2342                            if (GET_FIELD (insn, 18, 18) == 1)
2343                              fputs_filtered (",mb ", info);
2344                            else
2345                              fputs_filtered (",ma ", info);
2346                          }
2347                        else if (opc == 0x17 || opc == 0x1f)
2348                          {
2349                            if (GET_FIELD (insn, 31, 31) == 1)
2350                              fputs_filtered (",ma ", info);
2351                            else
2352                              fputs_filtered (",mb ", info);
2353                          }
2354                        else
2355                          fputs_filtered (" ", info);
2356
2357                        break;
2358                      }
2359                    }
2360                  break;
2361
2362                  /* Handle conditions.  */
2363                case '?':
2364                  {
2365                    s++;
2366                    switch (*s)
2367                      {
2368                      case 'f':
2369                        (*info->fprintf_func)
2370                          (info->stream, "%s ",
2371                           float_comp_names[GET_FIELD (insn, 27, 31)]);
2372                        break;
2373
2374                        /* These four conditions are for the set of instructions
2375                           which distinguish true/false conditions by opcode
2376                           rather than by the 'f' bit (sigh): comb, comib,
2377                           addb, addib.  */
2378                      case 't':
2379                        fputs_filtered
2380                          (compare_cond_names[GET_FIELD (insn, 16, 18)], info);
2381                        break;
2382                      case 'n':
2383                        fputs_filtered
2384                          (compare_cond_names[GET_FIELD (insn, 16, 18)
2385                                              + GET_FIELD (insn, 4, 4) * 8],
2386                           info);
2387                        break;
2388                      case 'N':
2389                        fputs_filtered
2390                          (compare_cond_64_names[GET_FIELD (insn, 16, 18)
2391                                                 + GET_FIELD (insn, 2, 2) * 8],
2392                           info);
2393                        break;
2394                      case 'Q':
2395                        fputs_filtered
2396                          (cmpib_cond_64_names[GET_FIELD (insn, 16, 18)],
2397                           info);
2398                        break;
2399                      case '@':
2400                        fputs_filtered
2401                          (add_cond_names[GET_FIELD (insn, 16, 18)
2402                                          + GET_FIELD (insn, 4, 4) * 8],
2403                           info);
2404                        break;
2405                      case 's':
2406                        (*info->fprintf_func)
2407                          (info->stream, "%s ",
2408                           compare_cond_names[GET_COND (insn)]);
2409                        break;
2410                      case 'S':
2411                        (*info->fprintf_func)
2412                          (info->stream, "%s ",
2413                           compare_cond_64_names[GET_COND (insn)]);
2414                        break;
2415                      case 'a':
2416                        (*info->fprintf_func)
2417                          (info->stream, "%s ",
2418                           add_cond_names[GET_COND (insn)]);
2419                        break;
2420                      case 'A':
2421                        (*info->fprintf_func)
2422                          (info->stream, "%s ",
2423                           add_cond_64_names[GET_COND (insn)]);
2424                        break;
2425                      case 'd':
2426                        (*info->fprintf_func)
2427                          (info->stream, "%s",
2428                           add_cond_names[GET_FIELD (insn, 16, 18)]);
2429                        break;
2430
2431                      case 'W':
2432                        (*info->fprintf_func)
2433                          (info->stream, "%s",
2434                           wide_add_cond_names[GET_FIELD (insn, 16, 18) +
2435                                               GET_FIELD (insn, 4, 4) * 8]);
2436                        break;
2437
2438                      case 'l':
2439                        (*info->fprintf_func)
2440                          (info->stream, "%s ",
2441                           logical_cond_names[GET_COND (insn)]);
2442                        break;
2443                      case 'L':
2444                        (*info->fprintf_func)
2445                          (info->stream, "%s ",
2446                           logical_cond_64_names[GET_COND (insn)]);
2447                        break;
2448                      case 'u':
2449                        (*info->fprintf_func)
2450                          (info->stream, "%s ",
2451                           unit_cond_names[GET_COND (insn)]);
2452                        break;
2453                      case 'U':
2454                        (*info->fprintf_func)
2455                          (info->stream, "%s ",
2456                           unit_cond_64_names[GET_COND (insn)]);
2457                        break;
2458                      case 'y':
2459                      case 'x':
2460                      case 'b':
2461                        (*info->fprintf_func)
2462                          (info->stream, "%s",
2463                           shift_cond_names[GET_FIELD (insn, 16, 18)]);
2464
2465                        /* If the next character in args is 'n', it will handle
2466                           putting out the space.  */
2467                        if (s[1] != 'n')
2468                          (*info->fprintf_func) (info->stream, " ");
2469                        break;
2470                      case 'X':
2471                        (*info->fprintf_func)
2472                          (info->stream, "%s ",
2473                           shift_cond_64_names[GET_FIELD (insn, 16, 18)]);
2474                        break;
2475                      case 'B':
2476                        (*info->fprintf_func)
2477                          (info->stream, "%s",
2478                           bb_cond_64_names[GET_FIELD (insn, 16, 16)]);
2479
2480                        /* If the next character in args is 'n', it will handle
2481                           putting out the space.  */
2482                        if (s[1] != 'n')
2483                          (*info->fprintf_func) (info->stream, " ");
2484                        break;
2485                      }
2486                    break;
2487                  }
2488
2489                case 'V':
2490                  fput_const (extract_5_store (insn), info);
2491                  break;
2492                case 'r':
2493                  fput_const (extract_5r_store (insn), info);
2494                  break;
2495                case 'R':
2496                  fput_const (extract_5R_store (insn), info);
2497                  break;
2498                case 'U':
2499                  fput_const (extract_10U_store (insn), info);
2500                  break;
2501                case 'B':
2502                case 'Q':
2503                  fput_const (extract_5Q_store (insn), info);
2504                  break;
2505                case 'i':
2506                  fput_const (extract_11 (insn), info);
2507                  break;
2508                case 'j':
2509                  fput_const (extract_14 (insn), info);
2510                  break;
2511                case 'k':
2512                  fputs_filtered ("L%", info);
2513                  fput_const (extract_21 (insn), info);
2514                  break;
2515                case '<':
2516                case 'l':
2517                  /* 16-bit long disp., PA2.0 wide only.  */
2518                  fput_const (extract_16 (insn), info);
2519                  break;
2520                case 'n':
2521                  if (insn & 0x2)
2522                    (*info->fprintf_func) (info->stream, ",n ");
2523                  else
2524                    (*info->fprintf_func) (info->stream, " ");
2525                  break;
2526                case 'N':
2527                  if ((insn & 0x20) && s[1])
2528                    (*info->fprintf_func) (info->stream, ",n ");
2529                  else if (insn & 0x20)
2530                    (*info->fprintf_func) (info->stream, ",n");
2531                  else if (s[1])
2532                    (*info->fprintf_func) (info->stream, " ");
2533                  break;
2534                case 'w':
2535                  (*info->print_address_func)
2536                    (memaddr + 8 + extract_12 (insn), info);
2537                  break;
2538                case 'W':
2539                  /* 17 bit PC-relative branch.  */
2540                  (*info->print_address_func)
2541                    ((memaddr + 8 + extract_17 (insn)), info);
2542                  break;
2543                case 'z':
2544                  /* 17 bit displacement.  This is an offset from a register
2545                     so it gets disasssembled as just a number, not any sort
2546                     of address.  */
2547                  fput_const (extract_17 (insn), info);
2548                  break;
2549
2550                case 'Z':
2551                  /* addil %r1 implicit output.  */
2552                  fputs_filtered ("r1", info);
2553                  break;
2554
2555                case 'Y':
2556                  /* be,l %sr0,%r31 implicit output.  */
2557                  fputs_filtered ("sr0,r31", info);
2558                  break;
2559
2560                case '@':
2561                  (*info->fprintf_func) (info->stream, "0");
2562                  break;
2563
2564                case '.':
2565                  (*info->fprintf_func) (info->stream, "%d",
2566                                         GET_FIELD (insn, 24, 25));
2567                  break;
2568                case '*':
2569                  (*info->fprintf_func) (info->stream, "%d",
2570                                         GET_FIELD (insn, 22, 25));
2571                  break;
2572                case '!':
2573                  fputs_filtered ("sar", info);
2574                  break;
2575                case 'p':
2576                  (*info->fprintf_func) (info->stream, "%d",
2577                                         31 - GET_FIELD (insn, 22, 26));
2578                  break;
2579                case '~':
2580                  {
2581                    int num;
2582                    num = GET_FIELD (insn, 20, 20) << 5;
2583                    num |= GET_FIELD (insn, 22, 26);
2584                    (*info->fprintf_func) (info->stream, "%d", 63 - num);
2585                    break;
2586                  }
2587                case 'P':
2588                  (*info->fprintf_func) (info->stream, "%d",
2589                                         GET_FIELD (insn, 22, 26));
2590                  break;
2591                case 'q':
2592                  {
2593                    int num;
2594                    num = GET_FIELD (insn, 20, 20) << 5;
2595                    num |= GET_FIELD (insn, 22, 26);
2596                    (*info->fprintf_func) (info->stream, "%d", num);
2597                    break;
2598                  }
2599                case 'T':
2600                  (*info->fprintf_func) (info->stream, "%d",
2601                                         32 - GET_FIELD (insn, 27, 31));
2602                  break;
2603                case '%':
2604                  {
2605                    int num;
2606                    num = (GET_FIELD (insn, 23, 23) + 1) * 32;
2607                    num -= GET_FIELD (insn, 27, 31);
2608                    (*info->fprintf_func) (info->stream, "%d", num);
2609                    break;
2610                  }
2611                case '|':
2612                  {
2613                    int num;
2614                    num = (GET_FIELD (insn, 19, 19) + 1) * 32;
2615                    num -= GET_FIELD (insn, 27, 31);
2616                    (*info->fprintf_func) (info->stream, "%d", num);
2617                    break;
2618                  }
2619                case '$':
2620                  fput_const (GET_FIELD (insn, 20, 28), info);
2621                  break;
2622                case 'A':
2623                  fput_const (GET_FIELD (insn, 6, 18), info);
2624                  break;
2625                case 'D':
2626                  fput_const (GET_FIELD (insn, 6, 31), info);
2627                  break;
2628                case 'v':
2629                  (*info->fprintf_func) (info->stream, ",%d",
2630                                         GET_FIELD (insn, 23, 25));
2631                  break;
2632                case 'O':
2633                  fput_const ((GET_FIELD (insn, 6,20) << 5 |
2634                               GET_FIELD (insn, 27, 31)), info);
2635                  break;
2636                case 'o':
2637                  fput_const (GET_FIELD (insn, 6, 20), info);
2638                  break;
2639                case '2':
2640                  fput_const ((GET_FIELD (insn, 6, 22) << 5 |
2641                               GET_FIELD (insn, 27, 31)), info);
2642                  break;
2643                case '1':
2644                  fput_const ((GET_FIELD (insn, 11, 20) << 5 |
2645                               GET_FIELD (insn, 27, 31)), info);
2646                  break;
2647                case '0':
2648                  fput_const ((GET_FIELD (insn, 16, 20) << 5 |
2649                               GET_FIELD (insn, 27, 31)), info);
2650                  break;
2651                case 'u':
2652                  (*info->fprintf_func) (info->stream, ",%d",
2653                                         GET_FIELD (insn, 23, 25));
2654                  break;
2655                case 'F':
2656                  /* If no destination completer and not before a completer
2657                     for fcmp, need a space here.  */
2658                  if (s[1] == 'G' || s[1] == '?')
2659                    fputs_filtered
2660                      (float_format_names[GET_FIELD (insn, 19, 20)], info);
2661                  else
2662                    (*info->fprintf_func)
2663                      (info->stream, "%s ",
2664                       float_format_names[GET_FIELD (insn, 19, 20)]);
2665                  break;
2666                case 'G':
2667                  (*info->fprintf_func)
2668                    (info->stream, "%s ",
2669                     float_format_names[GET_FIELD (insn, 17, 18)]);
2670                  break;
2671                case 'H':
2672                  if (GET_FIELD (insn, 26, 26) == 1)
2673                    (*info->fprintf_func) (info->stream, "%s ",
2674                                           float_format_names[0]);
2675                  else
2676                    (*info->fprintf_func) (info->stream, "%s ",
2677                                           float_format_names[1]);
2678                  break;
2679                case 'I':
2680                  /* If no destination completer and not before a completer
2681                     for fcmp, need a space here.  */
2682                  if (s[1] == '?')
2683                    fputs_filtered
2684                      (float_format_names[GET_FIELD (insn, 20, 20)], info);
2685                  else
2686                    (*info->fprintf_func)
2687                      (info->stream, "%s ",
2688                       float_format_names[GET_FIELD (insn, 20, 20)]);
2689                  break;
2690
2691                case 'J':
2692                  fput_const (extract_14 (insn), info);
2693                  break;
2694
2695                case '#':
2696                  {
2697                    int sign = GET_FIELD (insn, 31, 31);
2698                    int imm10 = GET_FIELD (insn, 18, 27);
2699                    int disp;
2700
2701                    if (sign)
2702                      disp = (-1 << 10) | imm10;
2703                    else
2704                      disp = imm10;
2705
2706                    disp <<= 3;
2707                    fput_const (disp, info);
2708                    break;
2709                  }
2710                case 'K':
2711                case 'd':
2712                  {
2713                    int sign = GET_FIELD (insn, 31, 31);
2714                    int imm11 = GET_FIELD (insn, 18, 28);
2715                    int disp;
2716
2717                    if (sign)
2718                      disp = (-1 << 11) | imm11;
2719                    else
2720                      disp = imm11;
2721
2722                    disp <<= 2;
2723                    fput_const (disp, info);
2724                    break;
2725                  }
2726
2727                case '>':
2728                case 'y':
2729                  {
2730                    /* 16-bit long disp., PA2.0 wide only.  */
2731                    int disp = extract_16 (insn);
2732                    disp &= ~3;
2733                    fput_const (disp, info);
2734                    break;
2735                  }
2736
2737                case '&':
2738                  {
2739                    /* 16-bit long disp., PA2.0 wide only.  */
2740                    int disp = extract_16 (insn);
2741                    disp &= ~7;
2742                    fput_const (disp, info);
2743                    break;
2744                  }
2745
2746                case '_':
2747                  break; /* Dealt with by '{' */
2748
2749                case '{':
2750                  {
2751                    int sub = GET_FIELD (insn, 14, 16);
2752                    int df = GET_FIELD (insn, 17, 18);
2753                    int sf = GET_FIELD (insn, 19, 20);
2754                    const char * const * source = float_format_names;
2755                    const char * const * dest = float_format_names;
2756                    const char *t = "";
2757
2758                    if (sub == 4)
2759                      {
2760                        fputs_filtered (",UND ", info);
2761                        break;
2762                      }
2763                    if ((sub & 3) == 3)
2764                      t = ",t";
2765                    if ((sub & 3) == 1)
2766                      source = sub & 4 ? fcnv_ufixed_names : fcnv_fixed_names;
2767                    if (sub & 2)
2768                      dest = sub & 4 ? fcnv_ufixed_names : fcnv_fixed_names;
2769
2770                    (*info->fprintf_func) (info->stream, "%s%s%s ",
2771                                           t, source[sf], dest[df]);
2772                    break;
2773                  }
2774
2775                case 'm':
2776                  {
2777                    int y = GET_FIELD (insn, 16, 18);
2778
2779                    if (y != 1)
2780                      fput_const ((y ^ 1) - 1, info);
2781                  }
2782                  break;
2783
2784                case 'h':
2785                  {
2786                    int cbit;
2787
2788                    cbit = GET_FIELD (insn, 16, 18);
2789
2790                    if (cbit > 0)
2791                      (*info->fprintf_func) (info->stream, ",%d", cbit - 1);
2792                    break;
2793                  }
2794
2795                case '=':
2796                  {
2797                    int cond = GET_FIELD (insn, 27, 31);
2798
2799                    switch (cond)
2800                      {
2801                      case  0: fputs_filtered (" ", info); break;
2802                      case  1: fputs_filtered ("acc ", info); break;
2803                      case  2: fputs_filtered ("rej ", info); break;
2804                      case  5: fputs_filtered ("acc8 ", info); break;
2805                      case  6: fputs_filtered ("rej8 ", info); break;
2806                      case  9: fputs_filtered ("acc6 ", info); break;
2807                      case 13: fputs_filtered ("acc4 ", info); break;
2808                      case 17: fputs_filtered ("acc2 ", info); break;
2809                      default: break;
2810                      }
2811                    break;
2812                  }
2813
2814                case 'X':
2815                  (*info->print_address_func)
2816                    (memaddr + 8 + extract_22 (insn), info);
2817                  break;
2818                case 'L':
2819                  fputs_filtered (",rp", info);
2820                  break;
2821                default:
2822                  (*info->fprintf_func) (info->stream, "%c", *s);
2823                  break;
2824                }
2825            }
2826          return sizeof (insn);
2827        }
2828    }
2829  (*info->fprintf_func) (info->stream, "#%8x", insn);
2830  return sizeof (insn);
2831}
2832