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
|
typedef enum {
O0, OT, O1, OC, O2, OI, OB, LS, BR, LI, LR, LJ, OM
} r16_opclass;
typedef struct inst
{ char *name;
unsigned short opclass;
unsigned short inst;
} r16_opcode_info;
#ifdef DEFINE_TABLE
r16_opcode_info r16_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", O1, 0x0050 },
{ "jmpt", O1, 0x0060 },
{ "jmpf", O1, 0x0070 },
{ "tsteq", O1, 0x0080 },
{ "tstgt", O1, 0x0090 },
{ "tstlt", O1, 0x00A0 },
{ "tstbz", 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", O1, 0x0140 },
{ "xtrb2", O1, 0x0150 },
{ "xtrb1", O1, 0x0160 },
{ "xtrb0", O1, 0x0170 },
{ "decgt", O1, 0x01C0 },
{ "declt", O1, 0x01D0 },
{ "brev", O1, 0x01E0 },
{ "not", O1, 0x01F0 },
{ "mfcr", OC, 0x0200 },
{ "mtcr", OC, 0x0300 },
{ "mov", O2, 0x0400 },
{ "movnc", O2, 0x0600 },
{ "tst", O2, 0x0700 },
{ "cmpeq", O2, 0x0800 },
{ "cmpgt", O2, 0x0900 },
{ "cmphi", 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", OB, 0x2000 },
{ "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", OB, 0x3800 },
{ "lsrc", O1, 0x3800 },
{ "asri", OB, 0x3A00 },
{ "asrc", O1, 0x3A00 },
{ "lsli", OB, 0x3C00 },
{ "lslc", O1, 0x3C00 },
{ "rotli", OB, 0x3E00 },
{ "rotlc", O1, 0x3E00 },
{ "ldm", OM, 0x6000 },
{ "stm", OM, 0x6010 },
{ "mult", O2, 0x6100 },
{ "mvir1", LI, 0x6800 },
{ "lrw", LR, 0x7000 },
{ "jmpi", LJ, 0x7300 },
{ "jsri", LJ, 0x7F00 },
{ "ld", LS, 0x8000 },
{ "st", 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
|