2009-01-04 Rodrigo Kumpera <rkumpera@novell.com>
[mono.git] / mono / mini / mini-ops.h
1
2 MINI_OP(OP_LOAD,        "load", NONE, NONE, NONE)
3 MINI_OP(OP_LDADDR,      "ldaddr", IREG, NONE, NONE)
4 MINI_OP(OP_STORE,       "store", NONE, NONE, NONE)
5 MINI_OP(OP_OBJADDR,     "objaddr", NONE, NONE, NONE)
6 MINI_OP(OP_VTADDR,      "vtaddr", NONE, NONE, NONE)
7 MINI_OP(OP_NOP,     "nop", NONE, NONE, NONE)
8 MINI_OP(OP_HARD_NOP,    "hard_nop", NONE, NONE, NONE)
9 MINI_OP(OP_RELAXED_NOP,     "relaxed_nop", NONE, NONE, NONE)
10 MINI_OP(OP_PHI,         "phi", IREG, NONE, NONE)
11 MINI_OP(OP_FPHI,        "fphi", FREG, NONE, NONE)
12 MINI_OP(OP_VPHI,        "vphi", VREG, NONE, NONE)
13 MINI_OP(OP_RENAME,      "rename", NONE, NONE, NONE)
14 MINI_OP(OP_COMPARE,     "compare", NONE, IREG, IREG)
15 MINI_OP(OP_COMPARE_IMM, "compare_imm", NONE, IREG, NONE)
16 MINI_OP(OP_FCOMPARE,    "fcompare", NONE, FREG, FREG)
17 MINI_OP(OP_LCOMPARE,    "lcompare", NONE, LREG, LREG)
18 MINI_OP(OP_ICOMPARE,    "icompare", NONE, IREG, IREG)
19 MINI_OP(OP_ICOMPARE_IMM,        "icompare_imm", NONE, IREG, NONE)
20 MINI_OP(OP_LCOMPARE_IMM,        "lcompare_imm", NONE, LREG, NONE)
21 MINI_OP(OP_LOCAL,       "local", NONE, NONE, NONE)
22 MINI_OP(OP_ARG,         "arg", NONE, NONE, NONE)
23 MINI_OP(OP_ARGLIST,     "oparglist", NONE, IREG, NONE)
24 MINI_OP(OP_OUTARG,      "outarg", NONE, NONE, NONE)
25 MINI_OP(OP_OUTARG_REG,  "outarg_reg", NONE, NONE, NONE)
26 MINI_OP(OP_OUTARG_FREG, "outarg_freg", NONE, NONE, NONE)
27 MINI_OP(OP_OUTARG_FREG_R4,      "outarg_freg_r4", NONE, NONE, NONE)
28 MINI_OP(OP_OUTARG_IMM,  "outarg_imm", NONE, NONE, NONE)
29 MINI_OP(OP_OUTARG_R4,   "outarg_r4", NONE, NONE, NONE)
30 MINI_OP(OP_OUTARG_R8,   "outarg_r8", NONE, NONE, NONE)
31 MINI_OP(OP_OUTARG_VT,   "outarg_vt", NONE, VREG, NONE)
32 MINI_OP(OP_OUTARG_VTRETADDR, "outarg_vtretaddr", IREG, NONE, NONE)
33 MINI_OP(OP_OUTARG_MEMBASE,      "outarg_membase", NONE, NONE, NONE)
34 MINI_OP(OP_INARG_VT,    "inarg_vt", NONE, NONE, NONE)
35 MINI_OP(OP_RETARG,      "retarg", NONE, NONE, NONE)
36 MINI_OP(OP_SETRET,      "setret", NONE, NONE, NONE)
37 MINI_OP(OP_SETFRET,     "setfret", FREG, FREG, NONE)
38 MINI_OP(OP_SETLRET,     "setlret", NONE, IREG, IREG)
39 MINI_OP(OP_LOCALLOC, "localloc", IREG, IREG, NONE)
40 MINI_OP(OP_LOCALLOC_IMM, "localloc_imm", IREG, NONE, NONE)
41 MINI_OP(OP_CHECK_THIS,  "checkthis", NONE, IREG, NONE)
42 MINI_OP(OP_CHECK_THIS_PASSTHROUGH,      "checkthis_passthrough", NONE, NONE, NONE)
43 MINI_OP(OP_VOIDCALL,    "voidcall", NONE, NONE, NONE)
44 MINI_OP(OP_VOIDCALLVIRT,        "voidcallvirt", NONE, NONE, NONE)
45 MINI_OP(OP_VOIDCALL_REG,        "voidcall_reg", NONE, IREG, NONE)
46 MINI_OP(OP_VOIDCALL_MEMBASE,    "voidcall_membase", NONE, IREG, NONE)
47 MINI_OP(OP_FCALL,       "fcall", FREG, NONE, NONE)
48 MINI_OP(OP_FCALLVIRT,   "fcallvirt", FREG, NONE, NONE)
49 MINI_OP(OP_FCALL_REG,   "fcall_reg", FREG, IREG, NONE)
50 MINI_OP(OP_FCALL_MEMBASE,       "fcall_membase", FREG, IREG, NONE)
51 MINI_OP(OP_LCALL,       "lcall", LREG, NONE, NONE)
52 MINI_OP(OP_LCALLVIRT,   "lcallvirt", LREG, NONE, NONE)
53 MINI_OP(OP_LCALL_REG,   "lcall_reg", LREG, IREG, NONE)
54 MINI_OP(OP_LCALL_MEMBASE,       "lcall_membase", LREG, IREG, NONE)
55 MINI_OP(OP_VCALL,       "vcall", VREG, NONE, NONE)
56 MINI_OP(OP_VCALLVIRT,   "vcallvirt", VREG, NONE, NONE)
57 MINI_OP(OP_VCALL_REG,   "vcall_reg", VREG, IREG, NONE)
58 MINI_OP(OP_VCALL_MEMBASE,       "vcall_membase", VREG, IREG, NONE)
59 MINI_OP(OP_VOIDCALL_RGCTX,      "voidcall_rgctx", NONE, NONE, NONE)
60 MINI_OP(OP_LCALL_RGCTX,         "lcall_rgctx", NONE, NONE, NONE)
61 MINI_OP(OP_VCALL_RGCTX,         "vcall_rgctx", NONE, NONE, NONE)
62 MINI_OP(OP_CALL_RGCTX,          "call_rgctx", NONE, NONE, NONE)
63 MINI_OP(OP_FCALL_RGCTX,         "fcall_rgctx", NONE, NONE, NONE)
64 MINI_OP(OP_VOIDCALL_REG_RGCTX,  "voidcall_reg_rgctx", NONE, NONE, NONE)
65 MINI_OP(OP_LCALL_REG_RGCTX,     "lcall_reg_rgctx", NONE, NONE, NONE)
66 MINI_OP(OP_VCALL_REG_RGCTX,     "vcall_reg_rgctx", NONE, NONE, NONE)
67 MINI_OP(OP_CALL_REG_RGCTX,      "call_reg_rgctx", NONE, NONE, NONE)
68 MINI_OP(OP_VOIDCALLVIRT_IMT,    "voidcallvirt_imt", NONE, NONE, NONE)
69 MINI_OP(OP_CALLVIRT_IMT,        "callvirt_imt", NONE, NONE, NONE)
70 MINI_OP(OP_FCALLVIRT_IMT,       "fcallvirt_imt", NONE, NONE, NONE)
71 MINI_OP(OP_LCALLVIRT_IMT,       "lcallvirt_imt", NONE, NONE, NONE)
72 MINI_OP(OP_VCALLVIRT_IMT,       "vcallvirt_imt", NONE, NONE, NONE)
73 MINI_OP(OP_FCALL_REG_RGCTX,     "fcall_reg_rgctx", NONE, NONE, NONE)
74
75 MINI_OP(OP_TRAMPCALL_VTABLE,    "trampcall_vtable", NONE, NONE, NONE)
76
77 /* Represents the decomposed vcall which doesn't return a vtype no more */
78 MINI_OP(OP_VCALL2,      "vcall2", NONE, NONE, NONE)
79 MINI_OP(OP_VCALL2_REG,  "vcall2_reg", NONE, IREG, NONE)
80 MINI_OP(OP_VCALL2_MEMBASE,      "vcall2_membase", NONE, IREG, NONE)
81
82 MINI_OP(OP_CALL,        "call", IREG, NONE, NONE)
83 MINI_OP(OP_CALL_REG,    "call_reg", IREG, IREG, NONE)
84 MINI_OP(OP_CALL_MEMBASE,        "call_membase", IREG, IREG, NONE)
85 MINI_OP(OP_CALLVIRT, "callvirt", IREG, NONE, NONE)
86 MINI_OP(OP_TRAP,        "trap", NONE, NONE, NONE)
87 MINI_OP(OP_ICONST,      "iconst", IREG, NONE, NONE)
88 MINI_OP(OP_I8CONST,     "i8const", LREG, NONE, NONE)
89 MINI_OP(OP_R4CONST,     "r4const", FREG, NONE, NONE)
90 MINI_OP(OP_R8CONST,     "r8const", FREG, NONE, NONE)
91 MINI_OP(OP_REGVAR,      "regvar", NONE, NONE, NONE)
92 MINI_OP(OP_REG,         "reg", NONE, NONE, NONE)
93 MINI_OP(OP_REGOFFSET,   "regoffset", NONE, NONE, NONE)
94 MINI_OP(OP_VTARG_ADDR,  "vtarg_addr", NONE, NONE, NONE)
95 MINI_OP(OP_LABEL,       "label", NONE, NONE, NONE)
96 MINI_OP(OP_SWITCH,  "switch", NONE, IREG, NONE)
97 MINI_OP(OP_CHECK_ARRAY_TYPE,    "check_array_type", NONE, NONE, NONE)
98 MINI_OP(OP_ARRAY_RANK,  "array_rank", NONE, NONE, NONE)
99 MINI_OP(OP_THROW, "throw", NONE, IREG, NONE)
100 MINI_OP(OP_THROW_OR_NULL,       "throw_or_null", NONE, NONE, NONE)
101 MINI_OP(OP_RETHROW,     "rethrow", NONE, IREG, NONE)
102 MINI_OP(OP_REFANYTYPE,  "refanytype", NONE, NONE, NONE)
103
104 /* MONO_IS_STORE_MEMBASE depends on the order here */
105 MINI_OP(OP_STORE_MEMBASE_REG,"store_membase_reg", IREG, IREG, NONE)
106 MINI_OP(OP_STOREI1_MEMBASE_REG, "storei1_membase_reg", IREG, IREG, NONE)
107 MINI_OP(OP_STOREI2_MEMBASE_REG, "storei2_membase_reg", IREG, IREG, NONE)
108 MINI_OP(OP_STOREI4_MEMBASE_REG, "storei4_membase_reg", IREG, IREG, NONE)
109 MINI_OP(OP_STOREI8_MEMBASE_REG, "storei8_membase_reg", IREG, IREG, NONE)
110 MINI_OP(OP_STORER4_MEMBASE_REG, "storer4_membase_reg", IREG, FREG, NONE)
111 MINI_OP(OP_STORER8_MEMBASE_REG, "storer8_membase_reg", IREG, FREG, NONE)
112
113 #ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
114 MINI_OP(OP_STOREX_MEMBASE_REG, "storex_membase_reg", IREG, XREG, NONE)
115 MINI_OP(OP_STOREX_ALIGNED_MEMBASE_REG,     "storex_aligned_membase_reg", IREG, XREG, NONE)
116 MINI_OP(OP_STOREX_NTA_MEMBASE_REG,     "storex_nta_membase_reg", IREG, XREG, NONE)
117 #endif
118
119 MINI_OP(OP_STORE_MEMBASE_IMM,"store_membase_imm", IREG, NONE, NONE)
120 MINI_OP(OP_STOREI1_MEMBASE_IMM, "storei1_membase_imm", IREG, NONE, NONE)
121 MINI_OP(OP_STOREI2_MEMBASE_IMM, "storei2_membase_imm", IREG, NONE, NONE)
122 MINI_OP(OP_STOREI4_MEMBASE_IMM, "storei4_membase_imm", IREG, NONE, NONE)
123 MINI_OP(OP_STOREI8_MEMBASE_IMM, "storei8_membase_imm", IREG, NONE, NONE)
124 MINI_OP(OP_STOREX_MEMBASE,              "storex_membase", IREG, XREG, NONE)
125 MINI_OP(OP_STOREV_MEMBASE,      "storev_membase", IREG, VREG, NONE)
126
127 /* MONO_IS_LOAD_MEMBASE depends on the order here */
128 MINI_OP(OP_LOAD_MEMBASE,        "load_membase", IREG, IREG, NONE)
129 MINI_OP(OP_LOADI1_MEMBASE,"loadi1_membase", IREG, IREG, NONE)
130 MINI_OP(OP_LOADU1_MEMBASE,"loadu1_membase", IREG, IREG, NONE)
131 MINI_OP(OP_LOADI2_MEMBASE,"loadi2_membase", IREG, IREG, NONE)
132 MINI_OP(OP_LOADU2_MEMBASE,"loadu2_membase", IREG, IREG, NONE)
133 MINI_OP(OP_LOADI4_MEMBASE,"loadi4_membase", IREG, IREG, NONE)
134 MINI_OP(OP_LOADU4_MEMBASE,"loadu4_membase", IREG, IREG, NONE)
135 MINI_OP(OP_LOADI8_MEMBASE,"loadi8_membase", IREG, IREG, NONE)
136 MINI_OP(OP_LOADR4_MEMBASE,"loadr4_membase", FREG, IREG, NONE)
137 MINI_OP(OP_LOADR8_MEMBASE,"loadr8_membase", FREG, IREG, NONE)
138
139 MINI_OP(OP_LOADX_MEMBASE,                       "loadx_membase", XREG, IREG, NONE)
140
141 #ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
142 MINI_OP(OP_LOADX_ALIGNED_MEMBASE,  "loadx_aligned_membase", XREG, IREG, NONE)
143 #endif
144
145 MINI_OP(OP_LOADV_MEMBASE,   "loadv_membase", VREG, IREG, NONE)
146
147 /* indexed loads: dreg = load at (sreg1 + sreg2)*/
148 MINI_OP(OP_LOAD_MEMINDEX,  "load_memindex", NONE, NONE, NONE)
149 MINI_OP(OP_LOADI1_MEMINDEX,"loadi1_memindex", NONE, NONE, NONE)
150 MINI_OP(OP_LOADU1_MEMINDEX,"loadu1_memindex", NONE, NONE, NONE)
151 MINI_OP(OP_LOADI2_MEMINDEX,"loadi2_memindex", NONE, NONE, NONE)
152 MINI_OP(OP_LOADU2_MEMINDEX,"loadu2_memindex", NONE, NONE, NONE)
153 MINI_OP(OP_LOADI4_MEMINDEX,"loadi4_memindex", NONE, NONE, NONE)
154 MINI_OP(OP_LOADU4_MEMINDEX,"loadu4_memindex", NONE, NONE, NONE)
155 MINI_OP(OP_LOADI8_MEMINDEX,"loadi8_memindex", NONE, NONE, NONE)
156 MINI_OP(OP_LOADR4_MEMINDEX,"loadr4_memindex", NONE, NONE, NONE)
157 MINI_OP(OP_LOADR8_MEMINDEX,"loadr8_memindex", NONE, NONE, NONE)
158 /* indexed stores: store sreg1 at (destbasereg + sreg2) */
159 /* MONO_IS_STORE_MEMINDEX depends on the order here */
160 MINI_OP(OP_STORE_MEMINDEX,"store_memindex", NONE, NONE, NONE)
161 MINI_OP(OP_STOREI1_MEMINDEX,"storei1_memindex", NONE, NONE, NONE)
162 MINI_OP(OP_STOREI2_MEMINDEX,"storei2_memindex", NONE, NONE, NONE)
163 MINI_OP(OP_STOREI4_MEMINDEX,"storei4_memindex", NONE, NONE, NONE)
164 MINI_OP(OP_STOREI8_MEMINDEX,"storei8_memindex", NONE, NONE, NONE)
165 MINI_OP(OP_STORER4_MEMINDEX,"storer4_memindex", NONE, NONE, NONE)
166 MINI_OP(OP_STORER8_MEMINDEX,"storer8_memindex", NONE, NONE, NONE)
167
168 MINI_OP(OP_LOADR8_SPILL_MEMBASE,"loadr8_spill_membase", NONE, NONE, NONE)
169 MINI_OP(OP_LOAD_MEM,"load_mem", IREG, NONE, NONE)
170 MINI_OP(OP_LOADU1_MEM,"loadu1_mem", IREG, NONE, NONE)
171 MINI_OP(OP_LOADU2_MEM,"loadu2_mem", IREG, NONE, NONE)
172 MINI_OP(OP_LOADI4_MEM,"loadi4_mem", IREG, NONE, NONE)
173 MINI_OP(OP_LOADU4_MEM,"loadu4_mem", IREG, NONE, NONE)
174 MINI_OP(OP_LOADI8_MEM,"loadi8_mem", IREG, NONE, NONE)
175 MINI_OP(OP_STORE_MEM_IMM, "store_mem_imm", NONE, NONE, NONE)
176
177 MINI_OP(OP_MOVE,        "move", IREG, IREG, NONE)
178 MINI_OP(OP_LMOVE,       "lmove", IREG, IREG, NONE)
179 MINI_OP(OP_FMOVE,       "fmove", FREG, FREG, NONE)
180 MINI_OP(OP_VMOVE,   "vmove", VREG, VREG, NONE)
181
182 MINI_OP(OP_VZERO,   "vzero", VREG, NONE, NONE)
183
184 MINI_OP(OP_ADD_IMM,    "add_imm", IREG, IREG, NONE)
185 MINI_OP(OP_SUB_IMM,    "sub_imm", IREG, IREG, NONE)
186 MINI_OP(OP_MUL_IMM,    "mul_imm", IREG, IREG, NONE)
187 MINI_OP(OP_DIV_IMM,    "div_imm", IREG, IREG, NONE)
188 MINI_OP(OP_DIV_UN_IMM, "div_un_imm", IREG, IREG, NONE)
189 MINI_OP(OP_REM_IMM,    "rem_imm", IREG, IREG, NONE)
190 MINI_OP(OP_REM_UN_IMM, "rem_un_imm", IREG, IREG, NONE)
191 MINI_OP(OP_AND_IMM,    "and_imm", IREG, IREG, NONE)
192 MINI_OP(OP_OR_IMM,     "or_imm", IREG, IREG, NONE)
193 MINI_OP(OP_XOR_IMM,    "xor_imm", IREG, IREG, NONE)
194 MINI_OP(OP_SHL_IMM,    "shl_imm", IREG, IREG, NONE)
195 MINI_OP(OP_SHR_IMM,    "shr_imm", IREG, IREG, NONE)
196 MINI_OP(OP_SHR_UN_IMM, "shr_un_imm", IREG, IREG, NONE)
197
198 MINI_OP(OP_BR,         "br", NONE, NONE, NONE)
199 MINI_OP(OP_JMP,        "jmp", NONE, NONE, NONE)
200 /* Same as OP_JMP, but the passing of arguments is done similarly to calls */
201 MINI_OP(OP_TAILCALL,   "tailcall", NONE, NONE, NONE)
202 MINI_OP(OP_BREAK,      "break", NONE, NONE, NONE)
203
204 MINI_OP(OP_CEQ,   "ceq", IREG, NONE, NONE)
205 MINI_OP(OP_CGT,   "cgt", IREG, NONE, NONE)
206 MINI_OP(OP_CGT_UN,"cgt.un", IREG, NONE, NONE)
207 MINI_OP(OP_CLT,   "clt", IREG, NONE, NONE)
208 MINI_OP(OP_CLT_UN,"clt.un", IREG, NONE, NONE)
209
210 /* exceptions: must be in the same order as the matching CEE_ branch opcodes */
211 MINI_OP(OP_COND_EXC_EQ, "cond_exc_eq", NONE, NONE, NONE)
212 MINI_OP(OP_COND_EXC_GE, "cond_exc_ge", NONE, NONE, NONE)
213 MINI_OP(OP_COND_EXC_GT, "cond_exc_gt", NONE, NONE, NONE)
214 MINI_OP(OP_COND_EXC_LE, "cond_exc_le", NONE, NONE, NONE)
215 MINI_OP(OP_COND_EXC_LT, "cond_exc_lt", NONE, NONE, NONE)
216 MINI_OP(OP_COND_EXC_NE_UN, "cond_exc_ne_un", NONE, NONE, NONE)
217 MINI_OP(OP_COND_EXC_GE_UN, "cond_exc_ge_un", NONE, NONE, NONE)
218 MINI_OP(OP_COND_EXC_GT_UN, "cond_exc_gt_un", NONE, NONE, NONE)
219 MINI_OP(OP_COND_EXC_LE_UN, "cond_exc_le_un", NONE, NONE, NONE)
220 MINI_OP(OP_COND_EXC_LT_UN, "cond_exc_lt_un", NONE, NONE, NONE)
221
222 MINI_OP(OP_COND_EXC_OV, "cond_exc_ov", NONE, NONE, NONE)
223 MINI_OP(OP_COND_EXC_NO, "cond_exc_no", NONE, NONE, NONE)
224 MINI_OP(OP_COND_EXC_C, "cond_exc_c", NONE, NONE, NONE)
225 MINI_OP(OP_COND_EXC_NC, "cond_exc_nc", NONE, NONE, NONE)
226
227 MINI_OP(OP_COND_EXC_IEQ, "cond_exc_ieq", NONE, NONE, NONE)
228 MINI_OP(OP_COND_EXC_IGE, "cond_exc_ige", NONE, NONE, NONE)
229 MINI_OP(OP_COND_EXC_IGT, "cond_exc_igt", NONE, NONE, NONE)
230 MINI_OP(OP_COND_EXC_ILE, "cond_exc_ile", NONE, NONE, NONE)
231 MINI_OP(OP_COND_EXC_ILT, "cond_exc_ilt", NONE, NONE, NONE)
232 MINI_OP(OP_COND_EXC_INE_UN, "cond_exc_ine_un", NONE, NONE, NONE)
233 MINI_OP(OP_COND_EXC_IGE_UN, "cond_exc_ige_un", NONE, NONE, NONE)
234 MINI_OP(OP_COND_EXC_IGT_UN, "cond_exc_igt_un", NONE, NONE, NONE)
235 MINI_OP(OP_COND_EXC_ILE_UN, "cond_exc_ile_un", NONE, NONE, NONE)
236 MINI_OP(OP_COND_EXC_ILT_UN, "cond_exc_ilt_un", NONE, NONE, NONE)
237
238 MINI_OP(OP_COND_EXC_IOV, "cond_exc_iov", NONE, NONE, NONE)
239 MINI_OP(OP_COND_EXC_INO, "cond_exc_ino", NONE, NONE, NONE)
240 MINI_OP(OP_COND_EXC_IC, "cond_exc_ic", NONE, NONE, NONE)
241 MINI_OP(OP_COND_EXC_INC, "cond_exc_inc", NONE, NONE, NONE)
242
243 /* 64 bit opcodes: must be in the same order as the matching CEE_ opcodes: binops_op_map */
244 MINI_OP(OP_LADD,    "long_add", LREG, LREG, LREG)
245 MINI_OP(OP_LSUB,    "long_sub", LREG, LREG, LREG)
246 MINI_OP(OP_LMUL,    "long_mul", LREG, LREG, LREG)
247 MINI_OP(OP_LDIV,    "long_div", LREG, LREG, LREG)
248 MINI_OP(OP_LDIV_UN, "long_div_un", LREG, LREG, LREG)
249 MINI_OP(OP_LREM,    "long_rem", LREG, LREG, LREG)
250 MINI_OP(OP_LREM_UN, "long_rem_un", LREG, LREG, LREG)
251 MINI_OP(OP_LAND,    "long_and", LREG, LREG, LREG)
252 MINI_OP(OP_LOR,     "long_or", LREG, LREG, LREG)
253 MINI_OP(OP_LXOR,    "long_xor", LREG, LREG, LREG)
254 MINI_OP(OP_LSHL,    "long_shl", LREG, LREG, IREG)
255 MINI_OP(OP_LSHR,    "long_shr", LREG, LREG, IREG)
256 MINI_OP(OP_LSHR_UN, "long_shr_un", LREG, LREG, IREG)
257
258 /* 64 bit opcodes: must be in the same order as the matching CEE_ opcodes: unops_op_map */
259 MINI_OP(OP_LNEG,       "long_neg", LREG, LREG, NONE)
260 MINI_OP(OP_LNOT,       "long_not", LREG, LREG, NONE)
261 MINI_OP(OP_LCONV_TO_I1,"long_conv_to_i1", LREG, LREG, NONE)
262 MINI_OP(OP_LCONV_TO_I2,"long_conv_to_i2", LREG, LREG, NONE)
263 MINI_OP(OP_LCONV_TO_I4,"long_conv_to_i4", LREG, LREG, NONE)
264 MINI_OP(OP_LCONV_TO_I8,"long_conv_to_i8", LREG, LREG, NONE)
265 MINI_OP(OP_LCONV_TO_R4,"long_conv_to_r4", FREG, LREG, NONE)
266 MINI_OP(OP_LCONV_TO_R8,"long_conv_to_r8", FREG, LREG, NONE)
267 MINI_OP(OP_LCONV_TO_U4,"long_conv_to_u4", LREG, LREG, NONE)
268 MINI_OP(OP_LCONV_TO_U8,"long_conv_to_u8", LREG, LREG, NONE)
269
270 MINI_OP(OP_LCONV_TO_U2,   "long_conv_to_u2", LREG, LREG, NONE)
271 MINI_OP(OP_LCONV_TO_U1,   "long_conv_to_u1", LREG, LREG, NONE)
272 MINI_OP(OP_LCONV_TO_I,    "long_conv_to_i", LREG, LREG, NONE)
273 MINI_OP(OP_LCONV_TO_OVF_I,"long_conv_to_ovf_i", LREG, LREG, NONE)
274 MINI_OP(OP_LCONV_TO_OVF_U,"long_conv_to_ovf_u", LREG, LREG, NONE)
275
276 MINI_OP(OP_LADD_OVF,      "long_add_ovf", LREG, LREG, LREG)
277 MINI_OP(OP_LADD_OVF_UN,   "long_add_ovf_un", LREG, LREG, LREG)
278 MINI_OP(OP_LMUL_OVF,      "long_mul_ovf", LREG, LREG, LREG)
279 MINI_OP(OP_LMUL_OVF_UN,   "long_mul_ovf_un", LREG, LREG, LREG)
280 MINI_OP(OP_LSUB_OVF,      "long_sub_ovf", LREG, LREG, LREG)
281 MINI_OP(OP_LSUB_OVF_UN,   "long_sub_ovf_un", LREG, LREG, LREG)
282
283 MINI_OP(OP_LCONV_TO_OVF_I1_UN,"long_conv_to_ovf_i1_un", LREG, LREG, NONE)
284 MINI_OP(OP_LCONV_TO_OVF_I2_UN,"long_conv_to_ovf_i2_un", LREG, LREG, NONE)
285 MINI_OP(OP_LCONV_TO_OVF_I4_UN,"long_conv_to_ovf_i4_un", LREG, LREG, NONE)
286 MINI_OP(OP_LCONV_TO_OVF_I8_UN,"long_conv_to_ovf_i8_un", LREG, LREG, NONE)
287 MINI_OP(OP_LCONV_TO_OVF_U1_UN,"long_conv_to_ovf_u1_un", LREG, LREG, NONE)
288 MINI_OP(OP_LCONV_TO_OVF_U2_UN,"long_conv_to_ovf_u2_un", LREG, LREG, NONE)
289 MINI_OP(OP_LCONV_TO_OVF_U4_UN,"long_conv_to_ovf_u4_un", LREG, LREG, NONE)
290 MINI_OP(OP_LCONV_TO_OVF_U8_UN,"long_conv_to_ovf_u8_un", LREG, LREG, NONE)
291 MINI_OP(OP_LCONV_TO_OVF_I_UN, "long_conv_to_ovf_i_un", LREG, LREG, NONE)
292 MINI_OP(OP_LCONV_TO_OVF_U_UN, "long_conv_to_ovf_u_un", LREG, LREG, NONE)
293
294 MINI_OP(OP_LCONV_TO_OVF_I1,"long_conv_to_ovf_i1", LREG, LREG, NONE)
295 MINI_OP(OP_LCONV_TO_OVF_U1,"long_conv_to_ovf_u1", LREG, LREG, NONE)
296 MINI_OP(OP_LCONV_TO_OVF_I2,"long_conv_to_ovf_i2", LREG, LREG, NONE)
297 MINI_OP(OP_LCONV_TO_OVF_U2,"long_conv_to_ovf_u2", LREG, LREG, NONE)
298 MINI_OP(OP_LCONV_TO_OVF_I4,"long_conv_to_ovf_i4", LREG, LREG, NONE)
299 MINI_OP(OP_LCONV_TO_OVF_U4,"long_conv_to_ovf_u4", LREG, LREG, NONE)
300 MINI_OP(OP_LCONV_TO_OVF_I8,"long_conv_to_ovf_i8", LREG, LREG, NONE)
301 MINI_OP(OP_LCONV_TO_OVF_U8,"long_conv_to_ovf_u8", LREG, LREG, NONE)
302
303 /* mono_decompose_long_opts () depends on the order here */
304 MINI_OP(OP_LCEQ,   "long_ceq", LREG, NONE, NONE)
305 MINI_OP(OP_LCGT,   "long_cgt", LREG, NONE, NONE)
306 MINI_OP(OP_LCGT_UN,"long_cgt_un", LREG, NONE, NONE)
307 MINI_OP(OP_LCLT,   "long_clt", LREG, NONE, NONE)
308 MINI_OP(OP_LCLT_UN,"long_clt_un", LREG, NONE, NONE)
309
310 MINI_OP(OP_LCONV_TO_R_UN,"long_conv_to_r_un", FREG, LREG, NONE)
311 MINI_OP(OP_LCONV_TO_U,   "long_conv_to_u", IREG, LREG, NONE)
312
313 MINI_OP(OP_LADD_IMM,    "long_add_imm", LREG, LREG, NONE)
314 MINI_OP(OP_LSUB_IMM,    "long_sub_imm", LREG, LREG, NONE)
315 MINI_OP(OP_LMUL_IMM,    "long_mul_imm", LREG, LREG, NONE)
316 MINI_OP(OP_LAND_IMM,    "long_and_imm", LREG, LREG, NONE)
317 MINI_OP(OP_LOR_IMM,     "long_or_imm", LREG, LREG, NONE)
318 MINI_OP(OP_LXOR_IMM,    "long_xor_imm", LREG, LREG, NONE)
319 MINI_OP(OP_LSHL_IMM,    "long_shl_imm", LREG, LREG, NONE)
320 MINI_OP(OP_LSHR_IMM,    "long_shr_imm", LREG, LREG, NONE)
321 MINI_OP(OP_LSHR_UN_IMM, "long_shr_un_imm", LREG, LREG, NONE)
322 MINI_OP(OP_LDIV_IMM,    "long_div_imm", LREG, LREG, NONE)
323 MINI_OP(OP_LDIV_UN_IMM, "long_div_un_imm", LREG, LREG, NONE)
324 MINI_OP(OP_LREM_IMM,    "long_rem_imm", LREG, LREG, NONE)
325 MINI_OP(OP_LREM_UN_IMM, "long_rem_un_imm", LREG, LREG, NONE)
326
327 /* mono_decompose_long_opts () depends on the order here */
328 MINI_OP(OP_LBEQ,    "long_beq", NONE, NONE, NONE)
329 MINI_OP(OP_LBGE,    "long_bge", NONE, NONE, NONE)
330 MINI_OP(OP_LBGT,    "long_bgt", NONE, NONE, NONE)
331 MINI_OP(OP_LBLE,    "long_ble", NONE, NONE, NONE)
332 MINI_OP(OP_LBLT,    "long_blt", NONE, NONE, NONE)
333 MINI_OP(OP_LBNE_UN, "long_bne_un", NONE, NONE, NONE)
334 MINI_OP(OP_LBGE_UN, "long_bge_un", NONE, NONE, NONE)
335 MINI_OP(OP_LBGT_UN, "long_bgt_un", NONE, NONE, NONE)
336 MINI_OP(OP_LBLE_UN, "long_ble_un", NONE, NONE, NONE)
337 MINI_OP(OP_LBLT_UN, "long_blt_un", NONE, NONE, NONE)
338
339 MINI_OP(OP_LSHR_UN_32, "long_shr_un_32", NONE, NONE, NONE)
340
341 /* Variants of the original opcodes which take the two parts of the long as two arguments */
342 MINI_OP(OP_LCONV_TO_R8_2,"long_conv_to_r8_2", FREG, IREG, IREG)
343 MINI_OP(OP_LCONV_TO_R4_2,"long_conv_to_r4_2", FREG, IREG, IREG)
344 MINI_OP(OP_LCONV_TO_R_UN_2,"long_conv_to_r_un_2", FREG, IREG, IREG)
345 MINI_OP(OP_LCONV_TO_OVF_I4_2,"long_conv_to_ovf_i4_2", IREG, IREG, IREG)
346
347 /* 32 bit opcodes: must be in the same order as the matching CEE_ opcodes: binops_op_map */
348 MINI_OP(OP_IADD,    "int_add", IREG, IREG, IREG)
349 MINI_OP(OP_ISUB,    "int_sub", IREG, IREG, IREG)
350 MINI_OP(OP_IMUL,    "int_mul", IREG, IREG, IREG)
351 MINI_OP(OP_IDIV,    "int_div", IREG, IREG, IREG)
352 MINI_OP(OP_IDIV_UN, "int_div_un", IREG, IREG, IREG)
353 MINI_OP(OP_IREM,    "int_rem", IREG, IREG, IREG)
354 MINI_OP(OP_IREM_UN, "int_rem_un", IREG, IREG, IREG)
355 MINI_OP(OP_IAND,    "int_and", IREG, IREG, IREG)
356 MINI_OP(OP_IOR,     "int_or", IREG, IREG, IREG)
357 MINI_OP(OP_IXOR,    "int_xor", IREG, IREG, IREG)
358 MINI_OP(OP_ISHL,    "int_shl", IREG, IREG, IREG)
359 MINI_OP(OP_ISHR,    "int_shr", IREG, IREG, IREG)
360 MINI_OP(OP_ISHR_UN, "int_shr_un", IREG, IREG, IREG)
361
362 /* 32 bit opcodes: must be in the same order as the matching CEE_ opcodes: unops_op_map */
363 MINI_OP(OP_INEG,       "int_neg", IREG, IREG, NONE)
364 MINI_OP(OP_INOT,       "int_not", IREG, IREG, NONE)
365 MINI_OP(OP_ICONV_TO_I1,"int_conv_to_i1", IREG, IREG, NONE)
366 MINI_OP(OP_ICONV_TO_I2,"int_conv_to_i2", IREG, IREG, NONE)
367 MINI_OP(OP_ICONV_TO_I4,"int_conv_to_i4", IREG, IREG, NONE)
368 MINI_OP(OP_ICONV_TO_I8,"int_conv_to_i8", IREG, IREG, NONE)
369 MINI_OP(OP_ICONV_TO_R4,"int_conv_to_r4", FREG, IREG, NONE)
370 MINI_OP(OP_ICONV_TO_R8,"int_conv_to_r8", FREG, IREG, NONE)
371 MINI_OP(OP_ICONV_TO_U4,"int_conv_to_u4", IREG, IREG, NONE)
372 MINI_OP(OP_ICONV_TO_U8,"int_conv_to_u8", LREG, IREG, NONE)
373
374 MINI_OP(OP_ICONV_TO_R_UN, "int_conv_to_r_un", FREG, IREG, NONE)
375 MINI_OP(OP_ICONV_TO_U,   "int_conv_to_u", IREG, IREG, NONE)
376
377 /* 32 bit opcodes: must be in the same order as the matching CEE_ opcodes: ovfops_op_map */
378 MINI_OP(OP_ICONV_TO_U2,   "int_conv_to_u2", IREG, IREG, NONE)
379 MINI_OP(OP_ICONV_TO_U1,   "int_conv_to_u1", IREG, IREG, NONE)
380 MINI_OP(OP_ICONV_TO_I,    "int_conv_to_i", IREG, IREG, NONE)
381 MINI_OP(OP_ICONV_TO_OVF_I,"int_conv_to_ovf_i", IREG, IREG, NONE)
382 MINI_OP(OP_ICONV_TO_OVF_U,"int_conv_to_ovf_u", IREG, IREG, NONE)
383 MINI_OP(OP_IADD_OVF,      "int_add_ovf", IREG, IREG, IREG)
384 MINI_OP(OP_IADD_OVF_UN,   "int_add_ovf_un", IREG, IREG, IREG)
385 MINI_OP(OP_IMUL_OVF,      "int_mul_ovf", IREG, IREG, IREG)
386 MINI_OP(OP_IMUL_OVF_UN,   "int_mul_ovf_un", IREG, IREG, IREG)
387 MINI_OP(OP_ISUB_OVF,      "int_sub_ovf", IREG, IREG, IREG)
388 MINI_OP(OP_ISUB_OVF_UN,   "int_sub_ovf_un", IREG, IREG, IREG)
389
390 /* 32 bit opcodes: must be in the same order as the matching CEE_ opcodes: ovf2ops_op_map */
391 MINI_OP(OP_ICONV_TO_OVF_I1_UN,"int_conv_to_ovf_i1_un", IREG, IREG, NONE)
392 MINI_OP(OP_ICONV_TO_OVF_I2_UN,"int_conv_to_ovf_i2_un", IREG, IREG, NONE)
393 MINI_OP(OP_ICONV_TO_OVF_I4_UN,"int_conv_to_ovf_i4_un", IREG, IREG, NONE)
394 MINI_OP(OP_ICONV_TO_OVF_I8_UN,"int_conv_to_ovf_i8_un", IREG, IREG, NONE)
395 MINI_OP(OP_ICONV_TO_OVF_U1_UN,"int_conv_to_ovf_u1_un", IREG, IREG, NONE)
396 MINI_OP(OP_ICONV_TO_OVF_U2_UN,"int_conv_to_ovf_u2_un", IREG, IREG, NONE)
397 MINI_OP(OP_ICONV_TO_OVF_U4_UN,"int_conv_to_ovf_u4_un", IREG, IREG, NONE)
398 MINI_OP(OP_ICONV_TO_OVF_U8_UN,"int_conv_to_ovf_u8_un", IREG, IREG, NONE)
399 MINI_OP(OP_ICONV_TO_OVF_I_UN, "int_conv_to_ovf_i_un", IREG, IREG, NONE)
400 MINI_OP(OP_ICONV_TO_OVF_U_UN, "int_conv_to_ovf_u_un", IREG, IREG, NONE)
401
402 /* 32 bit opcodes: must be in the same order as the matching CEE_ opcodes: ovf3ops_op_map */
403 MINI_OP(OP_ICONV_TO_OVF_I1,"int_conv_to_ovf_i1", IREG, IREG, NONE)
404 MINI_OP(OP_ICONV_TO_OVF_U1,"int_conv_to_ovf_u1", IREG, IREG, NONE)
405 MINI_OP(OP_ICONV_TO_OVF_I2,"int_conv_to_ovf_i2", IREG, IREG, NONE)
406 MINI_OP(OP_ICONV_TO_OVF_U2,"int_conv_to_ovf_u2", IREG, IREG, NONE)
407 MINI_OP(OP_ICONV_TO_OVF_I4,"int_conv_to_ovf_i4", IREG, IREG, NONE)
408 MINI_OP(OP_ICONV_TO_OVF_U4,"int_conv_to_ovf_u4", IREG, IREG, NONE)
409 MINI_OP(OP_ICONV_TO_OVF_I8,"int_conv_to_ovf_i8", IREG, IREG, NONE)
410 MINI_OP(OP_ICONV_TO_OVF_U8,"int_conv_to_ovf_u8", IREG, IREG, NONE)
411
412 MINI_OP(OP_IADC,     "int_adc", IREG, IREG, IREG)
413 MINI_OP(OP_IADC_IMM, "int_adc_imm", IREG, IREG, NONE)
414 MINI_OP(OP_ISBB,     "int_sbb", IREG, IREG, IREG)
415 MINI_OP(OP_ISBB_IMM, "int_sbb_imm", IREG, IREG, NONE)
416 MINI_OP(OP_IADDCC,   "int_addcc", IREG, IREG, IREG)
417 MINI_OP(OP_ISUBCC,   "int_subcc", IREG, IREG, IREG)
418
419 MINI_OP(OP_IADD_IMM,    "int_add_imm", IREG, IREG, NONE)
420 MINI_OP(OP_ISUB_IMM,    "int_sub_imm", IREG, IREG, NONE)
421 MINI_OP(OP_IMUL_IMM,    "int_mul_imm", IREG, IREG, NONE)
422 MINI_OP(OP_IDIV_IMM,    "int_div_imm", IREG, IREG, NONE)
423 MINI_OP(OP_IDIV_UN_IMM, "int_div_un_imm", IREG, IREG, NONE)
424 MINI_OP(OP_IREM_IMM,    "int_rem_imm", IREG, IREG, NONE)
425 MINI_OP(OP_IREM_UN_IMM, "int_rem_un_imm", IREG, IREG, NONE)
426 MINI_OP(OP_IAND_IMM,    "int_and_imm", IREG, IREG, NONE)
427 MINI_OP(OP_IOR_IMM,     "int_or_imm", IREG, IREG, NONE)
428 MINI_OP(OP_IXOR_IMM,    "int_xor_imm", IREG, IREG, NONE)
429 MINI_OP(OP_ISHL_IMM,    "int_shl_imm", IREG, IREG, NONE)
430 MINI_OP(OP_ISHR_IMM,    "int_shr_imm", IREG, IREG, NONE)
431 MINI_OP(OP_ISHR_UN_IMM, "int_shr_un_imm", IREG, IREG, NONE)
432
433 MINI_OP(OP_ICEQ,   "int_ceq", IREG, NONE, NONE)
434 MINI_OP(OP_ICGT,   "int_cgt", IREG, NONE, NONE)
435 MINI_OP(OP_ICGT_UN,"int_cgt_un", IREG, NONE, NONE)
436 MINI_OP(OP_ICLT,   "int_clt", IREG, NONE, NONE)
437 MINI_OP(OP_ICLT_UN,"int_clt_un", IREG, NONE, NONE)
438
439 MINI_OP(OP_IBEQ,    "int_beq", NONE, NONE, NONE)
440 MINI_OP(OP_IBGE,    "int_bge", NONE, NONE, NONE)
441 MINI_OP(OP_IBGT,    "int_bgt", NONE, NONE, NONE)
442 MINI_OP(OP_IBLE,    "int_ble", NONE, NONE, NONE)
443 MINI_OP(OP_IBLT,    "int_blt", NONE, NONE, NONE)
444 MINI_OP(OP_IBNE_UN, "int_bne_un", NONE, NONE, NONE)
445 MINI_OP(OP_IBGE_UN, "int_bge_un", NONE, NONE, NONE)
446 MINI_OP(OP_IBGT_UN, "int_bgt_un", NONE, NONE, NONE)
447 MINI_OP(OP_IBLE_UN, "int_ble_un", NONE, NONE, NONE)
448 MINI_OP(OP_IBLT_UN, "int_blt_un", NONE, NONE, NONE)
449
450 MINI_OP(OP_FBEQ,    "float_beq", NONE, NONE, NONE)
451 MINI_OP(OP_FBGE,    "float_bge", NONE, NONE, NONE)
452 MINI_OP(OP_FBGT,    "float_bgt", NONE, NONE, NONE)
453 MINI_OP(OP_FBLE,    "float_ble", NONE, NONE, NONE)
454 MINI_OP(OP_FBLT,    "float_blt", NONE, NONE, NONE)
455 MINI_OP(OP_FBNE_UN, "float_bne_un", NONE, NONE, NONE)
456 MINI_OP(OP_FBGE_UN, "float_bge_un", NONE, NONE, NONE)
457 MINI_OP(OP_FBGT_UN, "float_bgt_un", NONE, NONE, NONE)
458 MINI_OP(OP_FBLE_UN, "float_ble_un", NONE, NONE, NONE)
459 MINI_OP(OP_FBLT_UN, "float_blt_un", NONE, NONE, NONE)
460
461 /* float opcodes: must be in the same order as the matching CEE_ opcodes: binops_op_map */
462 MINI_OP(OP_FADD,   "float_add", FREG, FREG, FREG)
463 MINI_OP(OP_FSUB,   "float_sub", FREG, FREG, FREG)
464 MINI_OP(OP_FMUL,   "float_mul", FREG, FREG, FREG)
465 MINI_OP(OP_FDIV,   "float_div", FREG, FREG, FREG)
466 MINI_OP(OP_FDIV_UN,"float_div_un", FREG, FREG, FREG)
467 MINI_OP(OP_FREM,   "float_rem", FREG, FREG, FREG)
468 MINI_OP(OP_FREM_UN,"float_rem_un", FREG, FREG, FREG)
469
470 /* float opcodes: must be in the same order as the matching CEE_ opcodes: unops_op_map */
471 MINI_OP(OP_FNEG,       "float_neg", FREG, FREG, NONE)
472 MINI_OP(OP_FNOT,       "float_not", FREG, FREG, NONE)
473 MINI_OP(OP_FCONV_TO_I1,"float_conv_to_i1", IREG, FREG, NONE)
474 MINI_OP(OP_FCONV_TO_I2,"float_conv_to_i2", IREG, FREG, NONE)
475 MINI_OP(OP_FCONV_TO_I4,"float_conv_to_i4", IREG, FREG, NONE)
476 MINI_OP(OP_FCONV_TO_I8,"float_conv_to_i8", IREG, FREG, NONE)
477 MINI_OP(OP_FCONV_TO_R4,"float_conv_to_r4", FREG, FREG, NONE)
478 MINI_OP(OP_FCONV_TO_R8,"float_conv_to_r8", FREG, FREG, NONE)
479 MINI_OP(OP_FCONV_TO_U4,"float_conv_to_u4", IREG, FREG, NONE)
480 MINI_OP(OP_FCONV_TO_U8,"float_conv_to_u8", IREG, FREG, NONE)
481
482 MINI_OP(OP_FCONV_TO_U2,   "float_conv_to_u2", IREG, FREG, NONE)
483 MINI_OP(OP_FCONV_TO_U1,   "float_conv_to_u1", IREG, FREG, NONE)
484 MINI_OP(OP_FCONV_TO_I,    "float_conv_to_i", IREG, FREG, NONE)
485 MINI_OP(OP_FCONV_TO_OVF_I,"float_conv_to_ovf_i", IREG, FREG, NONE)
486 MINI_OP(OP_FCONV_TO_OVF_U,"float_conv_to_ovd_u", IREG, FREG, NONE)
487
488 MINI_OP(OP_FADD_OVF,      "float_add_ovf", FREG, FREG, FREG)
489 MINI_OP(OP_FADD_OVF_UN,   "float_add_ovf_un", FREG, FREG, FREG)
490 MINI_OP(OP_FMUL_OVF,      "float_mul_ovf", FREG, FREG, FREG)
491 MINI_OP(OP_FMUL_OVF_UN,   "float_mul_ovf_un", FREG, FREG, FREG)
492 MINI_OP(OP_FSUB_OVF,      "float_sub_ovf", FREG, FREG, FREG)
493 MINI_OP(OP_FSUB_OVF_UN,   "float_sub_ovf_un", FREG, FREG, FREG)
494
495 MINI_OP(OP_FCONV_TO_OVF_I1_UN,"float_conv_to_ovf_i1_un", IREG, FREG, NONE)
496 MINI_OP(OP_FCONV_TO_OVF_I2_UN,"float_conv_to_ovf_i2_un", IREG, FREG, NONE)
497 MINI_OP(OP_FCONV_TO_OVF_I4_UN,"float_conv_to_ovf_i4_un", IREG, FREG, NONE)
498 MINI_OP(OP_FCONV_TO_OVF_I8_UN,"float_conv_to_ovf_i8_un", IREG, FREG, NONE)
499 MINI_OP(OP_FCONV_TO_OVF_U1_UN,"float_conv_to_ovf_u1_un", IREG, FREG, NONE)
500 MINI_OP(OP_FCONV_TO_OVF_U2_UN,"float_conv_to_ovf_u2_un", IREG, FREG, NONE)
501 MINI_OP(OP_FCONV_TO_OVF_U4_UN,"float_conv_to_ovf_u4_un", IREG, FREG, NONE)
502 MINI_OP(OP_FCONV_TO_OVF_U8_UN,"float_conv_to_ovf_u8_un", IREG, FREG, NONE)
503 MINI_OP(OP_FCONV_TO_OVF_I_UN, "float_conv_to_ovf_i_un", IREG, FREG, NONE)
504 MINI_OP(OP_FCONV_TO_OVF_U_UN, "float_conv_to_ovf_u_un", IREG, FREG, NONE)
505
506 MINI_OP(OP_FCONV_TO_OVF_I1,"float_conv_to_ovf_i1", IREG, FREG, NONE)
507 MINI_OP(OP_FCONV_TO_OVF_U1,"float_conv_to_ovf_u1", IREG, FREG, NONE)
508 MINI_OP(OP_FCONV_TO_OVF_I2,"float_conv_to_ovf_i2", IREG, FREG, NONE)
509 MINI_OP(OP_FCONV_TO_OVF_U2,"float_conv_to_ovf_u2", IREG, FREG, NONE)
510 MINI_OP(OP_FCONV_TO_OVF_I4,"float_conv_to_ovf_i4", IREG, FREG, NONE)
511 MINI_OP(OP_FCONV_TO_OVF_U4,"float_conv_to_ovf_u4", IREG, FREG, NONE)
512 MINI_OP(OP_FCONV_TO_OVF_I8,"float_conv_to_ovf_i8", IREG, FREG, NONE)
513 MINI_OP(OP_FCONV_TO_OVF_U8,"float_conv_to_ovf_u8", IREG, FREG, NONE)
514
515 /* These do the comparison too */
516 MINI_OP(OP_FCEQ,   "float_ceq", IREG, FREG, FREG)
517 MINI_OP(OP_FCGT,   "float_cgt", IREG, FREG, FREG)
518 MINI_OP(OP_FCGT_UN,"float_cgt_un", IREG, FREG, FREG)
519 MINI_OP(OP_FCLT,   "float_clt", IREG, FREG, FREG)
520 MINI_OP(OP_FCLT_UN,"float_clt_un", IREG, FREG, FREG)
521
522 MINI_OP(OP_FCEQ_MEMBASE,   "float_ceq_membase", NONE, NONE, NONE)
523 MINI_OP(OP_FCGT_MEMBASE,   "float_cgt_membase", NONE, NONE, NONE)
524 MINI_OP(OP_FCGT_UN_MEMBASE,"float_cgt_un_membase", NONE, NONE, NONE)
525 MINI_OP(OP_FCLT_MEMBASE,   "float_clt_membase", NONE, NONE, NONE)
526 MINI_OP(OP_FCLT_UN_MEMBASE,"float_clt_un_membase", NONE, NONE, NONE)
527
528 MINI_OP(OP_FCONV_TO_U,  "float_conv_to_u", NONE, NONE, NONE)
529 MINI_OP(OP_CKFINITE, "ckfinite", FREG, FREG, NONE)
530
531 /* Return the low 32 bits of a double vreg */
532 MINI_OP(OP_FGETLOW32, "float_getlow32", IREG, FREG, NONE)
533 /* Return the high 32 bits of a double vreg */
534 MINI_OP(OP_FGETHIGH32, "float_gethigh32", IREG, FREG, NONE)
535
536 MINI_OP(OP_GROUP, "group", NONE, NONE, NONE)
537 MINI_OP(OP_JUMP_TABLE, "jump_table", IREG, NONE, NONE)
538
539 /* aot compiler */
540 MINI_OP(OP_AOTCONST, "aot_const", IREG, NONE, NONE)
541 MINI_OP(OP_PATCH_INFO, "patch_info", NONE, NONE, NONE)
542 MINI_OP(OP_GOT_ENTRY, "got_entry", IREG, IREG, NONE)
543
544 /* used to impl unbox */
545 MINI_OP(OP_UNBOXCAST  , "unboxcast", NONE, NONE, NONE)
546 MINI_OP(OP_UNBOXCAST_REG  , "unboxcast_reg", NONE, NONE, NONE)
547
548 /* exception related opcodes */
549 MINI_OP(OP_CALL_HANDLER  , "call_handler", NONE, NONE, NONE)
550 MINI_OP(OP_START_HANDLER  , "start_handler", NONE, NONE, NONE)
551 MINI_OP(OP_ENDFILTER,  "endfilter", NONE, IREG, NONE)
552 MINI_OP(OP_ENDFINALLY,  "endfinally", NONE, NONE, NONE)
553
554 /* inline (long)int * (long)int */
555 MINI_OP(OP_BIGMUL, "bigmul", NONE, NONE, NONE)
556 MINI_OP(OP_BIGMUL_UN, "bigmul_un", NONE, NONE, NONE)
557 MINI_OP(OP_IMIN_UN, "int_min_un", IREG, IREG, IREG)
558 MINI_OP(OP_IMAX_UN, "int_max_un", IREG, IREG, IREG)
559 MINI_OP(OP_LMIN_UN, "long_min_un", LREG, LREG, LREG)
560 MINI_OP(OP_LMAX_UN, "long_max_un", LREG, LREG, LREG)
561
562 MINI_OP(OP_MIN, "min", IREG, IREG, IREG)
563 MINI_OP(OP_MAX, "max", IREG, IREG, IREG)
564
565 MINI_OP(OP_IMIN, "int_min", IREG, IREG, IREG)
566 MINI_OP(OP_IMAX, "int_max", IREG, IREG, IREG)
567 MINI_OP(OP_LMIN, "long_min", LREG, LREG, LREG)
568 MINI_OP(OP_LMAX, "long_max", LREG, LREG, LREG)
569
570 /* opcodes most architecture have */
571 MINI_OP(OP_ADC,     "adc", IREG, IREG, IREG)
572 MINI_OP(OP_ADC_IMM, "adc_imm", IREG, IREG, NONE)
573 MINI_OP(OP_SBB,     "sbb", IREG, IREG, IREG)
574 MINI_OP(OP_SBB_IMM, "sbb_imm", IREG, IREG, NONE)
575 MINI_OP(OP_ADDCC,   "addcc", IREG, IREG, IREG)
576 MINI_OP(OP_ADDCC_IMM,   "addcc_imm", IREG, IREG, NONE)
577 MINI_OP(OP_SUBCC,   "subcc", IREG, IREG, IREG)
578 MINI_OP(OP_SUBCC_IMM,   "subcc_imm", IREG, IREG, NONE)
579 MINI_OP(OP_BR_REG,  "br_reg", NONE, IREG, NONE)
580 MINI_OP(OP_SEXT_I1,  "sext_i1", IREG, IREG, NONE)
581 MINI_OP(OP_SEXT_I2,  "sext_i2", IREG, IREG, NONE)
582 MINI_OP(OP_SEXT_I4,  "sext_i4", IREG, IREG, NONE)
583 MINI_OP(OP_ZEXT_I1,  "zext_i1", IREG, IREG, NONE)
584 MINI_OP(OP_ZEXT_I2,  "zext_i2", IREG, IREG, NONE)
585 MINI_OP(OP_ZEXT_I4,  "zext_i4", IREG, IREG, NONE)
586 MINI_OP(OP_CNE,      "cne", NONE, NONE, NONE)
587 /* to implement the upper half of long32 add and sub */
588 MINI_OP(OP_ADD_OVF_CARRY,   "add_ovf_carry", IREG, IREG, IREG)
589 MINI_OP(OP_SUB_OVF_CARRY,   "sub_ovf_carry", IREG, IREG, IREG)
590 MINI_OP(OP_ADD_OVF_UN_CARRY,   "add_ovf_un_carry", IREG, IREG, IREG)
591 MINI_OP(OP_SUB_OVF_UN_CARRY,   "sub_ovf_un_carry", IREG, IREG, IREG)
592
593 /* FP functions usually done by the CPU */
594 MINI_OP(OP_SIN,     "sin", FREG, FREG, NONE)
595 MINI_OP(OP_COS,     "cos", FREG, FREG, NONE)
596 MINI_OP(OP_ABS,     "abs", FREG, FREG, NONE)
597 MINI_OP(OP_TAN,     "tan", FREG, FREG, NONE)
598 MINI_OP(OP_ATAN,    "atan", FREG, FREG, NONE)
599 MINI_OP(OP_SQRT,    "sqrt", FREG, FREG, NONE)
600 /* to optimize strings */
601 MINI_OP(OP_GETCHR, "getchar", NONE, NONE, NONE)
602 MINI_OP(OP_STR_CHAR_ADDR, "str_char_addr", NONE, NONE, NONE)
603 MINI_OP(OP_STRLEN, "strlen", IREG, IREG, NONE)
604 MINI_OP(OP_GETTYPE, "gettype", NONE, NONE, NONE)
605 MINI_OP(OP_GETHASHCODE, "gethashcode", NONE, NONE, NONE)
606 MINI_OP(OP_NEWARR, "newarr", IREG, IREG, NONE)
607 MINI_OP(OP_LDLEN, "ldlen", IREG, IREG, NONE)
608 MINI_OP(OP_BOUNDS_CHECK, "bounds_check", NONE, IREG, IREG)
609 /* get adress of element in a 2D array */
610 MINI_OP(OP_LDELEMA2D, "getldelema2", NONE, NONE, NONE)
611 /* inlined small memcpy with constant length */
612 MINI_OP(OP_MEMCPY, "memcpy", NONE, NONE, NONE)
613 /* inlined small memset with constant length */
614 MINI_OP(OP_MEMSET, "memset", NONE, NONE, NONE)
615 /* type check that support custom remoting types */
616 MINI_OP(OP_CISINST, "cisinst", NONE, NONE, NONE)
617 MINI_OP(OP_CCASTCLASS, "ccastclass", NONE, NONE, NONE)
618 MINI_OP(OP_SAVE_LMF, "save_lmf", NONE, NONE, NONE)
619 MINI_OP(OP_RESTORE_LMF, "restore_lmf", NONE, NONE, NONE)
620 /* mkrefany/refanyval for generic sharing */
621 MINI_OP(OP_MKREFANY_REGS, "mkrefany_regs", NONE, NONE, NONE)
622 MINI_OP(OP_REFANYVAL_REG, "refanyval_reg", NONE, NONE, NONE)
623
624 /* arch-dep tls access */
625 MINI_OP(OP_TLS_GET,            "tls_get", IREG, NONE, NONE)
626
627 MINI_OP(OP_LOAD_GOTADDR, "load_gotaddr", IREG, NONE, NONE)
628 MINI_OP(OP_DUMMY_USE, "dummy_use", NONE, IREG, NONE)
629 MINI_OP(OP_DUMMY_STORE, "dummy_store", NONE, NONE, NONE)
630 MINI_OP(OP_NOT_REACHED, "not_reached", NONE, NONE, NONE)
631 MINI_OP(OP_NOT_NULL, "not_null", NONE, IREG, NONE)
632
633 /* SIMD opcodes. */
634
635 #ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
636
637 MINI_OP(OP_ADDPS, "addps", XREG, XREG, XREG)
638 MINI_OP(OP_DIVPS, "divps", XREG, XREG, XREG)
639 MINI_OP(OP_MULPS, "mulps", XREG, XREG, XREG)
640 MINI_OP(OP_SUBPS, "subps", XREG, XREG, XREG)
641 MINI_OP(OP_MAXPS, "maxps", XREG, XREG, XREG)
642 MINI_OP(OP_MINPS, "minps", XREG, XREG, XREG)
643 MINI_OP(OP_COMPPS, "compps", XREG, XREG, XREG)
644 MINI_OP(OP_ANDPS, "andps", XREG, XREG, XREG)
645 MINI_OP(OP_ANDNPS, "andnps", XREG, XREG, XREG)
646 MINI_OP(OP_ORPS, "orps", XREG, XREG, XREG)
647 MINI_OP(OP_XORPS, "xorps", XREG, XREG, XREG)
648 MINI_OP(OP_HADDPS, "haddps", XREG, XREG, XREG)
649 MINI_OP(OP_HSUBPS, "hsubps", XREG, XREG, XREG)
650 MINI_OP(OP_ADDSUBPS, "addsubps", XREG, XREG, XREG)
651 MINI_OP(OP_DUPPS_LOW, "dupps_low", XREG, XREG, NONE)
652 MINI_OP(OP_DUPPS_HIGH, "dupps_high", XREG, XREG, NONE)
653
654 MINI_OP(OP_RSQRTPS, "rsqrtps", XREG, XREG, NONE)
655 MINI_OP(OP_SQRTPS, "sqrtps", XREG, XREG, NONE)
656 MINI_OP(OP_RCPPS, "rcpps", XREG, XREG, NONE)
657 MINI_OP(OP_SHUFLEPS, "shuffleps", XREG, XREG, NONE)
658
659 MINI_OP(OP_PSHUFLEW_HIGH, "pshufflew_high", XREG, XREG, NONE)
660 MINI_OP(OP_PSHUFLEW_LOW, "pshufflew_low", XREG, XREG, NONE)
661 MINI_OP(OP_PSHUFLED, "pshuffled", XREG, XREG, NONE)
662
663 MINI_OP(OP_ADDPD, "addpd", XREG, XREG, XREG)
664 MINI_OP(OP_DIVPD, "divpd", XREG, XREG, XREG)
665 MINI_OP(OP_MULPD, "mulpd", XREG, XREG, XREG)
666 MINI_OP(OP_SUBPD, "subpd", XREG, XREG, XREG)
667 MINI_OP(OP_MAXPD, "maxpd", XREG, XREG, XREG)
668 MINI_OP(OP_MINPD, "minpd", XREG, XREG, XREG)
669 MINI_OP(OP_COMPPD, "comppd", XREG, XREG, XREG)
670 MINI_OP(OP_ANDPD, "andpd", XREG, XREG, XREG)
671 MINI_OP(OP_ANDNPD, "andnpd", XREG, XREG, XREG)
672 MINI_OP(OP_ORPD, "orpd", XREG, XREG, XREG)
673 MINI_OP(OP_XORPD, "xorpd", XREG, XREG, XREG)
674 MINI_OP(OP_HADDPD, "haddpd", XREG, XREG, XREG)
675 MINI_OP(OP_HSUBPD, "hsubpd", XREG, XREG, XREG)
676 MINI_OP(OP_ADDSUBPD, "addsubpd", XREG, XREG, XREG)
677 MINI_OP(OP_DUPPD, "duppd", XREG, XREG, NONE)
678
679 MINI_OP(OP_EXTRACT_MASK, "extract_mask", IREG, XREG, NONE)
680
681 MINI_OP(OP_PAND, "pand", XREG, XREG, XREG)
682 MINI_OP(OP_POR, "por", XREG, XREG, XREG)
683 MINI_OP(OP_PXOR, "pxor", XREG, XREG, XREG)
684
685 MINI_OP(OP_PADDB, "paddb", XREG, XREG, XREG)
686 MINI_OP(OP_PADDW, "paddw", XREG, XREG, XREG)
687 MINI_OP(OP_PADDD, "paddd", XREG, XREG, XREG)
688 MINI_OP(OP_PADDQ, "paddq", XREG, XREG, XREG)
689
690 MINI_OP(OP_PSUBB, "psubb", XREG, XREG, XREG)
691 MINI_OP(OP_PSUBW, "psubw", XREG, XREG, XREG)
692 MINI_OP(OP_PSUBD, "psubd", XREG, XREG, XREG)
693 MINI_OP(OP_PSUBQ, "psubq", XREG, XREG, XREG)
694
695 MINI_OP(OP_PMAXB_UN, "pmaxb_un", XREG, XREG, XREG)
696 MINI_OP(OP_PMAXW_UN, "pmaxw_un", XREG, XREG, XREG)
697 MINI_OP(OP_PMAXD_UN, "pmaxd_un", XREG, XREG, XREG)
698
699 MINI_OP(OP_PMAXB, "pmaxb", XREG, XREG, XREG)
700 MINI_OP(OP_PMAXW, "pmaxw", XREG, XREG, XREG)
701 MINI_OP(OP_PMAXD, "pmaxd", XREG, XREG, XREG)
702
703 MINI_OP(OP_PAVGB_UN, "pavgb_un", XREG, XREG, XREG)
704 MINI_OP(OP_PAVGW_UN, "pavgw_un", XREG, XREG, XREG)
705
706 MINI_OP(OP_PMINB_UN, "pminb_un", XREG, XREG, XREG)
707 MINI_OP(OP_PMINW_UN, "pminw_un", XREG, XREG, XREG)
708 MINI_OP(OP_PMIND_UN, "pmind_un", XREG, XREG, XREG)
709
710 MINI_OP(OP_PMINB, "pminb", XREG, XREG, XREG)
711 MINI_OP(OP_PMINW, "pminw", XREG, XREG, XREG)
712 MINI_OP(OP_PMIND, "pmind", XREG, XREG, XREG)
713
714 MINI_OP(OP_PCMPEQB, "pcmpeqb", XREG, XREG, XREG)
715 MINI_OP(OP_PCMPEQW, "pcmpeqw", XREG, XREG, XREG)
716 MINI_OP(OP_PCMPEQD, "pcmpeqd", XREG, XREG, XREG)
717 MINI_OP(OP_PCMPEQQ, "pcmpeqq", XREG, XREG, XREG)
718
719 MINI_OP(OP_PCMPGTB, "pcmpgtb", XREG, XREG, XREG)
720 MINI_OP(OP_PCMPGTW, "pcmpgtw", XREG, XREG, XREG)
721 MINI_OP(OP_PCMPGTD, "pcmpgtd", XREG, XREG, XREG)
722 MINI_OP(OP_PCMPGTQ, "pcmpgtq", XREG, XREG, XREG)
723
724 MINI_OP(OP_PSUM_ABS_DIFF, "psumabsdiff", XREG, XREG, XREG)
725
726 MINI_OP(OP_UNPACK_LOWB, "unpack_lowb", XREG, XREG, XREG)
727 MINI_OP(OP_UNPACK_LOWW, "unpack_loww", XREG, XREG, XREG)
728 MINI_OP(OP_UNPACK_LOWD, "unpack_lowd", XREG, XREG, XREG)
729 MINI_OP(OP_UNPACK_LOWQ, "unpack_lowq", XREG, XREG, XREG)
730 MINI_OP(OP_UNPACK_LOWPS, "unpack_lowps", XREG, XREG, XREG)
731 MINI_OP(OP_UNPACK_LOWPD, "unpack_lowpd", XREG, XREG, XREG)
732
733 MINI_OP(OP_UNPACK_HIGHB, "unpack_highb", XREG, XREG, XREG)
734 MINI_OP(OP_UNPACK_HIGHW, "unpack_highw", XREG, XREG, XREG)
735 MINI_OP(OP_UNPACK_HIGHD, "unpack_highd", XREG, XREG, XREG)
736 MINI_OP(OP_UNPACK_HIGHQ, "unpack_highq", XREG, XREG, XREG)
737 MINI_OP(OP_UNPACK_HIGHPS, "unpack_highps", XREG, XREG, XREG)
738 MINI_OP(OP_UNPACK_HIGHPD, "unpack_highpd", XREG, XREG, XREG)
739
740 MINI_OP(OP_PACKW, "packw", XREG, XREG, XREG)
741 MINI_OP(OP_PACKD, "packd", XREG, XREG, XREG)
742
743 MINI_OP(OP_PACKW_UN, "packw_un", XREG, XREG, XREG)
744 MINI_OP(OP_PACKD_UN, "packd_un", XREG, XREG, XREG)
745
746 MINI_OP(OP_PADDB_SAT, "paddb_sat", XREG, XREG, XREG)
747 MINI_OP(OP_PADDB_SAT_UN, "paddb_sat_un", XREG, XREG, XREG)
748
749 MINI_OP(OP_PADDW_SAT, "paddw_sat", XREG, XREG, XREG)
750 MINI_OP(OP_PADDW_SAT_UN, "paddw_sat_un", XREG, XREG, XREG)
751
752 MINI_OP(OP_PSUBB_SAT, "psubb_sat", XREG, XREG, XREG)
753 MINI_OP(OP_PSUBB_SAT_UN, "psubb_sat_un", XREG, XREG, XREG)
754
755 MINI_OP(OP_PSUBW_SAT, "psubw_sat", XREG, XREG, XREG)
756 MINI_OP(OP_PSUBW_SAT_UN, "psubw_sat_un", XREG, XREG, XREG)
757
758 MINI_OP(OP_PMULW, "pmulw", XREG, XREG, XREG)
759 MINI_OP(OP_PMULD, "pmuld", XREG, XREG, XREG)
760 MINI_OP(OP_PMULQ, "pmulq", XREG, XREG, XREG)
761
762 MINI_OP(OP_PMULW_HIGH_UN, "pmul_high_un", XREG, XREG, XREG)
763 MINI_OP(OP_PMULW_HIGH, "pmul_high", XREG, XREG, XREG)
764
765 /*SSE2 Shift ops must have the _reg version right after as code depends on this ordering.*/ 
766 MINI_OP(OP_PSHRW, "pshrw", XREG, XREG, NONE)
767 MINI_OP(OP_PSHRW_REG, "pshrw_reg", XREG, XREG, XREG)
768
769 MINI_OP(OP_PSARW, "psarw", XREG, XREG, NONE)
770 MINI_OP(OP_PSARW_REG, "psarw_reg", XREG, XREG, XREG)
771
772 MINI_OP(OP_PSHLW, "pshlw", XREG, XREG, NONE)
773 MINI_OP(OP_PSHLW_REG, "pshlw_reg", XREG, XREG, XREG)
774
775 MINI_OP(OP_PSHRD, "pshrd", XREG, XREG, NONE)
776 MINI_OP(OP_PSHRD_REG, "pshrd_reg", XREG, XREG, XREG)
777
778 MINI_OP(OP_PSHRQ, "pshrq", XREG, XREG, NONE)
779 MINI_OP(OP_PSHRQ_REG, "pshrq_reg", XREG, XREG, XREG)
780
781 MINI_OP(OP_PSARD, "psard", XREG, XREG, NONE)
782 MINI_OP(OP_PSARD_REG, "psard_reg", XREG, XREG, XREG)
783
784 MINI_OP(OP_PSHLD, "pshld", XREG, XREG, NONE)
785 MINI_OP(OP_PSHLD_REG, "pshld_reg", XREG, XREG, XREG)
786
787 MINI_OP(OP_PSHLQ, "pshlq", XREG, XREG, NONE)
788 MINI_OP(OP_PSHLQ_REG, "pshlq_reg", XREG, XREG, XREG)
789
790 MINI_OP(OP_EXTRACT_I4, "extract_i4", IREG, XREG, NONE)
791 MINI_OP(OP_ICONV_TO_R8_RAW, "iconv_to_r8_raw", FREG, IREG, NONE)
792 MINI_OP(OP_LOADX_R4, "loadx_r4", FREG, IREG, NONE)
793
794 MINI_OP(OP_PUSH_R4, "push_r4", NONE, FREG, NONE)
795 MINI_OP(OP_LOADX_STACK, "loadx_stack", XREG, NONE, NONE)
796
797 MINI_OP(OP_FCONV_TO_R8_X, "fconv_to_r8_x", XREG, FREG, NONE)
798 MINI_OP(OP_XCONV_R8_TO_I4, "xconv_r8_to_i4", IREG, XREG, NONE)
799 MINI_OP(OP_ICONV_TO_X, "iconv_to_x", XREG, IREG, NONE)
800
801
802 MINI_OP(OP_PREFETCH_MEMBASE, "prefetch_membase", NONE, IREG, NONE)
803
804 #endif
805
806 MINI_OP(OP_XMOVE,   "xmove", XREG, XREG, NONE)
807 MINI_OP(OP_XZERO,   "xzero", XREG, NONE, NONE)
808 MINI_OP(OP_XPHI,        "xphi", XREG, NONE, NONE)
809
810 /* Atomic specific
811
812         Note, OP_ATOMIC_ADD_IMM_NEW_I4 and
813         OP_ATOMIC_ADD_NEW_I4 returns the new
814         value compared to OP_ATOMIC_ADD_I4 that
815         returns the old value.
816
817         OP_ATOMIC_ADD_NEW_I4 is used by
818         Interlocked::Increment and Interlocked:Decrement
819         and atomic_add_i4 by Interlocked::Add
820 */
821 MINI_OP(OP_ATOMIC_ADD_I4, "atomic_add_i4", IREG, IREG, IREG)
822 MINI_OP(OP_ATOMIC_ADD_NEW_I4, "atomic_add_new_i4", IREG, IREG, IREG)
823 MINI_OP(OP_ATOMIC_ADD_IMM_I4, "atomic_add_imm_i4", IREG, IREG, NONE)
824 MINI_OP(OP_ATOMIC_ADD_IMM_NEW_I4, "atomic_add_imm_new_i4", IREG, IREG, NONE)
825 MINI_OP(OP_ATOMIC_EXCHANGE_I4, "atomic_exchange_i4", IREG, IREG, IREG)
826
827 MINI_OP(OP_ATOMIC_ADD_I8, "atomic_add_i8", IREG, IREG, IREG)
828 MINI_OP(OP_ATOMIC_ADD_NEW_I8, "atomic_add_new_i8", IREG, IREG, IREG)
829 MINI_OP(OP_ATOMIC_ADD_IMM_I8, "atomic_add_imm_i8", IREG, IREG, NONE)
830 MINI_OP(OP_ATOMIC_ADD_IMM_NEW_I8, "atomic_add_imm_new_i8", IREG, IREG, NONE)
831 MINI_OP(OP_ATOMIC_EXCHANGE_I8, "atomic_exchange_i8", IREG, IREG, IREG)
832 MINI_OP(OP_MEMORY_BARRIER, "memory_barrier", NONE, NONE, NONE)
833
834 /* CompareExchange where the value to store is a constant */
835 /* backend->data holds the constant value */
836 MINI_OP(OP_ATOMIC_CAS_IMM_I4, "atomic_cas_imm_i4", IREG, IREG, IREG)
837 MINI_OP(OP_ATOMIC_CAS_IMM_I8, "atomic_cas_imm_i8", IREG, IREG, IREG)
838
839 /* Conditional move opcodes.
840  * Must be in the same order as the matching CEE_B... opcodes
841  * sreg2 will be assigned to dreg if the condition is true.
842  * sreg1 should be equal to dreg and models the fact the instruction doesn't necessary
843  * modify dreg. The sreg1==dreg condition could be violated by SSA, so the local
844  * register allocator or the code generator should generate a mov dreg, sreg1 before
845  * the cmov in those cases.
846  * These opcodes operate on pointer sized values.
847  */
848 MINI_OP(OP_CMOV_IEQ,    "cmov_ieq", IREG, IREG, IREG)
849 MINI_OP(OP_CMOV_IGE,    "cmov_ige", IREG, IREG, IREG)
850 MINI_OP(OP_CMOV_IGT,    "cmov_igt", IREG, IREG, IREG)
851 MINI_OP(OP_CMOV_ILE,    "cmov_ile", IREG, IREG, IREG)
852 MINI_OP(OP_CMOV_ILT,    "cmov_ilt", IREG, IREG, IREG)
853 MINI_OP(OP_CMOV_INE_UN, "cmov_ine_un", IREG, IREG, IREG)
854 MINI_OP(OP_CMOV_IGE_UN, "cmov_ige_un", IREG, IREG, IREG)
855 MINI_OP(OP_CMOV_IGT_UN, "cmov_igt_un", IREG, IREG, IREG)
856 MINI_OP(OP_CMOV_ILE_UN, "cmov_ile_un", IREG, IREG, IREG)
857 MINI_OP(OP_CMOV_ILT_UN, "cmov_ilt_un", IREG, IREG, IREG)
858
859 MINI_OP(OP_CMOV_LEQ,    "cmov_leq", IREG, IREG, IREG)
860 MINI_OP(OP_CMOV_LGE,    "cmov_lge", IREG, IREG, IREG)
861 MINI_OP(OP_CMOV_LGT,    "cmov_lgt", IREG, IREG, IREG)
862 MINI_OP(OP_CMOV_LLE,    "cmov_lle", IREG, IREG, IREG)
863 MINI_OP(OP_CMOV_LLT,    "cmov_llt", IREG, IREG, IREG)
864 MINI_OP(OP_CMOV_LNE_UN, "cmov_lne_un", IREG, IREG, IREG)
865 MINI_OP(OP_CMOV_LGE_UN, "cmov_lge_un", IREG, IREG, IREG)
866 MINI_OP(OP_CMOV_LGT_UN, "cmov_lgt_un", IREG, IREG, IREG)
867 MINI_OP(OP_CMOV_LLE_UN, "cmov_lle_un", IREG, IREG, IREG)
868 MINI_OP(OP_CMOV_LLT_UN, "cmov_llt_un", IREG, IREG, IREG)
869
870 /* Arch specific opcodes */
871 #if defined(__i386__) || defined(__x86_64__)
872 MINI_OP(OP_X86_TEST_NULL,          "x86_test_null", NONE, NONE, NONE)
873 MINI_OP(OP_X86_COMPARE_MEMBASE_REG,"x86_compare_membase_reg", NONE, IREG, IREG)
874 MINI_OP(OP_X86_COMPARE_MEMBASE_IMM,"x86_compare_membase_imm", NONE, IREG, NONE)
875 MINI_OP(OP_X86_COMPARE_MEM_IMM,    "x86_compare_mem_imm", NONE, NONE, NONE)
876 MINI_OP(OP_X86_COMPARE_MEMBASE8_IMM,"x86_compare_membase8_imm", NONE, IREG, NONE)
877 MINI_OP(OP_X86_COMPARE_REG_MEMBASE,"x86_compare_reg_membase", NONE, IREG, IREG)
878 MINI_OP(OP_X86_INC_REG,            "x86_inc_reg", NONE, NONE, NONE)
879 MINI_OP(OP_X86_INC_MEMBASE,        "x86_inc_membase", NONE, IREG, NONE)
880 MINI_OP(OP_X86_DEC_REG,            "x86_dec_reg", NONE, NONE, NONE)
881 MINI_OP(OP_X86_DEC_MEMBASE,        "x86_dec_membase", NONE, IREG, NONE)
882 MINI_OP(OP_X86_ADD_MEMBASE_IMM,    "x86_add_membase_imm", NONE, IREG, NONE)
883 MINI_OP(OP_X86_SUB_MEMBASE_IMM,    "x86_sub_membase_imm", NONE, IREG, NONE)
884 MINI_OP(OP_X86_AND_MEMBASE_IMM,    "x86_and_membase_imm", NONE, IREG, NONE)
885 MINI_OP(OP_X86_OR_MEMBASE_IMM,     "x86_or_membase_imm", NONE, IREG, NONE)
886 MINI_OP(OP_X86_XOR_MEMBASE_IMM,    "x86_xor_membase_imm", NONE, IREG, NONE)
887 MINI_OP(OP_X86_ADD_MEMBASE_REG,    "x86_add_membase_reg", NONE, IREG, IREG)
888 MINI_OP(OP_X86_SUB_MEMBASE_REG,    "x86_sub_membase_reg", NONE, IREG, IREG)
889 MINI_OP(OP_X86_AND_MEMBASE_REG,    "x86_and_membase_reg", NONE, IREG, IREG)
890 MINI_OP(OP_X86_OR_MEMBASE_REG,     "x86_or_membase_reg", NONE, IREG, IREG)
891 MINI_OP(OP_X86_XOR_MEMBASE_REG,    "x86_xor_membase_reg", NONE, IREG, IREG)
892 MINI_OP(OP_X86_MUL_MEMBASE_REG,    "x86_mul_membase_reg", NONE, IREG, IREG)
893
894 MINI_OP(OP_X86_ADD_REG_MEMBASE,    "x86_add_reg_membase", NONE, IREG, IREG)
895 MINI_OP(OP_X86_SUB_REG_MEMBASE,    "x86_sub_reg_membase", NONE, IREG, IREG)
896 MINI_OP(OP_X86_MUL_REG_MEMBASE,    "x86_mul_reg_membase", NONE, IREG, IREG)
897 MINI_OP(OP_X86_AND_REG_MEMBASE,    "x86_and_reg_membase", IREG, IREG, IREG)
898 MINI_OP(OP_X86_OR_REG_MEMBASE,     "x86_or_reg_membase", IREG, IREG, IREG)
899 MINI_OP(OP_X86_XOR_REG_MEMBASE,    "x86_xor_reg_membase", IREG, IREG, IREG)
900
901 MINI_OP(OP_X86_PUSH_MEMBASE,       "x86_push_membase", NONE, IREG, NONE)
902 MINI_OP(OP_X86_PUSH_IMM,           "x86_push_imm", NONE, NONE, NONE)
903 MINI_OP(OP_X86_PUSH,               "x86_push", NONE, IREG, NONE)
904 MINI_OP(OP_X86_PUSH_FP,            "x86_push_fp", NONE, NONE, NONE)
905 MINI_OP(OP_X86_PUSH_OBJ,           "x86_push_obj", NONE, IREG, NONE)
906 MINI_OP(OP_X86_PUSH_GOT_ENTRY,     "x86_push_got_entry", NONE, IREG, NONE)
907 MINI_OP(OP_X86_LEA,                "x86_lea", IREG, IREG, IREG)
908 MINI_OP(OP_X86_LEA_MEMBASE,        "x86_lea_membase", IREG, IREG, NONE)
909 MINI_OP(OP_X86_XCHG,               "x86_xchg", NONE, NONE, NONE)
910 MINI_OP(OP_X86_FPOP,               "x86_fpop", NONE, FREG, NONE)
911 MINI_OP(OP_X86_FP_LOAD_I8,         "x86_fp_load_i8", NONE, NONE, NONE)
912 MINI_OP(OP_X86_FP_LOAD_I4,         "x86_fp_load_i4", NONE, NONE, NONE)
913 MINI_OP(OP_X86_SETEQ_MEMBASE,      "x86_seteq_membase", NONE, IREG, NONE)
914 MINI_OP(OP_X86_SETNE_MEMBASE,      "x86_setne_membase", NONE, IREG, NONE)
915 MINI_OP(OP_X86_SHRD,               "x86_shrd", IREG, IREG, IREG)
916 MINI_OP(OP_X86_FXCH,               "x86_fxch", NONE, NONE, NONE)
917 MINI_OP(OP_X86_OUTARG_ALIGN_STACK, "x86_outarg_align_stack", NONE, NONE, NONE)
918 #endif
919
920 #if defined(__x86_64__)
921 MINI_OP(OP_AMD64_TEST_NULL,              "amd64_test_null", NONE, NONE, NONE)
922 MINI_OP(OP_AMD64_SET_XMMREG_R4,          "amd64_set_xmmreg_r4", FREG, FREG, NONE)
923 MINI_OP(OP_AMD64_SET_XMMREG_R8,          "amd64_set_xmmreg_r8", FREG, FREG, NONE)
924 MINI_OP(OP_AMD64_OUTARG_XMMREG_R4,       "amd64_outarg_xmmreg_r4", NONE, NONE, NONE)
925 MINI_OP(OP_AMD64_OUTARG_XMMREG_R8,       "amd64_outarg_xmmreg_r8", NONE, NONE, NONE)
926 MINI_OP(OP_AMD64_ICOMPARE_MEMBASE_REG,   "amd64_icompare_membase_reg", NONE, IREG, IREG)
927 MINI_OP(OP_AMD64_ICOMPARE_MEMBASE_IMM,   "amd64_icompare_membase_imm", NONE, IREG, NONE)
928 MINI_OP(OP_AMD64_ICOMPARE_REG_MEMBASE,   "amd64_icompare_reg_membase", NONE, IREG, IREG)
929 MINI_OP(OP_AMD64_COMPARE_MEMBASE_REG,    "amd64_compare_membase_reg", NONE, IREG, IREG)
930 MINI_OP(OP_AMD64_COMPARE_MEMBASE_IMM,    "amd64_compare_membase_imm", NONE, IREG, NONE)
931 MINI_OP(OP_AMD64_COMPARE_REG_MEMBASE,    "amd64_compare_reg_membase", NONE, IREG, IREG)
932
933 MINI_OP(OP_AMD64_ADD_MEMBASE_REG,        "amd64_add_membase_reg", NONE, IREG, IREG)
934 MINI_OP(OP_AMD64_SUB_MEMBASE_REG,        "amd64_sub_membase_reg", NONE, IREG, IREG)
935 MINI_OP(OP_AMD64_AND_MEMBASE_REG,        "amd64_and_membase_reg", NONE, IREG, IREG)
936 MINI_OP(OP_AMD64_OR_MEMBASE_REG,         "amd64_or_membase_reg", NONE, IREG, IREG)
937 MINI_OP(OP_AMD64_XOR_MEMBASE_REG,        "amd64_xor_membase_reg", NONE, IREG, IREG)
938 MINI_OP(OP_AMD64_MUL_MEMBASE_REG,        "amd64_mul_membase_reg", NONE, IREG, IREG)
939
940 MINI_OP(OP_AMD64_ADD_MEMBASE_IMM,        "amd64_add_membase_imm", NONE, IREG, NONE)
941 MINI_OP(OP_AMD64_SUB_MEMBASE_IMM,        "amd64_sub_membase_imm", NONE, IREG, NONE)
942 MINI_OP(OP_AMD64_AND_MEMBASE_IMM,        "amd64_and_membase_imm", NONE, IREG, NONE)
943 MINI_OP(OP_AMD64_OR_MEMBASE_IMM,         "amd64_or_membase_imm", NONE, IREG, NONE)
944 MINI_OP(OP_AMD64_XOR_MEMBASE_IMM,        "amd64_xor_membase_imm", NONE, IREG, NONE)
945 MINI_OP(OP_AMD64_MUL_MEMBASE_IMM,        "amd64_mul_membase_imm", NONE, IREG, NONE)
946
947 MINI_OP(OP_AMD64_ADD_REG_MEMBASE,        "amd64_add_reg_membase", NONE, IREG, IREG)
948 MINI_OP(OP_AMD64_SUB_REG_MEMBASE,        "amd64_sub_reg_membase", NONE, IREG, IREG)
949 MINI_OP(OP_AMD64_AND_REG_MEMBASE,        "amd64_and_reg_membase", IREG, IREG, IREG)
950 MINI_OP(OP_AMD64_OR_REG_MEMBASE,         "amd64_or_reg_membase", IREG, IREG, IREG)
951 MINI_OP(OP_AMD64_XOR_REG_MEMBASE,        "amd64_xor_reg_membase", IREG, IREG, IREG)
952 MINI_OP(OP_AMD64_MUL_REG_MEMBASE,        "amd64_mul_reg_membase", NONE, IREG, IREG)
953
954 MINI_OP(OP_AMD64_OUTARG_ALIGN_STACK,     "amd64_outarg_align_stack", NONE, NONE, NONE)
955 MINI_OP(OP_AMD64_LOADI8_MEMINDEX,        "amd64_loadi8_memindex", NONE, NONE, NONE)
956 MINI_OP(OP_AMD64_SAVE_SP_TO_LMF,         "amd64_save_sp_to_lmf", NONE, NONE, NONE)
957 #endif
958
959 #if  defined(__ppc__) || defined(__powerpc__) || defined(__ppc64__)
960 MINI_OP(OP_PPC_SUBFIC,             "ppc_subfic", IREG, IREG, NONE)
961 MINI_OP(OP_PPC_SUBFZE,             "ppc_subfze", IREG, IREG, NONE)
962 MINI_OP(OP_CHECK_FINITE,           "ppc_check_finite", NONE, IREG, NONE)
963 #endif
964
965 #if defined(__arm__)
966 MINI_OP(OP_ARM_RSBS_IMM,            "arm_rsbs_imm", IREG, IREG, NONE)
967 MINI_OP(OP_ARM_RSC_IMM,             "arm_rsc_imm", IREG, IREG, NONE)
968 #endif
969
970 #if defined(__sparc__) || defined(sparc)
971 MINI_OP(OP_SPARC_OUTARG_REGPAIR,   "sparc_outarg_regpair", NONE, NONE, NONE)
972 MINI_OP(OP_SPARC_OUTARG_MEM,       "sparc_outarg_mem", NONE, NONE, NONE)
973 MINI_OP(OP_SPARC_OUTARG_MEMPAIR,   "sparc_outarg_mempair", NONE, NONE, NONE)
974 MINI_OP(OP_SPARC_OUTARG_SPLIT_REG_STACK, "sparc_outarg_split_reg_stack", NONE, NONE, NONE)
975 MINI_OP(OP_SPARC_OUTARG_FLOAT_REG, "sparc_outarg_float_reg", NONE, NONE, NONE)
976 MINI_OP(OP_SPARC_OUTARG_DOUBLE_REG, "sparc_outarg_double_reg", NONE, NONE, NONE)
977 MINI_OP(OP_SPARC_OUTARG_FLOAT,      "sparc_outarg_float", NONE, NONE, NONE)
978 MINI_OP(OP_SPARC_OUTARG_REGPAIR_FLOAT, "sparc_outarg_float", NONE, NONE, NONE)
979 MINI_OP(OP_SPARC_SETFREG_FLOAT,   "sparc_setfreg_float", NONE, NONE, NONE)
980 MINI_OP(OP_SPARC_BRZ,              "sparc_brz", NONE, NONE, NONE)
981 MINI_OP(OP_SPARC_BRLEZ,            "sparc_brlez", NONE, NONE, NONE)
982 MINI_OP(OP_SPARC_BRLZ,             "sparc_brlz", NONE, NONE, NONE)
983 MINI_OP(OP_SPARC_BRNZ,             "sparc_brnz", NONE, NONE, NONE)
984 MINI_OP(OP_SPARC_BRGZ,             "sparc_brgz", NONE, NONE, NONE)
985 MINI_OP(OP_SPARC_BRGEZ,            "sparc_brgez", NONE, NONE, NONE)
986 MINI_OP(OP_SPARC_COND_EXC_EQZ,     "sparc_cond_exc_eqz", NONE, NONE, NONE)
987 MINI_OP(OP_SPARC_COND_EXC_GEZ,     "sparc_cond_exc_gez", NONE, NONE, NONE)
988 MINI_OP(OP_SPARC_COND_EXC_GTZ,     "sparc_cond_exc_gtz", NONE, NONE, NONE)
989 MINI_OP(OP_SPARC_COND_EXC_LEZ,     "sparc_cond_exc_lez", NONE, NONE, NONE)
990 MINI_OP(OP_SPARC_COND_EXC_LTZ,     "sparc_cond_exc_ltz", NONE, NONE, NONE)
991 MINI_OP(OP_SPARC_COND_EXC_NEZ,     "sparc_cond_exc_nez", NONE, NONE, NONE)
992 #endif
993
994 #if defined(__s390__) || defined(s390)
995 MINI_OP(OP_S390_LOADARG,           "s390_loadarg", NONE, NONE, NONE)
996 MINI_OP(OP_S390_ARGREG,            "s390_argreg", NONE, NONE, NONE)
997 MINI_OP(OP_S390_ARGPTR,            "s390_argptr", NONE, NONE, NONE)
998 MINI_OP(OP_S390_STKARG,            "s390_stkarg", NONE, NONE, NONE)
999 MINI_OP(OP_S390_MOVE,              "s390_move", IREG, IREG, NONE)
1000 MINI_OP(OP_S390_SETF4RET,          "s390_setf4ret", FREG, FREG, NONE)
1001 MINI_OP(OP_S390_BKCHAIN,           "s390_bkchain", NONE, NONE, NONE)
1002 MINI_OP(OP_S390_LADD,          "s390_long_add", LREG, IREG, IREG)
1003 MINI_OP(OP_S390_LADD_OVF,      "s390_long_add_ovf", LREG, IREG, IREG)
1004 MINI_OP(OP_S390_LADD_OVF_UN,   "s390_long_add_ovf_un", LREG, IREG, IREG)
1005 MINI_OP(OP_S390_LSUB,          "s390_long_sub", LREG, IREG, IREG)
1006 MINI_OP(OP_S390_LSUB_OVF,      "s390_long_sub_ovf", LREG, IREG, IREG)
1007 MINI_OP(OP_S390_LSUB_OVF_UN,   "s390_long_sub_ovf_un", LREG, IREG, IREG)
1008 MINI_OP(OP_S390_LNEG,          "s390_long_neg", LREG, IREG, IREG)
1009 MINI_OP(OP_S390_IADD_OVF,       "s390_int_add_ovf", IREG, IREG, IREG)
1010 MINI_OP(OP_S390_IADD_OVF_UN,    "s390_int_add_ovf_un", IREG, IREG, IREG)
1011 MINI_OP(OP_S390_ISUB_OVF,       "s390_int_sub_ovf", IREG, IREG, IREG)
1012 MINI_OP(OP_S390_ISUB_OVF_UN,    "s390_int_sub_ovf_un", IREG, IREG, IREG)
1013 #endif
1014
1015 #if defined(__ia64__)
1016 MINI_OP(OP_IA64_LOAD,          "ia64_load", NONE, NONE, NONE)
1017 MINI_OP(OP_IA64_LOADI1,        "ia64_loadi1", NONE, NONE, NONE)
1018 MINI_OP(OP_IA64_LOADU1,        "ia64_loadu1", NONE, NONE, NONE)
1019 MINI_OP(OP_IA64_LOADI2,        "ia64_loadi2", NONE, NONE, NONE)
1020 MINI_OP(OP_IA64_LOADU2,        "ia64_loadu2", NONE, NONE, NONE)
1021 MINI_OP(OP_IA64_LOADI4,        "ia64_loadi4", NONE, NONE, NONE)
1022 MINI_OP(OP_IA64_LOADU4,        "ia64_loadu4", NONE, NONE, NONE)
1023 MINI_OP(OP_IA64_LOADI8,        "ia64_loadi8", NONE, NONE, NONE)
1024 MINI_OP(OP_IA64_LOADU8,        "ia64_loadu8", NONE, NONE, NONE)
1025 MINI_OP(OP_IA64_LOADR4,        "ia64_loadr4", NONE, NONE, NONE)
1026 MINI_OP(OP_IA64_LOADR8,        "ia64_loadr8", NONE, NONE, NONE)
1027 MINI_OP(OP_IA64_STORE,          "ia64_store", NONE, NONE, NONE)
1028 MINI_OP(OP_IA64_STOREI1,        "ia64_storei1", NONE, NONE, NONE)
1029 MINI_OP(OP_IA64_STOREU1,        "ia64_storeu1", NONE, NONE, NONE)
1030 MINI_OP(OP_IA64_STOREI2,        "ia64_storei2", NONE, NONE, NONE)
1031 MINI_OP(OP_IA64_STOREU2,        "ia64_storeu2", NONE, NONE, NONE)
1032 MINI_OP(OP_IA64_STOREI4,        "ia64_storei4", NONE, NONE, NONE)
1033 MINI_OP(OP_IA64_STOREU4,        "ia64_storeu4", NONE, NONE, NONE)
1034 MINI_OP(OP_IA64_STOREI8,        "ia64_storei8", NONE, NONE, NONE)
1035 MINI_OP(OP_IA64_STOREU8,        "ia64_storeu8", NONE, NONE, NONE)
1036 MINI_OP(OP_IA64_STORER4,        "ia64_storer4", NONE, NONE, NONE)
1037 MINI_OP(OP_IA64_STORER8,        "ia64_storer8", NONE, NONE, NONE)
1038
1039 MINI_OP(OP_IA64_CMP4_EQ,        "ia64_cmp4_eq", NONE, NONE, NONE)
1040 MINI_OP(OP_IA64_CMP4_NE,        "ia64_cmp4_ne", NONE, NONE, NONE)
1041 MINI_OP(OP_IA64_CMP4_LE,        "ia64_cmp4_le", NONE, NONE, NONE)
1042 MINI_OP(OP_IA64_CMP4_LT,        "ia64_cmp4_lt", NONE, NONE, NONE)
1043 MINI_OP(OP_IA64_CMP4_GE,        "ia64_cmp4_ge", NONE, NONE, NONE)
1044 MINI_OP(OP_IA64_CMP4_GT,        "ia64_cmp4_gt", NONE, NONE, NONE)
1045 MINI_OP(OP_IA64_CMP4_LE_UN,     "ia64_cmp4_le_un", NONE, NONE, NONE)
1046 MINI_OP(OP_IA64_CMP4_LT_UN,     "ia64_cmp4_lt_un", NONE, NONE, NONE)
1047 MINI_OP(OP_IA64_CMP4_GE_UN,     "ia64_cmp4_ge_un", NONE, NONE, NONE)
1048 MINI_OP(OP_IA64_CMP4_GT_UN,     "ia64_cmp4_gt_un", NONE, NONE, NONE)
1049 MINI_OP(OP_IA64_CMP_EQ,         "ia64_cmp_eq", NONE, NONE, NONE)
1050 MINI_OP(OP_IA64_CMP_NE,         "ia64_cmp_ne", NONE, NONE, NONE)
1051 MINI_OP(OP_IA64_CMP_LE,         "ia64_cmp_le", NONE, NONE, NONE)
1052 MINI_OP(OP_IA64_CMP_LT,         "ia64_cmp_lt", NONE, NONE, NONE)
1053 MINI_OP(OP_IA64_CMP_GE,         "ia64_cmp_ge", NONE, NONE, NONE)
1054 MINI_OP(OP_IA64_CMP_GT,         "ia64_cmp_gt", NONE, NONE, NONE)
1055 MINI_OP(OP_IA64_CMP_LT_UN,      "ia64_cmp_lt_un", NONE, NONE, NONE)
1056 MINI_OP(OP_IA64_CMP_GT_UN,      "ia64_cmp_gt_un", NONE, NONE, NONE)
1057 MINI_OP(OP_IA64_CMP_GE_UN,      "ia64_cmp_ge_un", NONE, NONE, NONE)
1058 MINI_OP(OP_IA64_CMP_LE_UN,      "ia64_cmp_le_un", NONE, NONE, NONE)
1059
1060 MINI_OP(OP_IA64_CMP4_EQ_IMM,        "ia64_cmp4_eq_imm", NONE, NONE, NONE)
1061 MINI_OP(OP_IA64_CMP4_NE_IMM,        "ia64_cmp4_ne_imm", NONE, NONE, NONE)
1062 MINI_OP(OP_IA64_CMP4_LE_IMM,        "ia64_cmp4_le_imm", NONE, NONE, NONE)
1063 MINI_OP(OP_IA64_CMP4_LT_IMM,        "ia64_cmp4_lt_imm", NONE, NONE, NONE)
1064 MINI_OP(OP_IA64_CMP4_GE_IMM,        "ia64_cmp4_ge_imm", NONE, NONE, NONE)
1065 MINI_OP(OP_IA64_CMP4_GT_IMM,        "ia64_cmp4_gt_imm", NONE, NONE, NONE)
1066 MINI_OP(OP_IA64_CMP4_LE_UN_IMM,     "ia64_cmp4_le_un_imm", NONE, NONE, NONE)
1067 MINI_OP(OP_IA64_CMP4_LT_UN_IMM,     "ia64_cmp4_lt_un_imm", NONE, NONE, NONE)
1068 MINI_OP(OP_IA64_CMP4_GE_UN_IMM,     "ia64_cmp4_ge_un_imm", NONE, NONE, NONE)
1069 MINI_OP(OP_IA64_CMP4_GT_UN_IMM,     "ia64_cmp4_gt_un_imm", NONE, NONE, NONE)
1070 MINI_OP(OP_IA64_CMP_EQ_IMM,         "ia64_cmp_eq_imm", NONE, NONE, NONE)
1071 MINI_OP(OP_IA64_CMP_NE_IMM,         "ia64_cmp_ne_imm", NONE, NONE, NONE)
1072 MINI_OP(OP_IA64_CMP_LE_IMM,         "ia64_cmp_le_imm", NONE, NONE, NONE)
1073 MINI_OP(OP_IA64_CMP_LT_IMM,         "ia64_cmp_lt_imm", NONE, NONE, NONE)
1074 MINI_OP(OP_IA64_CMP_GE_IMM,         "ia64_cmp_ge_imm", NONE, NONE, NONE)
1075 MINI_OP(OP_IA64_CMP_GT_IMM,         "ia64_cmp_gt_imm", NONE, NONE, NONE)
1076 MINI_OP(OP_IA64_CMP_LT_UN_IMM,      "ia64_cmp_lt_un_imm", NONE, NONE, NONE)
1077 MINI_OP(OP_IA64_CMP_GT_UN_IMM,      "ia64_cmp_gt_un_imm", NONE, NONE, NONE)
1078 MINI_OP(OP_IA64_CMP_GE_UN_IMM,      "ia64_cmp_ge_un_imm", NONE, NONE, NONE)
1079 MINI_OP(OP_IA64_CMP_LE_UN_IMM,      "ia64_cmp_le_un_imm", NONE, NONE, NONE)
1080
1081 MINI_OP(OP_IA64_FCMP_EQ,         "ia64_fcmp_eq", NONE, NONE, NONE)
1082 MINI_OP(OP_IA64_FCMP_NE,         "ia64_fcmp_ne", NONE, NONE, NONE)
1083 MINI_OP(OP_IA64_FCMP_LE,         "ia64_fcmp_le", NONE, NONE, NONE)
1084 MINI_OP(OP_IA64_FCMP_LT,         "ia64_fcmp_lt", NONE, NONE, NONE)
1085 MINI_OP(OP_IA64_FCMP_GE,         "ia64_fcmp_ge", NONE, NONE, NONE)
1086 MINI_OP(OP_IA64_FCMP_GT,         "ia64_fcmp_gt", NONE, NONE, NONE)
1087 MINI_OP(OP_IA64_FCMP_LT_UN,      "ia64_fcmp_lt_un", NONE, NONE, NONE)
1088 MINI_OP(OP_IA64_FCMP_GT_UN,      "ia64_fcmp_gt_un", NONE, NONE, NONE)
1089 MINI_OP(OP_IA64_FCMP_GE_UN,      "ia64_fcmp_ge_un", NONE, NONE, NONE)
1090 MINI_OP(OP_IA64_FCMP_LE_UN,      "ia64_fcmp_le_un", NONE, NONE, NONE)
1091
1092 MINI_OP(OP_IA64_BR_COND,        "ia64_br_cond", NONE, NONE, NONE)
1093 MINI_OP(OP_IA64_COND_EXC,       "ia64_cond_exc", NONE, NONE, NONE)
1094 MINI_OP(OP_IA64_CSET,           "ia64_cset", NONE, NONE, NONE)
1095
1096 MINI_OP(OP_IA64_OUTARG_R4,      "ia64_outarg_r4", NONE, NONE, NONE)
1097 MINI_OP(OP_IA64_STOREI1_MEMBASE_INC_REG, "ia64_storei1_membase_inc_reg", NONE, NONE, NONE)
1098 MINI_OP(OP_IA64_STOREI2_MEMBASE_INC_REG, "ia64_storei2_membase_inc_reg", NONE, NONE, NONE)
1099 MINI_OP(OP_IA64_STOREI4_MEMBASE_INC_REG, "ia64_storei4_membase_inc_reg", NONE, NONE, NONE)
1100 MINI_OP(OP_IA64_STOREI8_MEMBASE_INC_REG, "ia64_storei8_membase_inc_reg", NONE, NONE, NONE)
1101 MINI_OP(OP_IA64_STORER4_MEMBASE_INC_REG, "ia64_storer4_membase_inc_reg", NONE, NONE, NONE)
1102 MINI_OP(OP_IA64_STORER8_MEMBASE_INC_REG, "ia64_storer8_membase_inc_reg", NONE, NONE, NONE)
1103 MINI_OP(OP_IA64_LOADI1_MEMBASE_INC,"ia64_loadi1_membase_inc", NONE, NONE, NONE)
1104 MINI_OP(OP_IA64_LOADU1_MEMBASE_INC,"ia64_loadu1_membase_inc", NONE, NONE, NONE)
1105 MINI_OP(OP_IA64_LOADI2_MEMBASE_INC,"ia64_loadi2_membase_inc", NONE, NONE, NONE)
1106 MINI_OP(OP_IA64_LOADU2_MEMBASE_INC,"ia64_loadu2_membase_inc", NONE, NONE, NONE)
1107 MINI_OP(OP_IA64_LOADI4_MEMBASE_INC,"ia64_loadi4_membase_inc", NONE, NONE, NONE)
1108 MINI_OP(OP_IA64_LOADU4_MEMBASE_INC,"ia64_loadu4_membase_inc", NONE, NONE, NONE)
1109 MINI_OP(OP_IA64_LOADI8_MEMBASE_INC,"ia64_loadi8_membase_inc", NONE, NONE, NONE)
1110 MINI_OP(OP_IA64_LOADR4_MEMBASE_INC,"ia64_loadr4_membase_inc", NONE, NONE, NONE)
1111 MINI_OP(OP_IA64_LOADR8_MEMBASE_INC,"ia64_loadr8_membase_inc", NONE, NONE, NONE)
1112 #endif
1113
1114 #if defined(__alpha__)
1115 MINI_OP(OP_ALPHA_CMP_EQ, "alpha_cmp_eq")
1116 MINI_OP(OP_ALPHA_CMP_IMM_EQ, "alpha_cmp_imm_eq")
1117 MINI_OP(OP_ALPHA_CMP_ULT, "alpha_cmp_ult")
1118 MINI_OP(OP_ALPHA_CMP_IMM_ULT, "alpha_cmp_imm_ult")
1119 MINI_OP(OP_ALPHA_CMP_ULE, "alpha_cmp_ule")
1120 MINI_OP(OP_ALPHA_CMP_IMM_ULE, "alpha_cmp_imm_ule")
1121 MINI_OP(OP_ALPHA_CMP_LT, "alpha_cmp_lt")
1122 MINI_OP(OP_ALPHA_CMP_IMM_LT, "alpha_cmp_imm_lt")
1123 MINI_OP(OP_ALPHA_CMP_LE, "alpha_cmp_le")
1124 MINI_OP(OP_ALPHA_CMP_IMM_LE, "alpha_cmp_imm_le")
1125
1126 MINI_OP(OP_ALPHA_CMPT_EQ, "alpha_cmpt_eq")
1127 MINI_OP(OP_ALPHA_CMPT_EQ_SU, "alpha_cmpt_eq_su")
1128 MINI_OP(OP_ALPHA_CMPT_LT, "alpha_cmpt_lt")
1129 MINI_OP(OP_ALPHA_CMPT_LT_SU, "alpha_cmpt_lt_su")
1130 MINI_OP(OP_ALPHA_CMPT_LE, "alpha_cmpt_le")
1131 MINI_OP(OP_ALPHA_CMPT_LE_SU, "alpha_cmpt_le_su")
1132 MINI_OP(OP_ALPHA_CMPT_UN, "alpha_cmpt_un")
1133 MINI_OP(OP_ALPHA_CMPT_UN_SU, "alpha_cmpt_un_su")
1134 MINI_OP(OP_ALPHA_TRAPB, "alpha_trapb")
1135
1136 #endif
1137
1138 #if defined(__mips__)
1139 MINI_OP(OP_LONG_SHRUN_32,   "long_shrun_32", NONE, NONE, NONE)
1140 MINI_OP(OP_MIPS_BEQ,   "mips_beq", NONE, NONE, NONE)
1141 MINI_OP(OP_MIPS_BGEZ,  "mips_bgez", NONE, NONE, NONE)
1142 MINI_OP(OP_MIPS_BGTZ,  "mips_bgtz", NONE, NONE, NONE)
1143 MINI_OP(OP_MIPS_BLEZ,  "mips_blez", NONE, NONE, NONE)
1144 MINI_OP(OP_MIPS_BLTZ,  "mips_bltz", NONE, NONE, NONE)
1145 MINI_OP(OP_MIPS_BNE,   "mips_bne", NONE, NONE, NONE)
1146 MINI_OP(OP_MIPS_CVTSD, "mips_cvtsd", NONE, NONE, NONE)
1147 MINI_OP(OP_MIPS_FBEQ,  "mips_fbeq", NONE, NONE, NONE)
1148 MINI_OP(OP_MIPS_FBGE,  "mips_fbge", NONE, NONE, NONE)
1149 MINI_OP(OP_MIPS_FBGT,  "mips_fbgt", NONE, NONE, NONE)
1150 MINI_OP(OP_MIPS_FBLE,  "mips_fble", NONE, NONE, NONE)
1151 MINI_OP(OP_MIPS_FBLT,  "mips_fblt", NONE, NONE, NONE)
1152 MINI_OP(OP_MIPS_FBNE,  "mips_fbne", NONE, NONE, NONE)
1153 MINI_OP(OP_MIPS_FBFALSE, "mips_fbfalse", NONE, NONE, NONE)
1154 MINI_OP(OP_MIPS_FBTRUE, "mips_fbtrue", NONE, NONE, NONE)
1155 MINI_OP(OP_MIPS_LWC1,  "mips_lwc1", NONE, NONE, NONE)
1156 MINI_OP(OP_MIPS_MTC1S, "mips_mtc1_s", NONE, NONE, NONE)
1157 MINI_OP(OP_MIPS_MFC1S, "mips_mfc1_s", NONE, NONE, NONE)
1158 MINI_OP(OP_MIPS_MTC1D, "mips_mtc1_d", NONE, NONE, NONE)
1159 MINI_OP(OP_MIPS_MFC1D, "mips_mfc1_d", NONE, NONE, NONE)
1160 MINI_OP(OP_MIPS_NOP,   "mips_nop", NONE, NONE, NONE)
1161 MINI_OP(OP_MIPS_SLTI,  "mips_slti", NONE, NONE, NONE)
1162 MINI_OP(OP_MIPS_SLT,   "mips_slt", NONE, NONE, NONE)
1163 MINI_OP(OP_MIPS_SLTIU, "mips_sltiu", NONE, NONE, NONE)
1164 MINI_OP(OP_MIPS_SLTU,  "mips_sltu", NONE, NONE, NONE)
1165 MINI_OP(OP_MIPS_XORI,  "mips_xori", NONE, NONE, NONE)
1166
1167 MINI_OP(OP_MIPS_COND_EXC_EQ, "mips_cond_exc_eq", NONE, NONE, NONE)
1168 MINI_OP(OP_MIPS_COND_EXC_GE, "mips_cond_exc_ge", NONE, NONE, NONE)
1169 MINI_OP(OP_MIPS_COND_EXC_GT, "mips_cond_exc_gt", NONE, NONE, NONE)
1170 MINI_OP(OP_MIPS_COND_EXC_LE, "mips_cond_exc_le", NONE, NONE, NONE)
1171 MINI_OP(OP_MIPS_COND_EXC_LT, "mips_cond_exc_lt", NONE, NONE, NONE)
1172 MINI_OP(OP_MIPS_COND_EXC_NE_UN, "mips_cond_exc_ne_un", NONE, NONE, NONE)
1173 MINI_OP(OP_MIPS_COND_EXC_GE_UN, "mips_cond_exc_ge_un", NONE, NONE, NONE)
1174 MINI_OP(OP_MIPS_COND_EXC_GT_UN, "mips_cond_exc_gt_un", NONE, NONE, NONE)
1175 MINI_OP(OP_MIPS_COND_EXC_LE_UN, "mips_cond_exc_le_un", NONE, NONE, NONE)
1176 MINI_OP(OP_MIPS_COND_EXC_LT_UN, "mips_cond_exc_lt_un", NONE, NONE, NONE)
1177
1178 MINI_OP(OP_MIPS_COND_EXC_OV, "mips_cond_exc_ov", NONE, NONE, NONE)
1179 MINI_OP(OP_MIPS_COND_EXC_NO, "mips_cond_exc_no", NONE, NONE, NONE)
1180 MINI_OP(OP_MIPS_COND_EXC_C, "mips_cond_exc_c", NONE, NONE, NONE)
1181 MINI_OP(OP_MIPS_COND_EXC_NC, "mips_cond_exc_nc", NONE, NONE, NONE)
1182
1183 MINI_OP(OP_MIPS_COND_EXC_IEQ, "mips_cond_exc_ieq", NONE, NONE, NONE)
1184 MINI_OP(OP_MIPS_COND_EXC_IGE, "mips_cond_exc_ige", NONE, NONE, NONE)
1185 MINI_OP(OP_MIPS_COND_EXC_IGT, "mips_cond_exc_igt", NONE, NONE, NONE)
1186 MINI_OP(OP_MIPS_COND_EXC_ILE, "mips_cond_exc_ile", NONE, NONE, NONE)
1187 MINI_OP(OP_MIPS_COND_EXC_ILT, "mips_cond_exc_ilt", NONE, NONE, NONE)
1188 MINI_OP(OP_MIPS_COND_EXC_INE_UN, "mips_cond_exc_ine_un", NONE, NONE, NONE)
1189 MINI_OP(OP_MIPS_COND_EXC_IGE_UN, "mips_cond_exc_ige_un", NONE, NONE, NONE)
1190 MINI_OP(OP_MIPS_COND_EXC_IGT_UN, "mips_cond_exc_igt_un", NONE, NONE, NONE)
1191 MINI_OP(OP_MIPS_COND_EXC_ILE_UN, "mips_cond_exc_ile_un", NONE, NONE, NONE)
1192 MINI_OP(OP_MIPS_COND_EXC_ILT_UN, "mips_cond_exc_ilt_un", NONE, NONE, NONE)
1193
1194 MINI_OP(OP_MIPS_COND_EXC_IOV, "mips_cond_exc_iov", NONE, NONE, NONE)
1195 MINI_OP(OP_MIPS_COND_EXC_INO, "mips_cond_exc_ino", NONE, NONE, NONE)
1196 MINI_OP(OP_MIPS_COND_EXC_IC, "mips_cond_exc_ic", NONE, NONE, NONE)
1197 MINI_OP(OP_MIPS_COND_EXC_INC, "mips_cond_exc_inc", NONE, NONE, NONE)
1198
1199 #endif
1200
1201 #if defined(__hppa)
1202 MINI_OP(OP_HPPA_BEQ, "hppa_beq", NONE, NONE, NONE)
1203 MINI_OP(OP_HPPA_BGE, "hppa_bge", NONE, NONE, NONE)
1204 MINI_OP(OP_HPPA_BGT, "hppa_bgt", NONE, NONE, NONE)
1205 MINI_OP(OP_HPPA_BLE, "hppa_ble", NONE, NONE, NONE)
1206 MINI_OP(OP_HPPA_BLT, "hppa_blt", NONE, NONE, NONE)
1207 MINI_OP(OP_HPPA_BNE, "hppa_bne", NONE, NONE, NONE)
1208 MINI_OP(OP_HPPA_BGE_UN, "hppa_bge_un", NONE, NONE, NONE)
1209 MINI_OP(OP_HPPA_BGT_UN, "hppa_bgt_un", NONE, NONE, NONE)
1210 MINI_OP(OP_HPPA_BLE_UN, "hppa_ble_un", NONE, NONE, NONE)
1211 MINI_OP(OP_HPPA_BLT_UN, "hppa_blt_un", NONE, NONE, NONE)
1212
1213 MINI_OP(OP_HPPA_CEQ, "hppa_ceq", NONE, NONE, NONE)
1214 MINI_OP(OP_HPPA_CGT, "hppa_cgt", NONE, NONE, NONE)
1215 MINI_OP(OP_HPPA_CGT_UN, "hppa_cgt_un", NONE, NONE, NONE)
1216 MINI_OP(OP_HPPA_CLT, "hppa_clt", NONE, NONE, NONE)
1217 MINI_OP(OP_HPPA_CLT_UN, "hppa_clt_un", NONE, NONE, NONE)
1218
1219 MINI_OP(OP_HPPA_CEQ_IMM, "hppa_ceq_imm", NONE, NONE, NONE)
1220 MINI_OP(OP_HPPA_CGT_IMM, "hppa_cgt_imm", NONE, NONE, NONE)
1221 MINI_OP(OP_HPPA_CGT_UN_IMM, "hppa_cgt_un_imm", NONE, NONE, NONE)
1222 MINI_OP(OP_HPPA_CLT_IMM, "hppa_clt_imm", NONE, NONE, NONE)
1223 MINI_OP(OP_HPPA_CLT_UN_IMM, "hppa_clt_un_imm", NONE, NONE, NONE)
1224
1225 MINI_OP(OP_HPPA_COND_EXC_EQ, "hppa_cond_exc_eq", NONE, NONE, NONE)
1226 MINI_OP(OP_HPPA_COND_EXC_GE, "hppa_cond_exc_ge", NONE, NONE, NONE)
1227 MINI_OP(OP_HPPA_COND_EXC_GT, "hppa_cond_exc_gt", NONE, NONE, NONE)
1228 MINI_OP(OP_HPPA_COND_EXC_LE, "hppa_cond_exc_le", NONE, NONE, NONE)
1229 MINI_OP(OP_HPPA_COND_EXC_LT, "hppa_cond_exc_lt", NONE, NONE, NONE)
1230 MINI_OP(OP_HPPA_COND_EXC_NE_UN, "hppa_cond_exc_ne_un", NONE, NONE, NONE)
1231 MINI_OP(OP_HPPA_COND_EXC_GE_UN, "hppa_cond_exc_ge_un", NONE, NONE, NONE)
1232 MINI_OP(OP_HPPA_COND_EXC_GT_UN, "hppa_cond_exc_gt_un", NONE, NONE, NONE)
1233 MINI_OP(OP_HPPA_COND_EXC_LE_UN, "hppa_cond_exc_le_un", NONE, NONE, NONE)
1234 MINI_OP(OP_HPPA_COND_EXC_LT_UN, "hppa_cond_exc_lt_un", NONE, NONE, NONE)
1235 MINI_OP(OP_HPPA_COND_EXC_OV, "hppa_cond_exc_ov", NONE, NONE, NONE)
1236 MINI_OP(OP_HPPA_COND_EXC_NO, "hppa_cond_exc_no", NONE, NONE, NONE)
1237 MINI_OP(OP_HPPA_COND_EXC_C, "hppa_cond_exc_c", NONE, NONE, NONE)
1238 MINI_OP(OP_HPPA_COND_EXC_NC, "hppa_cond_exc_nc", NONE, NONE, NONE)
1239
1240 MINI_OP(OP_HPPA_XMPYU, "hppa_xmpyu", NONE, NONE, NONE)
1241 MINI_OP(OP_HPPA_ADD_OVF, "hppa_add_ovf", NONE, NONE, NONE)
1242 MINI_OP(OP_HPPA_SUB_OVF, "hppa_sub_ovf", NONE, NONE, NONE)
1243 MINI_OP(OP_HPPA_ADDC_OVF, "hppa_addc_ovf", NONE, NONE, NONE)
1244 MINI_OP(OP_HPPA_SUBB_OVF, "hppa_subb_ovf", NONE, NONE, NONE)
1245
1246 MINI_OP(OP_HPPA_OUTARG_R4CONST, "hppa_outarg_r4const", NONE, NONE, NONE)
1247 MINI_OP(OP_HPPA_OUTARG_REGOFFSET, "hppa_outarg_regoffset", NONE, NONE, NONE)
1248
1249 MINI_OP(OP_HPPA_LOADR4_LEFT, "hppa_loadr4_left", NONE, NONE, NONE)
1250 MINI_OP(OP_HPPA_LOADR4_RIGHT, "hppa_loadr4_right", NONE, NONE, NONE)
1251 MINI_OP(OP_HPPA_STORER4_LEFT, "hppa_storer4_left", NONE, NONE, NONE)
1252 MINI_OP(OP_HPPA_STORER4_RIGHT, "hppa_storer4_right", NONE, NONE, NONE)
1253
1254 MINI_OP(OP_HPPA_SETF4REG, "hppa_setf4reg", NONE, NONE, NONE)
1255 #endif