/*
 * (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
 * See the copyright notice in the ACK home directory, in the file "Copyright".
 */
#define RCSID3 "$Header$"

/*
 * INTEL 80386 keywords
 *
 * No system registers for now ...
 */

0,	R32,		0,		"ax",
0,	R32,		1,		"cx",
0,	R32,		2,		"dx",
0,	R32,		3,		"bx",
0,	R32,		4,		"sp",
0,	R32,		5,		"bp",
0,	R32,		6,		"si",
0,	R32,		7,		"di",
0,	R32,		0,		"eax",
0,	R32,		1,		"ecx",
0,	R32,		2,		"edx",
0,	R32,		3,		"ebx",
0,	R32,		4,		"esp",
0,	R32,		5,		"ebp",
0,	R32,		6,		"esi",
0,	R32,		7,		"edi",
0,	R8,		0,		"al",
0,	R8,		1,		"cl",
0,	R8,		2,		"dl",
0,	R8,		3,		"bl",
0,	R8,		4,		"ah",
0,	R8,		5,		"ch",
0,	R8,		6,		"dh",
0,	R8,		7,		"bh",
0,	RSEG,		0,		"es",
0,	RSEG,		1,		"cs",
0,	RSEG,		2,		"ss",
0,	RSEG,		3,		"ds",
0,	RSEG,		4,		"fs",
0,	RSEG,		5,		"gs",
0,	RSYSCR,		0,		"cr0",
0,	RSYSCR,		2,		"cr2",
0,	RSYSCR,		3,		"cr3",
0,	RSYSDR,		0,		"dr0",
0,	RSYSDR,		1,		"dr1",
0,	RSYSDR,		2,		"dr2",
0,	RSYSDR,		3,		"dr3",
0,	RSYSDR,		6,		"dr6",
0,	RSYSDR,		7,		"dr7",
0,	RSYSTR,		6,		"tr6",
0,	RSYSTR,		7,		"tr7",
0,	ADDOP,		000,		"addb",
0,	ADDOP,		001,		"add",
0,	ADDOP,		010,		"orb",
0,	ADDOP,		011,		"or",
0,	ADDOP,		020,		"adcb",
0,	ADDOP,		021,		"adc",
0,	ADDOP,		030,		"sbbb",
0,	ADDOP,		031,		"sbb",
0,	ADDOP,		040,		"andb",
0,	ADDOP,		041,		"and",
0,	ADDOP,		050,		"subb",
0,	ADDOP,		051,		"sub",
0,	ADDOP,		060,		"xorb",
0,	ADDOP,		061,		"xor",
0,	ADDOP,		070,		"cmpb",
0,	ADDOP,		071,		"cmp",
0,	BITTEST,	04,		"bt",
0,	BITTEST,	05,		"bts",
0,	BITTEST,	06,		"btr",
0,	BITTEST,	07,		"btc",
0,	CALFOP,		030+(0232<<8),	"callf",
0,	CALFOP,		050+(0352<<8),	"jmpf",
0,	CALLOP,		020+(0350<<8),	"call",
0,	CALLOP,		040+(0351<<8),	"jmp",
0,	ENTER,		0310,		"enter",
0,	EXTEND,		0266,		"movzx",
0,	EXTEND,		0276,		"movsx",
0,	EXTOP,		0002,		"lar",
0,	EXTOP,		0003,		"lsl",
0,	EXTOP,		0274,		"bsf",
0,	EXTOP,		0275,		"bsr",
0,	EXTOP1,		0000,		"sldt",
0,	EXTOP1,		0001,		"sgdt",
0,	EXTOP1,		0010,		"str",
0,	EXTOP1,		0011,		"sidt",
0,	EXTOP1,		0020,		"lldt",
0,	EXTOP1,		0021,		"lgdt",
0,	EXTOP1,		0030,		"ltr",
0,	EXTOP1,		0031,		"lidt",
0,	EXTOP1,		0040,		"verr",
0,	EXTOP1,		0041,		"smsw",
0,	EXTOP1,		0050,		"verw",
0,	EXTOP1,		0061,		"lmsw",
0,	IMUL,		00,		"imul",
0,	IMULB,		01,		"imulb",
0,	INCOP,		000,		"incb",
0,	INCOP,		001,		"inc",
0,	INCOP,		010,		"decb",
0,	INCOP,		011,		"dec",
0,	INT,		0,		"int",
0,	IOOP,		0344,		"inb",
0,	IOOP,		0345,		"in",
0,	IOOP,		0346,		"outb",
0,	IOOP,		0347,		"out",
0,	JOP,		0340,		"loopne",
0,	JOP,		0340,		"loopnz",
0,	JOP,		0341,		"loope",
0,	JOP,		0341,		"loopz",
0,	JOP,		0342,		"loop",
0,	JOP,		0343,		"jcxz",
0,	JOP,		0343,		"jecxz",
0,	JOP2,		0000,		"jo",
0,	JOP2,		0001,		"jno",
0,	JOP2,		0002,		"jb",
0,	JOP2,		0002,		"jnae",
0,	JOP2,		0003,		"jae",
0,	JOP2,		0003,		"jnb",
0,	JOP2,		0004,		"je",
0,	JOP2,		0004,		"jz",
0,	JOP2,		0005,		"jne",
0,	JOP2,		0005,		"jnz",
0,	JOP2,		0006,		"jbe",
0,	JOP2,		0006,		"jna",
0,	JOP2,		0007,		"ja",
0,	JOP2,		0007,		"jnbe",
0,	JOP2,		0010,		"js",
0,	JOP2,		0011,		"jns",
0,	JOP2,		0012,		"jp",
0,	JOP2,		0012,		"jpe",
0,	JOP2,		0013,		"jnp",
0,	JOP2,		0013,		"jpo",
0,	JOP2,		0014,		"jl",
0,	JOP2,		0014,		"jnge",
0,	JOP2,		0015,		"jge",
0,	JOP2,		0015,		"jnl",
0,	JOP2,		0016,		"jle",
0,	JOP2,		0016,		"jng",
0,	JOP2,		0017,		"jg",
0,	JOP2,		0017,		"jnle",
0,	LEAOP,		0142,		"bound",
0,	LEAOP,		0215,		"lea",
0,	LEAOP,		0304,		"les",
0,	LEAOP,		0305,		"lds",
0,	LEAOP2,		0262,		"lss",
0,	LEAOP2,		0264,		"lfs",
0,	LEAOP2,		0265,		"lgs",
0,	LSHFT,		0244,		"shld",
0,	LSHFT,		0254,		"shrd",
0,	MOV,		0,		"movb",
0,	MOV,		1,		"mov",
0,	NOOP_1,		0140,		"pusha",
0,	NOOP_1,		0140,		"pushad",
0,	NOOP_1,		0141,		"popa",
0,	NOOP_1,		0141,		"popad",
0,	NOOP_1,		0156,		"outsb",
0,	NOOP_1,		0157,		"outs",
0,	NOOP_1,		0220,		"nop",
0,	NOOP_1,		0230,		"cbw",
0,	NOOP_1,		0230,		"cwde",	/* same opcode as cbw! */
0,	NOOP_1,		0231,		"cdq",	/* same opcode as cwd! */
0,	NOOP_1,		0231,		"cwd",
0,	NOOP_1,		0233,		"wait",
0,	NOOP_1,		0234,		"pushf",
0,	NOOP_1,		0235,		"popf",
0,	NOOP_1,		0236,		"sahf",
0,	NOOP_1,		0237,		"lahf",
0,	NOOP_1,		0244,		"movsb",
0,	NOOP_1,		0245,		"movs",
0,	NOOP_1,		0246,		"cmpsb",
0,	NOOP_1,		0246,		"insb",
0,	NOOP_1,		0247,		"cmps",
0,	NOOP_1,		0247,		"ins",
0,	NOOP_1,		0252,		"stosb",
0,	NOOP_1,		0253,		"stos",
0,	NOOP_1,		0254,		"lodsb",
0,	NOOP_1,		0255,		"lods",
0,	NOOP_1,		0256,		"scasb",
0,	NOOP_1,		0257,		"scas",
0,	NOOP_1,		0311,		"leave",
0,	NOOP_1,		0316,		"into",
0,	NOOP_1,		0317,		"iret",
0,	NOOP_1,		0317,		"iretd",
0,	NOOP_1,		0327,		"xlat",
0,	NOOP_1,		0364,		"hlt",
0,	NOOP_1,		0365,		"cmc",
0,	NOOP_1,		0370,		"clc",
0,	NOOP_1,		0371,		"stc",
0,	NOOP_1,		0372,		"cli",
0,	NOOP_1,		0373,		"sti",
0,	NOOP_1,		0374,		"cld",
0,	NOOP_1,		0375,		"std",
0,	NOOP_1,		047,		"daa",
0,	NOOP_1,		057,		"das",
0,	NOOP_1,		067,		"aaa",
0,	NOOP_1,		077,		"aas",
0,	NOOP_2,		017+06<<8,	"clts",
0,	NOOP_2,		0324+012<<8,	"aam",
0,	NOOP_2,		0325+012<<8,	"aad",
0,	NOTOP,		020,		"notb",
0,	NOTOP,		021,		"not",
0,	NOTOP,		030,		"negb",
0,	NOTOP,		031,		"neg",
0,	NOTOP,		040,		"mulb",
0,	NOTOP,		041,		"mul",
0,	NOTOP,		060,		"divb",
0,	NOTOP,		061,		"div",
0,	NOTOP,		070,		"idivb",
0,	NOTOP,		071,		"idiv",
0,	PREFIX,		0144,		"fseg",
0,	PREFIX,		0145,		"gseg",
0,	PREFIX,		0146,		"o16",	/* operand size toggle */
0,	PREFIX,		0146,		"o32",	/* operand size toggle */
0,	PREFIX,		0147,		"a16",	/* address size toggle */
0,	PREFIX,		0147,		"a32",	/* address size toggle */
0,	PREFIX,		0360,		"lock",
0,	PREFIX,		0362,		"rep",
0,	PREFIX,		0362,		"repne",
0,	PREFIX,		0362,		"repnz",
0,	PREFIX,		0363,		"repe",
0,	PREFIX,		0363,		"repz",
0,	PREFIX,		046,		"eseg",
0,	PREFIX,		056,		"cseg",
0,	PREFIX,		066,		"sseg",
0,	PREFIX,		076,		"dseg",
0,	PUSHOP,		0,		"push",
0,	PUSHOP,		1,		"pop",
0,	RET,		0303,		"ret",
0,	RET,		0313,		"retf",
0,	ROLOP,		000,		"rolb",
0,	ROLOP,		001,		"rol",
0,	ROLOP,		010,		"rorb",
0,	ROLOP,		011,		"ror",
0,	ROLOP,		020,		"rclb",
0,	ROLOP,		021,		"rcl",
0,	ROLOP,		030,		"rcrb",
0,	ROLOP,		031,		"rcr",
0,	ROLOP,		040,		"salb",
0,	ROLOP,		040,		"shlb",
0,	ROLOP,		041,		"sal",
0,	ROLOP,		041,		"shl",
0,	ROLOP,		050,		"shrb",
0,	ROLOP,		051,		"shr",
0,	ROLOP,		070,		"sarb",
0,	ROLOP,		071,		"sar",
0,	SETCC,		0000,		"seto",
0,	SETCC,		0001,		"setno",
0,	SETCC,		0002,		"setb",
0,	SETCC,		0002,		"setnae",
0,	SETCC,		0003,		"setae",
0,	SETCC,		0003,		"setnb",
0,	SETCC,		0004,		"sete",
0,	SETCC,		0004,		"setz",
0,	SETCC,		0005,		"setne",
0,	SETCC,		0005,		"setnz",
0,	SETCC,		0006,		"setbe",
0,	SETCC,		0006,		"setna",
0,	SETCC,		0007,		"seta",
0,	SETCC,		0007,		"setnbe",
0,	SETCC,		0010,		"sets",
0,	SETCC,		0011,		"setns",
0,	SETCC,		0012,		"setp",
0,	SETCC,		0012,		"setpe",
0,	SETCC,		0013,		"setnp",
0,	SETCC,		0013,		"setpo",
0,	SETCC,		0014,		"setl",
0,	SETCC,		0014,		"setnge",
0,	SETCC,		0015,		"setge",
0,	SETCC,		0015,		"setnl",
0,	SETCC,		0016,		"setle",
0,	SETCC,		0016,		"setng",
0,	SETCC,		0017,		"setg",
0,	SETCC,		0017,		"setnle",
0,	TEST,		0,		"testb",
0,	TEST,		1,		"test",
0,	XCHG,		0,		"xchgb",
0,	XCHG,		1,		"xchg",