/* Opcode table for the Alpha.

   Copyright 1993 Free Software Foundation, Inc.
   
   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2, or (at your option)
   any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */

/*
  Contributed by sac@cygnus.com
*/


/* Alpha opcode format */
#define RA(x) (((x)>>21)& 0x1f)
#define RB(x) (((x)>>16)& 0x1f)
#define RC(x) (((x)>>0) & 0x1f)
#define DISP(x) ((((x) & 0xffff) ^ 0x8000)-0x8000)
#define BDISP(x) ((((x) & 0x1fffff) ^ 0x100000)-0x100000)
#define OPCODE(x) (((x) >>26)&0x3f)
#define JUMP_OPTYPE(x) (((x)>>14) & 0xf)
#define JUMP_HINT(x) ((x) & 0x3fff)
#define JDISP(x) ((((x) & 0x3fff) ^ 0x2000)-0x2000)
#define OP_OPTYPE(x) (((x)>>5)&0x7f)
#define OP_IS_CONSTANT(x) ((x) & (1<<12))
#define LITERAL(x) (((x)>>13) & 0xff)


/* Shapes

   Memory instruction format    oooo ooaa aaab bbbb dddd dddd dddd dddd
   Memory with function         oooo ooaa aaab bbbb ffff ffff ffff ffff
   Memory branch                oooo ooaa aaab bbbb BBff ffff ffff ffff
   Branch                       oooo ooaa aaad dddd dddd dddd dddd dddd
   Operate reg                  oooo ooaa aaab bbbb ***F ffff fffc cccc
   Operate cont                 oooo ooaa aaal llll lll1 ffff fffc cccc
   FP reg                       oooo ooaa aaab bbbb 000f ffff fffc cccc
   Pal                          oooo oodd dddd dddd dddd dddd dddd dddd

*/

#define MEMORY_FORMAT_MASK 		0xfc000000
#define MEMORY_BRANCH_FORMAT_MASK 	0xfc00c000
#define BRANCH_FORMAT_MASK    		0xfc000000
#define OPERATE_FORMAT_MASK		0xfc000fe0
#define FLOAT_FORMAT_MASK		0xfc000fe0
typedef struct 

{
  unsigned i;
  char *name;
  int type;
} alpha_insn;
#ifdef DEFINE_TABLE

char *alpha_regs[32] =
{
  "v0",
  "t0", "t1", "t2", "t3", "t4", "t5", "t6", "t7",
  "s0", "s1", "s2", "s3", "s4", "s5",
  "fp",
  "a0", "a1", "a2", "a3", "a4", "a5",
  "t8", "t9", "t10", "t11",
  "ra", "t12", "at", "gp", "sp", "zero"
};

#define MEMORY_FORMAT_CODE 1
#define MEMORY_FORMAT(op, name) \
 { op << 26, name, MEMORY_FORMAT_CODE }

#define MEMORY_BRANCH_FORMAT_CODE 2
#define MEMORY_BRANCH_FORMAT(op, func, name) \
{ (op<<26)+(func<<14),name, MEMORY_BRANCH_FORMAT_CODE }

#define MEMORY_FUNCTION_FORMAT_CODE 3
#define MEMORY_FORMAT_FUNCTION(op, func, name) \
 { (op<<26)+(func), name, MEMORY_FUNCTION_FORMAT_CODE }

#define BRANCH_FORMAT_CODE  4
#define BRANCH_FORMAT(op, name) \
 { (op<<26), name , BRANCH_FORMAT_CODE }

#define OPERATE_FORMAT_CODE 5
#define OPERATE_FORMAT(op, extra,name)  \
 {(op<<26)+(extra<<5),name , OPERATE_FORMAT_CODE}

#define FLOAT_FORMAT_CODE 6
#define FLOAT_FORMAT(op, extra,name) \
{(op<<26)+(extra<<5),name , FLOAT_FORMAT_CODE }

#define PAL_FORMAT_CODE 7
#define PAL_FORMAT(op, extra, name) \
{(op<<26)+(extra),name, PAL_FORMAT_CODE}  

#define FLOAT_MEMORY_FORMAT_CODE 8
#define FLOAT_MEMORY_FORMAT(op, name) \
 { op << 26, name, FLOAT_MEMORY_FORMAT_CODE }

#define FLOAT_BRANCH_FORMAT_CODE  9
#define FLOAT_BRANCH_FORMAT(op, name) \
 { (op<<26), name , FLOAT_BRANCH_FORMAT_CODE }



alpha_insn alpha_insn_set[] =
{
  
/* Memory format instruction opcodes */
MEMORY_FORMAT(0x08,"lda"),
FLOAT_MEMORY_FORMAT(0x21,"ldg"),
MEMORY_FORMAT(0x29,"ldq"),
FLOAT_MEMORY_FORMAT(0x22,"lds"),
FLOAT_MEMORY_FORMAT(0x25,"stg"),
MEMORY_FORMAT(0x2d,"stq"),
FLOAT_MEMORY_FORMAT(0x26,"sts"),
MEMORY_FORMAT(0x09,"ldah"),
MEMORY_FORMAT(0x28,"ldl"),
MEMORY_FORMAT(0x2b,"ldq_l"),
FLOAT_MEMORY_FORMAT(0x23,"ldt"),
MEMORY_FORMAT(0x2c,"stl"),
MEMORY_FORMAT(0x2f,"stq_c"),
FLOAT_MEMORY_FORMAT(0x27,"stt"),
FLOAT_MEMORY_FORMAT(0x20,"ldf"),
MEMORY_FORMAT(0x2a,"ldl_l"),
MEMORY_FORMAT(0x0b,"ldq_u"),
FLOAT_MEMORY_FORMAT(0x24,"stf"),
MEMORY_FORMAT(0x2e,"stl_c"),
MEMORY_FORMAT(0x0f,"stq_u"),

/* Memory format instructions with a function code */
MEMORY_FORMAT_FUNCTION(0x18, 0x8000,"fetch"),
MEMORY_FORMAT_FUNCTION(0x18, 0xe000,"rc"),
MEMORY_FORMAT_FUNCTION(0x18, 0x0000,"trapb"),
MEMORY_FORMAT_FUNCTION(0x18, 0xa000,"fetch_m"),
MEMORY_FORMAT_FUNCTION(0x18, 0xc000,"rpcc"),
MEMORY_FORMAT_FUNCTION(0x18, 0x4000,"mb"),
MEMORY_FORMAT_FUNCTION(0x18, 0xf000,"rs"),

MEMORY_BRANCH_FORMAT(0x1a, 0x0, "jmp"),
MEMORY_BRANCH_FORMAT(0x1a, 0x2, "ret"),
MEMORY_BRANCH_FORMAT(0x1a, 0x1, "jsr"),
MEMORY_BRANCH_FORMAT(0x1a, 0x3, "jsr_coroutine"),


BRANCH_FORMAT(0x30,"br"),
FLOAT_BRANCH_FORMAT(0x33,"fble"),
FLOAT_BRANCH_FORMAT(0x36,"fbge"),
BRANCH_FORMAT(0x39,"beq"),
BRANCH_FORMAT(0x3c,"blbs"),
BRANCH_FORMAT(0x3f,"bgt"),
FLOAT_BRANCH_FORMAT(0x31,"fbeq"),
BRANCH_FORMAT(0x34,"bsr"),
FLOAT_BRANCH_FORMAT(0x37,"fbgt"),
BRANCH_FORMAT(0x3a,"blt"),
BRANCH_FORMAT(0x3d,"bne"),
FLOAT_BRANCH_FORMAT(0x32,"fblt"),
FLOAT_BRANCH_FORMAT(0x35,"fbne"),
BRANCH_FORMAT(0x38,"blbc"),
BRANCH_FORMAT(0x3b,"ble"),
BRANCH_FORMAT(0x3e,"bge"),

OPERATE_FORMAT(0x10,0x00,"addl"),
OPERATE_FORMAT(0x10,0x02,"s4addl"),
OPERATE_FORMAT(0x10,0x09,"subl"),
OPERATE_FORMAT(0x10,0x0b,"s4subl"),
OPERATE_FORMAT(0x10,0x0f,"cmpbge"),
OPERATE_FORMAT(0x10,0x12,"s8addl"),
OPERATE_FORMAT(0x10,0x1b,"s8subl"),
OPERATE_FORMAT(0x10,0x1d,"cmpult"),
OPERATE_FORMAT(0x10,0x20,"addq"),
OPERATE_FORMAT(0x10,0x22,"s4addq"),
OPERATE_FORMAT(0x10,0x29,"subq"),
OPERATE_FORMAT(0x10,0x2b,"s4subq"),
OPERATE_FORMAT(0x10,0x2d,"cmpeq"),
OPERATE_FORMAT(0x10,0x32,"s8addq"),
OPERATE_FORMAT(0x10,0x3b,"s8subq"),
OPERATE_FORMAT(0x10,0x3d,"cmpule"),
OPERATE_FORMAT(0x10,0x40,"addlv"),
OPERATE_FORMAT(0x10,0x49,"sublv"),
OPERATE_FORMAT(0x10,0x4d,"cmplt"),
OPERATE_FORMAT(0x10,0x60,"addqv"),
OPERATE_FORMAT(0x10,0x69,"subqv"),
OPERATE_FORMAT(0x10,0x6d,"cmple"),
OPERATE_FORMAT(0x11,0x00,"and"),
OPERATE_FORMAT(0x11,0x08,"bic"),
OPERATE_FORMAT(0x11,0x14,"cmovlbs"),
OPERATE_FORMAT(0x11,0x16,"cmovlbc"),
OPERATE_FORMAT(0x11,0x20,"bis"),
OPERATE_FORMAT(0x11,0x24,"cmoveq"),
OPERATE_FORMAT(0x11,0x26,"cmovne"),
OPERATE_FORMAT(0x11,0x28,"ornot"),
OPERATE_FORMAT(0x11,0x40,"xor"),
OPERATE_FORMAT(0x11,0x44,"cmovlt"),
OPERATE_FORMAT(0x11,0x46,"cmovge"),
OPERATE_FORMAT(0x11,0x48,"eqv"),
OPERATE_FORMAT(0x11,0x64,"cmovle"),
OPERATE_FORMAT(0x11,0x66,"cmovgt"),
OPERATE_FORMAT(0x12,0x02,"mskbl"),
OPERATE_FORMAT(0x12,0x06,"extbl"),
OPERATE_FORMAT(0x12,0x0b,"insbl"),
OPERATE_FORMAT(0x12,0x12,"mskwl"),
OPERATE_FORMAT(0x12,0x16,"extwl"),
OPERATE_FORMAT(0x12,0x1b,"inswl"),
OPERATE_FORMAT(0x12,0x22,"mskll"),
OPERATE_FORMAT(0x12,0x26,"extll"),
OPERATE_FORMAT(0x12,0x2b,"insll"),
OPERATE_FORMAT(0x12,0x30,"zap"),
OPERATE_FORMAT(0x12,0x31,"zapnot"),
OPERATE_FORMAT(0x12,0x32,"mskql"),
OPERATE_FORMAT(0x12,0x34,"srl"),
OPERATE_FORMAT(0x12,0x36,"extql"),
OPERATE_FORMAT(0x12,0x39,"sll"),
OPERATE_FORMAT(0x12,0x3b,"insql"),
OPERATE_FORMAT(0x12,0x3c,"sra"),
OPERATE_FORMAT(0x12,0x52,"mskwh"),
OPERATE_FORMAT(0x12,0x57,"inswh"),
OPERATE_FORMAT(0x12,0x5a,"extwh"),
OPERATE_FORMAT(0x12,0x62,"msklh"),
OPERATE_FORMAT(0x12,0x67,"inslh"),
OPERATE_FORMAT(0x12,0x6a,"extlh"),
OPERATE_FORMAT(0x12,0x72,"mskqh"),
OPERATE_FORMAT(0x12,0x77,"insqh"),
OPERATE_FORMAT(0x12,0x7a,"extqh"),
OPERATE_FORMAT(0x13,0x00,"mull"),
OPERATE_FORMAT(0x13,0x20,"mulq"),
OPERATE_FORMAT(0x13,0x30,"umulh"),
OPERATE_FORMAT(0x13,0x40,"mullv"),
OPERATE_FORMAT(0x13,0x60,"mulqv"),

FLOAT_FORMAT(0x17,0x20,"cpys"),
FLOAT_FORMAT(0x17,0x21,"cpysn"),
FLOAT_FORMAT(0x17,0x22,"cpyse"),
FLOAT_FORMAT(0x17,0x24,"mt_fpcr"),
FLOAT_FORMAT(0x17,0x25,"mf_fpcr"),
FLOAT_FORMAT(0x17,0x2a,"fcmoveq"),
FLOAT_FORMAT(0x17,0x2b,"fcmovne"),
FLOAT_FORMAT(0x17,0x2c,"fcmovlt"),
FLOAT_FORMAT(0x17,0x2d,"fcmovge"),
FLOAT_FORMAT(0x17,0x2e,"fcmovle"),
FLOAT_FORMAT(0x17,0x2f,"fcmovgt"),
FLOAT_FORMAT(0x17,0x10,"cvtlq"),
FLOAT_FORMAT(0x17,0x30,"cvtql"),
FLOAT_FORMAT(0x17,0x130,"cvtql/v"),
FLOAT_FORMAT(0x17,0x530,"cvtql/sv"),

FLOAT_FORMAT(0x16,0x080,"adds"),
FLOAT_FORMAT(0x16,0x000,"adds/c"),
FLOAT_FORMAT(0x16,0x040,"adds/m"),
FLOAT_FORMAT(0x16,0x0c0,"adds/d"),
FLOAT_FORMAT(0x16,0x180,"adds/u"),
FLOAT_FORMAT(0x16,0x100,"adds/uc"),
FLOAT_FORMAT(0x16,0x140,"adds/um"),
FLOAT_FORMAT(0x16,0x1c0,"adds/ud"),
FLOAT_FORMAT(0x16,0x580,"adds/su"),
FLOAT_FORMAT(0x16,0x500,"adds/suc"),
FLOAT_FORMAT(0x16,0x540,"adds/sum"),
FLOAT_FORMAT(0x16,0x5c0,"adds/sud"),
FLOAT_FORMAT(0x16,0x780,"adds/sui"),
FLOAT_FORMAT(0x16,0x700,"adds/suic"),
FLOAT_FORMAT(0x16,0x740,"adds/suim"),
FLOAT_FORMAT(0x16,0x7c0,"adds/suid"),
FLOAT_FORMAT(0x16,0x0a0,"addt"),
FLOAT_FORMAT(0x16,0x020,"addt/c"),
FLOAT_FORMAT(0x16,0x060,"addt/m"),
FLOAT_FORMAT(0x16,0x0e0,"addt/d"),
FLOAT_FORMAT(0x16,0x1a0,"addt/u"),
FLOAT_FORMAT(0x16,0x120,"addt/uc"),
FLOAT_FORMAT(0x16,0x160,"addt/um"),
FLOAT_FORMAT(0x16,0x1e0,"addt/ud"),
FLOAT_FORMAT(0x16,0x5a0,"addt/su"),
FLOAT_FORMAT(0x16,0x520,"addt/suc"),
FLOAT_FORMAT(0x16,0x560,"addt/sum"),
FLOAT_FORMAT(0x16,0x5e0,"addt/sud"),
FLOAT_FORMAT(0x16,0x7a0,"addt/sui"),
FLOAT_FORMAT(0x16,0x720,"addt/suic"),
FLOAT_FORMAT(0x16,0x760,"addt/suim"),
FLOAT_FORMAT(0x16,0x7e0,"addt/suid"),
FLOAT_FORMAT(0x16,0x0a5,"cmpteq"),
FLOAT_FORMAT(0x16,0x025,"cmpteq/c"),
FLOAT_FORMAT(0x16,0x065,"cmpteq/m"),
FLOAT_FORMAT(0x16,0x0e5,"cmpteq/d"),
FLOAT_FORMAT(0x16,0x1a5,"cmpteq/u"),
FLOAT_FORMAT(0x16,0x125,"cmpteq/uc"),
FLOAT_FORMAT(0x16,0x165,"cmpteq/um"),
FLOAT_FORMAT(0x16,0x1e5,"cmpteq/ud"),
FLOAT_FORMAT(0x16,0x5a5,"cmpteq/su"),
FLOAT_FORMAT(0x16,0x525,"cmpteq/suc"),
FLOAT_FORMAT(0x16,0x565,"cmpteq/sum"),
FLOAT_FORMAT(0x16,0x5e5,"cmpteq/sud"),
FLOAT_FORMAT(0x16,0x7a5,"cmpteq/sui"),
FLOAT_FORMAT(0x16,0x725,"cmpteq/suic"),
FLOAT_FORMAT(0x16,0x765,"cmpteq/suim"),
FLOAT_FORMAT(0x16,0x7e5,"cmpteq/suid"),
FLOAT_FORMAT(0x16,0x0a6,"cmptlt"),
FLOAT_FORMAT(0x16,0x026,"cmptlt/c"),
FLOAT_FORMAT(0x16,0x066,"cmptlt/m"),
FLOAT_FORMAT(0x16,0x0e6,"cmptlt/d"),
FLOAT_FORMAT(0x16,0x1a6,"cmptlt/u"),
FLOAT_FORMAT(0x16,0x126,"cmptlt/uc"),
FLOAT_FORMAT(0x16,0x166,"cmptlt/um"),
FLOAT_FORMAT(0x16,0x1e6,"cmptlt/ud"),
FLOAT_FORMAT(0x16,0x5a6,"cmptlt/su"),
FLOAT_FORMAT(0x16,0x526,"cmptlt/suc"),
FLOAT_FORMAT(0x16,0x566,"cmptlt/sum"),
FLOAT_FORMAT(0x16,0x5e6,"cmptlt/sud"),
FLOAT_FORMAT(0x16,0x7a6,"cmptlt/sui"),
FLOAT_FORMAT(0x16,0x726,"cmptlt/suic"),
FLOAT_FORMAT(0x16,0x766,"cmptlt/suim"),
FLOAT_FORMAT(0x16,0x7e6,"cmptlt/suid"),
FLOAT_FORMAT(0x16,0x0a7,"cmptle"),
FLOAT_FORMAT(0x16,0x027,"cmptle/c"),
FLOAT_FORMAT(0x16,0x067,"cmptle/m"),
FLOAT_FORMAT(0x16,0x0e7,"cmptle/d"),
FLOAT_FORMAT(0x16,0x1a7,"cmptle/u"),
FLOAT_FORMAT(0x16,0x127,"cmptle/uc"),
FLOAT_FORMAT(0x16,0x167,"cmptle/um"),
FLOAT_FORMAT(0x16,0x1e7,"cmptle/ud"),
FLOAT_FORMAT(0x16,0x5a7,"cmptle/su"),
FLOAT_FORMAT(0x16,0x527,"cmptle/suc"),
FLOAT_FORMAT(0x16,0x567,"cmptle/sum"),
FLOAT_FORMAT(0x16,0x5e7,"cmptle/sud"),
FLOAT_FORMAT(0x16,0x7a7,"cmptle/sui"),
FLOAT_FORMAT(0x16,0x727,"cmptle/suic"),
FLOAT_FORMAT(0x16,0x767,"cmptle/suim"),
FLOAT_FORMAT(0x16,0x7e7,"cmptle/suid"),
FLOAT_FORMAT(0x16,0x0a4,"cmptun"),
FLOAT_FORMAT(0x16,0x024,"cmptun/c"),
FLOAT_FORMAT(0x16,0x064,"cmptun/m"),
FLOAT_FORMAT(0x16,0x0e4,"cmptun/d"),
FLOAT_FORMAT(0x16,0x1a4,"cmptun/u"),
FLOAT_FORMAT(0x16,0x124,"cmptun/uc"),
FLOAT_FORMAT(0x16,0x164,"cmptun/um"),
FLOAT_FORMAT(0x16,0x1e4,"cmptun/ud"),
FLOAT_FORMAT(0x16,0x5a4,"cmptun/su"),
FLOAT_FORMAT(0x16,0x524,"cmptun/suc"),
FLOAT_FORMAT(0x16,0x564,"cmptun/sum"),
FLOAT_FORMAT(0x16,0x5e4,"cmptun/sud"),
FLOAT_FORMAT(0x16,0x7a4,"cmptun/sui"),
FLOAT_FORMAT(0x16,0x724,"cmptun/suic"),
FLOAT_FORMAT(0x16,0x764,"cmptun/suim"),
FLOAT_FORMAT(0x16,0x7e4,"cmptun/suid"),
FLOAT_FORMAT(0x16,0x0bc,"cvtqs"),
FLOAT_FORMAT(0x16,0x03c,"cvtqs/c"),
FLOAT_FORMAT(0x16,0x07c,"cvtqs/m"),
FLOAT_FORMAT(0x16,0x0fc,"cvtqs/d"),
FLOAT_FORMAT(0x16,0x1bc,"cvtqs/u"),
FLOAT_FORMAT(0x16,0x13c,"cvtqs/uc"),
FLOAT_FORMAT(0x16,0x17c,"cvtqs/um"),
FLOAT_FORMAT(0x16,0x1fc,"cvtqs/ud"),
FLOAT_FORMAT(0x16,0x5bc,"cvtqs/su"),
FLOAT_FORMAT(0x16,0x53c,"cvtqs/suc"),
FLOAT_FORMAT(0x16,0x57c,"cvtqs/sum"),
FLOAT_FORMAT(0x16,0x5fc,"cvtqs/sud"),
FLOAT_FORMAT(0x16,0x7bc,"cvtqs/sui"),
FLOAT_FORMAT(0x16,0x73c,"cvtqs/suic"),
FLOAT_FORMAT(0x16,0x77c,"cvtqs/suim"),
FLOAT_FORMAT(0x16,0x7fc,"cvtqs/suid"),
FLOAT_FORMAT(0x16,0x0be,"cvtqt"),
FLOAT_FORMAT(0x16,0x03e,"cvtqt/c"),
FLOAT_FORMAT(0x16,0x07e,"cvtqt/m"),
FLOAT_FORMAT(0x16,0x0fe,"cvtqt/d"),
FLOAT_FORMAT(0x16,0x1be,"cvtqt/u"),
FLOAT_FORMAT(0x16,0x13e,"cvtqt/uc"),
FLOAT_FORMAT(0x16,0x17e,"cvtqt/um"),
FLOAT_FORMAT(0x16,0x1fe,"cvtqt/ud"),
FLOAT_FORMAT(0x16,0x5be,"cvtqt/su"),
FLOAT_FORMAT(0x16,0x53e,"cvtqt/suc"),
FLOAT_FORMAT(0x16,0x57e,"cvtqt/sum"),
FLOAT_FORMAT(0x16,0x5fe,"cvtqt/sud"),
FLOAT_FORMAT(0x16,0x7be,"cvtqt/sui"),
FLOAT_FORMAT(0x16,0x73e,"cvtqt/suic"),
FLOAT_FORMAT(0x16,0x77e,"cvtqt/suim"),
FLOAT_FORMAT(0x16,0x7fe,"cvtqt/suid"),
FLOAT_FORMAT(0x16,0x0ac,"cvtts"),
FLOAT_FORMAT(0x16,0x02c,"cvtts/c"),
FLOAT_FORMAT(0x16,0x06c,"cvtts/m"),
FLOAT_FORMAT(0x16,0x0ec,"cvtts/d"),
FLOAT_FORMAT(0x16,0x1ac,"cvtts/u"),
FLOAT_FORMAT(0x16,0x12c,"cvtts/uc"),
FLOAT_FORMAT(0x16,0x16c,"cvtts/um"),
FLOAT_FORMAT(0x16,0x1ec,"cvtts/ud"),
FLOAT_FORMAT(0x16,0x5ac,"cvtts/su"),
FLOAT_FORMAT(0x16,0x52c,"cvtts/suc"),
FLOAT_FORMAT(0x16,0x56c,"cvtts/sum"),
FLOAT_FORMAT(0x16,0x5ec,"cvtts/sud"),
FLOAT_FORMAT(0x16,0x7ac,"cvtts/sui"),
FLOAT_FORMAT(0x16,0x72c,"cvtts/suic"),
FLOAT_FORMAT(0x16,0x76c,"cvtts/suim"),
FLOAT_FORMAT(0x16,0x7ec,"cvtts/suid"),
FLOAT_FORMAT(0x16,0x083,"divs"),
FLOAT_FORMAT(0x16,0x003,"divs/c"),
FLOAT_FORMAT(0x16,0x043,"divs/m"),
FLOAT_FORMAT(0x16,0x0c3,"divs/d"),
FLOAT_FORMAT(0x16,0x183,"divs/u"),
FLOAT_FORMAT(0x16,0x103,"divs/uc"),
FLOAT_FORMAT(0x16,0x143,"divs/um"),
FLOAT_FORMAT(0x16,0x1c3,"divs/ud"),
FLOAT_FORMAT(0x16,0x583,"divs/su"),
FLOAT_FORMAT(0x16,0x503,"divs/suc"),
FLOAT_FORMAT(0x16,0x543,"divs/sum"),
FLOAT_FORMAT(0x16,0x5c3,"divs/sud"),
FLOAT_FORMAT(0x16,0x783,"divs/sui"),
FLOAT_FORMAT(0x16,0x703,"divs/suic"),
FLOAT_FORMAT(0x16,0x743,"divs/suim"),
FLOAT_FORMAT(0x16,0x7c3,"divs/suid"),
FLOAT_FORMAT(0x16,0x0a3,"divt"),
FLOAT_FORMAT(0x16,0x023,"divt/c"),
FLOAT_FORMAT(0x16,0x063,"divt/m"),
FLOAT_FORMAT(0x16,0x0e3,"divt/d"),
FLOAT_FORMAT(0x16,0x1a3,"divt/u"),
FLOAT_FORMAT(0x16,0x123,"divt/uc"),
FLOAT_FORMAT(0x16,0x163,"divt/um"),
FLOAT_FORMAT(0x16,0x1e3,"divt/ud"),
FLOAT_FORMAT(0x16,0x5a3,"divt/su"),
FLOAT_FORMAT(0x16,0x523,"divt/suc"),
FLOAT_FORMAT(0x16,0x563,"divt/sum"),
FLOAT_FORMAT(0x16,0x5e3,"divt/sud"),
FLOAT_FORMAT(0x16,0x7a3,"divt/sui"),
FLOAT_FORMAT(0x16,0x723,"divt/suic"),
FLOAT_FORMAT(0x16,0x763,"divt/suim"),
FLOAT_FORMAT(0x16,0x7e3,"divt/suid"),
FLOAT_FORMAT(0x16,0x082,"muls"),
FLOAT_FORMAT(0x16,0x002,"muls/c"),
FLOAT_FORMAT(0x16,0x042,"muls/m"),
FLOAT_FORMAT(0x16,0x0c2,"muls/d"),
FLOAT_FORMAT(0x16,0x182,"muls/u"),
FLOAT_FORMAT(0x16,0x102,"muls/uc"),
FLOAT_FORMAT(0x16,0x142,"muls/um"),
FLOAT_FORMAT(0x16,0x1c2,"muls/ud"),
FLOAT_FORMAT(0x16,0x582,"muls/su"),
FLOAT_FORMAT(0x16,0x502,"muls/suc"),
FLOAT_FORMAT(0x16,0x542,"muls/sum"),
FLOAT_FORMAT(0x16,0x5c2,"muls/sud"),
FLOAT_FORMAT(0x16,0x782,"muls/sui"),
FLOAT_FORMAT(0x16,0x702,"muls/suic"),
FLOAT_FORMAT(0x16,0x742,"muls/suim"),
FLOAT_FORMAT(0x16,0x7c2,"muls/suid"),
FLOAT_FORMAT(0x16,0x0a2,"mult"),
FLOAT_FORMAT(0x16,0x022,"mult/c"),
FLOAT_FORMAT(0x16,0x062,"mult/m"),
FLOAT_FORMAT(0x16,0x0e2,"mult/d"),
FLOAT_FORMAT(0x16,0x1a2,"mult/u"),
FLOAT_FORMAT(0x16,0x122,"mult/uc"),
FLOAT_FORMAT(0x16,0x162,"mult/um"),
FLOAT_FORMAT(0x16,0x1e2,"mult/ud"),
FLOAT_FORMAT(0x16,0x5a2,"mult/su"),
FLOAT_FORMAT(0x16,0x522,"mult/suc"),
FLOAT_FORMAT(0x16,0x562,"mult/sum"),
FLOAT_FORMAT(0x16,0x5e2,"mult/sud"),
FLOAT_FORMAT(0x16,0x7a2,"mult/sui"),
FLOAT_FORMAT(0x16,0x722,"mult/suic"),
FLOAT_FORMAT(0x16,0x762,"mult/suim"),
FLOAT_FORMAT(0x16,0x7e2,"mult/suid"),
FLOAT_FORMAT(0x16,0x081,"subs"),
FLOAT_FORMAT(0x16,0x001,"subs/c"),
FLOAT_FORMAT(0x16,0x041,"subs/m"),
FLOAT_FORMAT(0x16,0x0c1,"subs/d"),
FLOAT_FORMAT(0x16,0x181,"subs/u"),
FLOAT_FORMAT(0x16,0x101,"subs/uc"),
FLOAT_FORMAT(0x16,0x141,"subs/um"),
FLOAT_FORMAT(0x16,0x1c1,"subs/ud"),
FLOAT_FORMAT(0x16,0x581,"subs/su"),
FLOAT_FORMAT(0x16,0x501,"subs/suc"),
FLOAT_FORMAT(0x16,0x541,"subs/sum"),
FLOAT_FORMAT(0x16,0x5c1,"subs/sud"),
FLOAT_FORMAT(0x16,0x781,"subs/sui"),
FLOAT_FORMAT(0x16,0x701,"subs/suic"),
FLOAT_FORMAT(0x16,0x741,"subs/suim"),
FLOAT_FORMAT(0x16,0x7c1,"subs/suid"),
FLOAT_FORMAT(0x16,0x0a1,"subt"),
FLOAT_FORMAT(0x16,0x021,"subt/c"),
FLOAT_FORMAT(0x16,0x061,"subt/m"),
FLOAT_FORMAT(0x16,0x0e1,"subt/d"),
FLOAT_FORMAT(0x16,0x1a1,"subt/u"),
FLOAT_FORMAT(0x16,0x121,"subt/uc"),
FLOAT_FORMAT(0x16,0x161,"subt/um"),
FLOAT_FORMAT(0x16,0x1e1,"subt/ud"),
FLOAT_FORMAT(0x16,0x5a1,"subt/su"),
FLOAT_FORMAT(0x16,0x521,"subt/suc"),
FLOAT_FORMAT(0x16,0x561,"subt/sum"),
FLOAT_FORMAT(0x16,0x5e1,"subt/sud"),
FLOAT_FORMAT(0x16,0x7a1,"subt/sui"),
FLOAT_FORMAT(0x16,0x721,"subt/suic"),
FLOAT_FORMAT(0x16,0x761,"subt/suim"),
FLOAT_FORMAT(0x16,0x7e1,"subt/suid"),

PAL_FORMAT(0x00, 0x0080,"bpt"),
PAL_FORMAT(0x00, 0x00aa,"gentrap"),
PAL_FORMAT(0x00, 0x009f,"wrunique"),
PAL_FORMAT(0x00, 0x0081,"bugchk"),
PAL_FORMAT(0x00, 0x0086,"imb"),
PAL_FORMAT(0x00, 0x0083,"callsys"),
PAL_FORMAT(0x00, 0x009e,"rdunique"),

	0
};
#endif