aboutsummaryrefslogtreecommitdiff
path: root/opcodes/rce-opc.h
blob: c1a9408483876881c4f00b6dae32e2a2d04f1593 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
typedef enum {
	O0, OT, O1, OC, O2, X1, OI, OB, SI, I7, LS, BR, LI, LR, LJ, OM, OQ, JSR
} rce_opclass;

typedef struct inst
{	char *name;
	unsigned short opclass;
	unsigned short inst;
} rce_opcode_info;

#ifdef DEFINE_TABLE
rce_opcode_info rce_table[]={
{ "bkpt",	O0,	0x0000 },
{ "sync",	O0,	0x0001 },
{ "rte",	O0,	0x0002 },
{ "rfi",	O0,	0x0003 },
{ "stop",	O0,	0x0004 },
{ "wait",	O0,	0x0005 },

{ "trap",	OT,	0x0010 },
{ "mvc",	O1,	0x0020 },
{ "mvcv",	O1,	0x0030 },
{ "jmp",	O1,	0x0040 },
{ "jsr",	JSR,	0x0050 },
/*****
{ "jmpt",	O1,	0x0060 },
{ "jmpf",	O1,	0x0070 },
*****/
{ "tstne",	O1,	0x0080 },
{ "tstgt",	O1,	0x0090 },
{ "tstlt",	O1,	0x00A0 },
{ "tstnbz",	O1,	0x00B0 },
{ "inct",	O1,	0x00C0 },
{ "incf",	O1,	0x00D0 },
{ "dect",	O1,	0x00E0 },
{ "decf",	O1,	0x00F0 },
{ "zextb",	O1,	0x0100 },
{ "sextb",	O1,	0x0110 },
{ "zexth",	O1,	0x0120 },
{ "sexth",	O1,	0x0130 },
{ "xtrb3",	X1,	0x0140 },
{ "xtrb2",	X1,	0x0150 },
{ "xtrb1",	X1,	0x0160 },
{ "xtrb0",	X1,	0x0170 },

{ "decgt",	O1,	0x01C0 },
{ "declt",	O1,	0x01D0 },
{ "brev",	O1,	0x01E0 },
{ "not",	O1,	0x01F0 },
{ "mfcr",	OC,	0x0400 },
{ "mtcr",	OC,	0x0600 },
{ "mov",	O2,	0x0200 },
{ "movnc",	O2,	0x0C00 },
{ "tst",	O2,	0x0B00 },
{ "cmpne",	O2,	0x0800 },
{ "cmplt",	O2,	0x0900 },
{ "cmphs",	O2,	0x0A00 },
{ "bgenr",	O2,	0x0D00 },
{ "movt",	O2,	0x0E00 },
{ "movf",	O2,	0x0F00 },
{ "and",	O2,	0x1000 },
{ "andn",	O2,	0x1100 },
{ "xor",	O2,	0x1200 },
{ "xnor",	O2,	0x1300 },
{ "or",		O2,	0x1400 },
{ "rsub",	O2,	0x1500 },
{ "addu",	O2,	0x1600 },
{ "subu",	O2,	0x1700 },
{ "ixh",	O2,	0x1800 },
{ "ixw",	O2,	0x1900 },
{ "addc",	O2,	0x1A00 },
{ "subc",	O2,	0x1B00 },
{ "lsr",	O2,	0x1C00 },
{ "asr",	O2,	0x1D00 },
{ "lsl",	O2,	0x1E00 },
/*****
{ "rotl",	O2,	0x1F00 },
*****/

{ "movi",	I7,	0x6800 },

{ "andi",	OB,	0x2200 },
{ "movit",	OB,	0x2400 },
{ "movif",	OB,	0x2600 },
{ "btsti",	OB,	0x2800 },
{ "bclri",	OB,	0x2A00 },
{ "bseti",	OB,	0x2C00 },
{ "bmaski",	OB,	0x2E00 },
{ "bgeni",	OB,	0x3000 },
{ "rsubi",	OB,	0x3200 },
{ "addi",	OI,	0x3400 },
{ "subi",	OI,	0x3600 },
{ "lsri",	SI,	0x3800 },
{ "lsrc",	O1,	0x3800 },
{ "asri",	SI,	0x3A00 },
{ "asrc",	O1,	0x3A00 },
{ "lsli",	SI,	0x3C00 },
{ "lslc",	O1,	0x3C00 },
{ "rotli",	SI,	0x3E00 },
{ "xsr",	O1,	0x3E00 },

{ "ldm",	OM,	0x6000 },
{ "stm",	OM,	0x6010 },
{ "ldq",	OQ,	0x6000 },
{ "stq",	OQ,	0x6010 },
{ "mult",	O2,	0x6100 },

/* { "mvir1",	LI,	0x6800 }, */
{ "lrw",	LR,	0x7000 },
{ "jmpi",	LJ,	0x7000 },
{ "jsri",	LJ,	0x7F00 },

{ "ld",		LS,	0x8000 },
{ "st",		LS,	0x9000 },
{ "ld.w",	LS,	0x8000 },
{ "st.w",	LS,	0x9000 },
{ "ld.b",	LS,	0xA000 },
{ "st.b",	LS,	0xB000 },
{ "ld.h",	LS,	0xC000 },
{ "st.h",	LS,	0xD000 },
{ "br",		BR,	0xE000 },
{ "bsr",	BR,	0xE800 },
{ "bt",		BR,	0xF000 },
{ "bf",		BR,	0xF800 },
{ 0,		0,	0 }
};
#endif