Merge remote branch 'upstream/master'
[mono.git] / mono / mini / mini-ops.h
index b5759c8125af2d158bea799c6e28f1964296f526..687abadec168f4c8cace239a5999c9e18fb2bf1c 100644 (file)
@@ -2,15 +2,12 @@
 MINI_OP(OP_LOAD,       "load", NONE, NONE, NONE)
 MINI_OP(OP_LDADDR,     "ldaddr", IREG, NONE, NONE)
 MINI_OP(OP_STORE,      "store", NONE, NONE, NONE)
-MINI_OP(OP_OBJADDR,    "objaddr", NONE, NONE, NONE)
-MINI_OP(OP_VTADDR,     "vtaddr", NONE, NONE, NONE)
 MINI_OP(OP_NOP,     "nop", NONE, NONE, NONE)
 MINI_OP(OP_HARD_NOP,    "hard_nop", NONE, NONE, NONE)
 MINI_OP(OP_RELAXED_NOP,     "relaxed_nop", NONE, NONE, NONE)
 MINI_OP(OP_PHI,                "phi", IREG, NONE, NONE)
 MINI_OP(OP_FPHI,       "fphi", FREG, NONE, NONE)
 MINI_OP(OP_VPHI,       "vphi", VREG, NONE, NONE)
-MINI_OP(OP_RENAME,     "rename", NONE, NONE, NONE)
 MINI_OP(OP_COMPARE,    "compare", NONE, IREG, IREG)
 MINI_OP(OP_COMPARE_IMM,        "compare_imm", NONE, IREG, NONE)
 MINI_OP(OP_FCOMPARE,   "fcompare", NONE, FREG, FREG)
@@ -20,30 +17,25 @@ MINI_OP(OP_ICOMPARE_IMM,    "icompare_imm", NONE, IREG, NONE)
 MINI_OP(OP_LCOMPARE_IMM,       "lcompare_imm", NONE, LREG, NONE)
 MINI_OP(OP_LOCAL,      "local", NONE, NONE, NONE)
 MINI_OP(OP_ARG,                "arg", NONE, NONE, NONE)
-MINI_OP(OP_ARGLIST,    "oparglist", NONE, IREG, NONE)
-MINI_OP(OP_OUTARG,     "outarg", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_REG, "outarg_reg", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_FREG,        "outarg_freg", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_FREG_R4,     "outarg_freg_r4", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_IMM, "outarg_imm", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_R4,  "outarg_r4", NONE, NONE, NONE)
-MINI_OP(OP_OUTARG_R8,  "outarg_r8", NONE, NONE, NONE)
 MINI_OP(OP_OUTARG_VT,  "outarg_vt", NONE, VREG, NONE)
 MINI_OP(OP_OUTARG_VTRETADDR, "outarg_vtretaddr", IREG, NONE, NONE)
-MINI_OP(OP_OUTARG_MEMBASE,     "outarg_membase", NONE, NONE, NONE)
-MINI_OP(OP_INARG_VT,   "inarg_vt", NONE, NONE, NONE)
-MINI_OP(OP_RETARG,     "retarg", NONE, NONE, NONE)
-MINI_OP(OP_SETRET,     "setret", NONE, NONE, NONE)
+MINI_OP(OP_SETRET,     "setret", NONE, IREG, NONE)
 MINI_OP(OP_SETFRET,    "setfret", FREG, FREG, NONE)
 MINI_OP(OP_SETLRET,    "setlret", NONE, IREG, IREG)
 MINI_OP(OP_LOCALLOC, "localloc", IREG, IREG, NONE)
 MINI_OP(OP_LOCALLOC_IMM, "localloc_imm", IREG, NONE, NONE)
 MINI_OP(OP_CHECK_THIS, "checkthis", NONE, IREG, NONE)
-MINI_OP(OP_CHECK_THIS_PASSTHROUGH,     "checkthis_passthrough", NONE, NONE, NONE)
+MINI_OP(OP_SEQ_POINT, "seq_point", NONE, NONE, NONE)
+MINI_OP(OP_IMPLICIT_EXCEPTION, "implicit_exception", NONE, NONE, NONE)
+
 MINI_OP(OP_VOIDCALL,   "voidcall", NONE, NONE, NONE)
 MINI_OP(OP_VOIDCALLVIRT,       "voidcallvirt", NONE, NONE, NONE)
 MINI_OP(OP_VOIDCALL_REG,       "voidcall_reg", NONE, IREG, NONE)
 MINI_OP(OP_VOIDCALL_MEMBASE,   "voidcall_membase", NONE, IREG, NONE)
+MINI_OP(OP_CALL,        "call", IREG, NONE, NONE)
+MINI_OP(OP_CALL_REG,   "call_reg", IREG, IREG, NONE)
+MINI_OP(OP_CALL_MEMBASE,       "call_membase", IREG, IREG, NONE)
+MINI_OP(OP_CALLVIRT, "callvirt", IREG, NONE, NONE)
 MINI_OP(OP_FCALL,      "fcall", FREG, NONE, NONE)
 MINI_OP(OP_FCALLVIRT,  "fcallvirt", FREG, NONE, NONE)
 MINI_OP(OP_FCALL_REG,  "fcall_reg", FREG, IREG, NONE)
@@ -56,63 +48,54 @@ MINI_OP(OP_VCALL,   "vcall", VREG, NONE, NONE)
 MINI_OP(OP_VCALLVIRT,  "vcallvirt", VREG, NONE, NONE)
 MINI_OP(OP_VCALL_REG,  "vcall_reg", VREG, IREG, NONE)
 MINI_OP(OP_VCALL_MEMBASE,      "vcall_membase", VREG, IREG, NONE)
-MINI_OP(OP_VOIDCALL_RGCTX,     "voidcall_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_LCALL_RGCTX,                "lcall_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_VCALL_RGCTX,                "vcall_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_CALL_RGCTX,         "call_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_FCALL_RGCTX,                "fcall_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_VOIDCALL_REG_RGCTX, "voidcall_reg_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_LCALL_REG_RGCTX,    "lcall_reg_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_VCALL_REG_RGCTX,    "vcall_reg_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_CALL_REG_RGCTX,     "call_reg_rgctx", NONE, NONE, NONE)
-MINI_OP(OP_VOIDCALLVIRT_IMT,   "voidcallvirt_imt", NONE, NONE, NONE)
-MINI_OP(OP_CALLVIRT_IMT,       "callvirt_imt", NONE, NONE, NONE)
-MINI_OP(OP_FCALLVIRT_IMT,      "fcallvirt_imt", NONE, NONE, NONE)
-MINI_OP(OP_LCALLVIRT_IMT,      "lcallvirt_imt", NONE, NONE, NONE)
-MINI_OP(OP_VCALLVIRT_IMT,      "vcallvirt_imt", NONE, NONE, NONE)
-MINI_OP(OP_FCALL_REG_RGCTX,    "fcall_reg_rgctx", NONE, NONE, NONE)
-
-MINI_OP(OP_TRAMPCALL_VTABLE,   "trampcall_vtable", NONE, NONE, NONE)
-
 /* Represents the decomposed vcall which doesn't return a vtype no more */
 MINI_OP(OP_VCALL2,     "vcall2", NONE, NONE, NONE)
 MINI_OP(OP_VCALL2_REG, "vcall2_reg", NONE, IREG, NONE)
 MINI_OP(OP_VCALL2_MEMBASE,     "vcall2_membase", NONE, IREG, NONE)
+MINI_OP(OP_DYN_CALL, "dyn_call", NONE, IREG, IREG)
 
-MINI_OP(OP_CALL,        "call", IREG, NONE, NONE)
-MINI_OP(OP_CALL_REG,   "call_reg", IREG, IREG, NONE)
-MINI_OP(OP_CALL_MEMBASE,       "call_membase", IREG, IREG, NONE)
-MINI_OP(OP_CALLVIRT, "callvirt", IREG, NONE, NONE)
-MINI_OP(OP_TRAP,       "trap", NONE, NONE, NONE)
 MINI_OP(OP_ICONST,     "iconst", IREG, NONE, NONE)
 MINI_OP(OP_I8CONST,    "i8const", LREG, NONE, NONE)
 MINI_OP(OP_R4CONST,    "r4const", FREG, NONE, NONE)
 MINI_OP(OP_R8CONST,    "r8const", FREG, NONE, NONE)
 MINI_OP(OP_REGVAR,     "regvar", NONE, NONE, NONE)
-MINI_OP(OP_REG,                "reg", NONE, NONE, NONE)
 MINI_OP(OP_REGOFFSET,  "regoffset", NONE, NONE, NONE)
 MINI_OP(OP_VTARG_ADDR, "vtarg_addr", NONE, NONE, NONE)
 MINI_OP(OP_LABEL,      "label", NONE, NONE, NONE)
 MINI_OP(OP_SWITCH,  "switch", NONE, IREG, NONE)
-MINI_OP(OP_CHECK_ARRAY_TYPE,   "check_array_type", NONE, NONE, NONE)
-MINI_OP(OP_ARRAY_RANK, "array_rank", NONE, NONE, NONE)
 MINI_OP(OP_THROW, "throw", NONE, IREG, NONE)
-MINI_OP(OP_THROW_OR_NULL,      "throw_or_null", NONE, NONE, NONE)
 MINI_OP(OP_RETHROW,    "rethrow", NONE, IREG, NONE)
-MINI_OP(OP_REFANYTYPE, "refanytype", NONE, NONE, NONE)
+
+/*
+ * Vararg calls are implemented as follows:
+ * - the caller emits a hidden argument just before the varargs argument. this
+ *   'signature cookie' argument contains the signature describing the the call.
+ * - all implicit arguments are passed in memory right after the signature cookie, i.e.
+ *   the stack will look like this:
+ *   <argn>
+ *   ..
+ *   <arg1>
+ *   <sig cookie>
+ * - the OP_ARGLIST opcode in the callee computes the address of the sig cookie argument
+ *   on the stack and saves it into its sreg1.
+ * - mono_ArgIterator_Setup receives this value and uses it to find the signature and
+ *   the arguments.
+ */
+MINI_OP(OP_ARGLIST,    "oparglist", NONE, IREG, NONE)
 
 /* MONO_IS_STORE_MEMBASE depends on the order here */
 MINI_OP(OP_STORE_MEMBASE_REG,"store_membase_reg", IREG, IREG, NONE)
 MINI_OP(OP_STOREI1_MEMBASE_REG, "storei1_membase_reg", IREG, IREG, NONE)
 MINI_OP(OP_STOREI2_MEMBASE_REG, "storei2_membase_reg", IREG, IREG, NONE)
 MINI_OP(OP_STOREI4_MEMBASE_REG, "storei4_membase_reg", IREG, IREG, NONE)
-MINI_OP(OP_STOREI8_MEMBASE_REG, "storei8_membase_reg", IREG, IREG, NONE)
+MINI_OP(OP_STOREI8_MEMBASE_REG, "storei8_membase_reg", IREG, LREG, NONE)
 MINI_OP(OP_STORER4_MEMBASE_REG, "storer4_membase_reg", IREG, FREG, NONE)
 MINI_OP(OP_STORER8_MEMBASE_REG, "storer8_membase_reg", IREG, FREG, NONE)
 
-#ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
+#if defined(TARGET_X86) || defined(TARGET_AMD64)
 MINI_OP(OP_STOREX_MEMBASE_REG, "storex_membase_reg", IREG, XREG, NONE)
 MINI_OP(OP_STOREX_ALIGNED_MEMBASE_REG,     "storex_aligned_membase_reg", IREG, XREG, NONE)
+MINI_OP(OP_STOREX_NTA_MEMBASE_REG,     "storex_nta_membase_reg", IREG, XREG, NONE)
 #endif
 
 MINI_OP(OP_STORE_MEMBASE_IMM,"store_membase_imm", IREG, NONE, NONE)
@@ -131,40 +114,39 @@ MINI_OP(OP_LOADI2_MEMBASE,"loadi2_membase", IREG, IREG, NONE)
 MINI_OP(OP_LOADU2_MEMBASE,"loadu2_membase", IREG, IREG, NONE)
 MINI_OP(OP_LOADI4_MEMBASE,"loadi4_membase", IREG, IREG, NONE)
 MINI_OP(OP_LOADU4_MEMBASE,"loadu4_membase", IREG, IREG, NONE)
-MINI_OP(OP_LOADI8_MEMBASE,"loadi8_membase", IREG, IREG, NONE)
+MINI_OP(OP_LOADI8_MEMBASE,"loadi8_membase", LREG, IREG, NONE)
 MINI_OP(OP_LOADR4_MEMBASE,"loadr4_membase", FREG, IREG, NONE)
 MINI_OP(OP_LOADR8_MEMBASE,"loadr8_membase", FREG, IREG, NONE)
 
 MINI_OP(OP_LOADX_MEMBASE,                      "loadx_membase", XREG, IREG, NONE)
 
-#ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
+#if defined(TARGET_X86) || defined(TARGET_AMD64)
 MINI_OP(OP_LOADX_ALIGNED_MEMBASE,  "loadx_aligned_membase", XREG, IREG, NONE)
 #endif
 
 MINI_OP(OP_LOADV_MEMBASE,   "loadv_membase", VREG, IREG, NONE)
 
 /* indexed loads: dreg = load at (sreg1 + sreg2)*/
-MINI_OP(OP_LOAD_MEMINDEX,  "load_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADI1_MEMINDEX,"loadi1_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADU1_MEMINDEX,"loadu1_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADI2_MEMINDEX,"loadi2_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADU2_MEMINDEX,"loadu2_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADI4_MEMINDEX,"loadi4_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADU4_MEMINDEX,"loadu4_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADI8_MEMINDEX,"loadi8_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADR4_MEMINDEX,"loadr4_memindex", NONE, NONE, NONE)
-MINI_OP(OP_LOADR8_MEMINDEX,"loadr8_memindex", NONE, NONE, NONE)
+MINI_OP(OP_LOAD_MEMINDEX,  "load_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADI1_MEMINDEX,"loadi1_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADU1_MEMINDEX,"loadu1_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADI2_MEMINDEX,"loadi2_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADU2_MEMINDEX,"loadu2_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADI4_MEMINDEX,"loadi4_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADU4_MEMINDEX,"loadu4_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADI8_MEMINDEX,"loadi8_memindex", IREG, IREG, IREG)
+MINI_OP(OP_LOADR4_MEMINDEX,"loadr4_memindex", FREG, IREG, IREG)
+MINI_OP(OP_LOADR8_MEMINDEX,"loadr8_memindex", FREG, IREG, IREG)
 /* indexed stores: store sreg1 at (destbasereg + sreg2) */
 /* MONO_IS_STORE_MEMINDEX depends on the order here */
-MINI_OP(OP_STORE_MEMINDEX,"store_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STOREI1_MEMINDEX,"storei1_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STOREI2_MEMINDEX,"storei2_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STOREI4_MEMINDEX,"storei4_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STOREI8_MEMINDEX,"storei8_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STORER4_MEMINDEX,"storer4_memindex", NONE, NONE, NONE)
-MINI_OP(OP_STORER8_MEMINDEX,"storer8_memindex", NONE, NONE, NONE)
-
-MINI_OP(OP_LOADR8_SPILL_MEMBASE,"loadr8_spill_membase", NONE, NONE, NONE)
+MINI_OP(OP_STORE_MEMINDEX,"store_memindex", IREG, IREG, IREG)
+MINI_OP(OP_STOREI1_MEMINDEX,"storei1_memindex", IREG, IREG, IREG)
+MINI_OP(OP_STOREI2_MEMINDEX,"storei2_memindex", IREG, IREG, IREG)
+MINI_OP(OP_STOREI4_MEMINDEX,"storei4_memindex", IREG, IREG, IREG)
+MINI_OP(OP_STOREI8_MEMINDEX,"storei8_memindex", IREG, IREG, IREG)
+MINI_OP(OP_STORER4_MEMINDEX,"storer4_memindex", IREG, FREG, IREG)
+MINI_OP(OP_STORER8_MEMINDEX,"storer8_memindex", IREG, FREG, IREG)
+
 MINI_OP(OP_LOAD_MEM,"load_mem", IREG, NONE, NONE)
 MINI_OP(OP_LOADU1_MEM,"loadu1_mem", IREG, NONE, NONE)
 MINI_OP(OP_LOADU2_MEM,"loadu2_mem", IREG, NONE, NONE)
@@ -266,8 +248,8 @@ MINI_OP(OP_LCONV_TO_R8,"long_conv_to_r8", FREG, LREG, NONE)
 MINI_OP(OP_LCONV_TO_U4,"long_conv_to_u4", LREG, LREG, NONE)
 MINI_OP(OP_LCONV_TO_U8,"long_conv_to_u8", LREG, LREG, NONE)
 
-MINI_OP(OP_LCONV_TO_U2,   "long_conv_to_u2", LREG, LREG, NONE)
-MINI_OP(OP_LCONV_TO_U1,   "long_conv_to_u1", LREG, LREG, NONE)
+MINI_OP(OP_LCONV_TO_U2,   "long_conv_to_u2", IREG, LREG, NONE)
+MINI_OP(OP_LCONV_TO_U1,   "long_conv_to_u1", IREG, LREG, NONE)
 MINI_OP(OP_LCONV_TO_I,    "long_conv_to_i", LREG, LREG, NONE)
 MINI_OP(OP_LCONV_TO_OVF_I,"long_conv_to_ovf_i", LREG, LREG, NONE)
 MINI_OP(OP_LCONV_TO_OVF_U,"long_conv_to_ovf_u", LREG, LREG, NONE)
@@ -335,8 +317,6 @@ MINI_OP(OP_LBGT_UN, "long_bgt_un", NONE, NONE, NONE)
 MINI_OP(OP_LBLE_UN, "long_ble_un", NONE, NONE, NONE)
 MINI_OP(OP_LBLT_UN, "long_blt_un", NONE, NONE, NONE)
 
-MINI_OP(OP_LSHR_UN_32, "long_shr_un_32", NONE, NONE, NONE)
-
 /* Variants of the original opcodes which take the two parts of the long as two arguments */
 MINI_OP(OP_LCONV_TO_R8_2,"long_conv_to_r8_2", FREG, IREG, IREG)
 MINI_OP(OP_LCONV_TO_R4_2,"long_conv_to_r4_2", FREG, IREG, IREG)
@@ -472,11 +452,11 @@ MINI_OP(OP_FNOT,       "float_not", FREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_I1,"float_conv_to_i1", IREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_I2,"float_conv_to_i2", IREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_I4,"float_conv_to_i4", IREG, FREG, NONE)
-MINI_OP(OP_FCONV_TO_I8,"float_conv_to_i8", IREG, FREG, NONE)
+MINI_OP(OP_FCONV_TO_I8,"float_conv_to_i8", LREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_R4,"float_conv_to_r4", FREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_R8,"float_conv_to_r8", FREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_U4,"float_conv_to_u4", IREG, FREG, NONE)
-MINI_OP(OP_FCONV_TO_U8,"float_conv_to_u8", IREG, FREG, NONE)
+MINI_OP(OP_FCONV_TO_U8,"float_conv_to_u8", LREG, FREG, NONE)
 
 MINI_OP(OP_FCONV_TO_U2,   "float_conv_to_u2", IREG, FREG, NONE)
 MINI_OP(OP_FCONV_TO_U1,   "float_conv_to_u1", IREG, FREG, NONE)
@@ -518,13 +498,13 @@ MINI_OP(OP_FCGT_UN,"float_cgt_un", IREG, FREG, FREG)
 MINI_OP(OP_FCLT,   "float_clt", IREG, FREG, FREG)
 MINI_OP(OP_FCLT_UN,"float_clt_un", IREG, FREG, FREG)
 
-MINI_OP(OP_FCEQ_MEMBASE,   "float_ceq_membase", NONE, NONE, NONE)
-MINI_OP(OP_FCGT_MEMBASE,   "float_cgt_membase", NONE, NONE, NONE)
-MINI_OP(OP_FCGT_UN_MEMBASE,"float_cgt_un_membase", NONE, NONE, NONE)
-MINI_OP(OP_FCLT_MEMBASE,   "float_clt_membase", NONE, NONE, NONE)
-MINI_OP(OP_FCLT_UN_MEMBASE,"float_clt_un_membase", NONE, NONE, NONE)
+MINI_OP(OP_FCEQ_MEMBASE,   "float_ceq_membase", IREG, FREG, IREG)
+MINI_OP(OP_FCGT_MEMBASE,   "float_cgt_membase", IREG, FREG, IREG)
+MINI_OP(OP_FCGT_UN_MEMBASE,"float_cgt_un_membase", IREG, FREG, IREG)
+MINI_OP(OP_FCLT_MEMBASE,   "float_clt_membase", IREG, FREG, IREG)
+MINI_OP(OP_FCLT_UN_MEMBASE,"float_clt_un_membase", IREG, FREG, IREG)
 
-MINI_OP(OP_FCONV_TO_U, "float_conv_to_u", NONE, NONE, NONE)
+MINI_OP(OP_FCONV_TO_U, "float_conv_to_u", IREG, FREG, NONE)
 MINI_OP(OP_CKFINITE, "ckfinite", FREG, FREG, NONE)
 
 /* Return the low 32 bits of a double vreg */
@@ -532,7 +512,6 @@ MINI_OP(OP_FGETLOW32, "float_getlow32", IREG, FREG, NONE)
 /* Return the high 32 bits of a double vreg */
 MINI_OP(OP_FGETHIGH32, "float_gethigh32", IREG, FREG, NONE)
 
-MINI_OP(OP_GROUP, "group", NONE, NONE, NONE)
 MINI_OP(OP_JUMP_TABLE, "jump_table", IREG, NONE, NONE)
 
 /* aot compiler */
@@ -540,10 +519,6 @@ MINI_OP(OP_AOTCONST, "aot_const", IREG, NONE, NONE)
 MINI_OP(OP_PATCH_INFO, "patch_info", NONE, NONE, NONE)
 MINI_OP(OP_GOT_ENTRY, "got_entry", IREG, IREG, NONE)
 
-/* used to impl unbox */
-MINI_OP(OP_UNBOXCAST  , "unboxcast", NONE, NONE, NONE)
-MINI_OP(OP_UNBOXCAST_REG  , "unboxcast_reg", NONE, NONE, NONE)
-
 /* exception related opcodes */
 MINI_OP(OP_CALL_HANDLER  , "call_handler", NONE, NONE, NONE)
 MINI_OP(OP_START_HANDLER  , "start_handler", NONE, NONE, NONE)
@@ -551,8 +526,8 @@ MINI_OP(OP_ENDFILTER,  "endfilter", NONE, IREG, NONE)
 MINI_OP(OP_ENDFINALLY,  "endfinally", NONE, NONE, NONE)
 
 /* inline (long)int * (long)int */
-MINI_OP(OP_BIGMUL, "bigmul", NONE, NONE, NONE)
-MINI_OP(OP_BIGMUL_UN, "bigmul_un", NONE, NONE, NONE)
+MINI_OP(OP_BIGMUL, "bigmul", LREG, IREG, IREG)
+MINI_OP(OP_BIGMUL_UN, "bigmul_un", LREG, IREG, IREG)
 MINI_OP(OP_IMIN_UN, "int_min_un", IREG, IREG, IREG)
 MINI_OP(OP_IMAX_UN, "int_max_un", IREG, IREG, IREG)
 MINI_OP(OP_LMIN_UN, "long_min_un", LREG, LREG, LREG)
@@ -578,11 +553,12 @@ MINI_OP(OP_SUBCC_IMM,   "subcc_imm", IREG, IREG, NONE)
 MINI_OP(OP_BR_REG,  "br_reg", NONE, IREG, NONE)
 MINI_OP(OP_SEXT_I1,  "sext_i1", IREG, IREG, NONE)
 MINI_OP(OP_SEXT_I2,  "sext_i2", IREG, IREG, NONE)
-MINI_OP(OP_SEXT_I4,  "sext_i4", IREG, IREG, NONE)
+MINI_OP(OP_SEXT_I4,  "sext_i4", LREG, IREG, NONE)
 MINI_OP(OP_ZEXT_I1,  "zext_i1", IREG, IREG, NONE)
 MINI_OP(OP_ZEXT_I2,  "zext_i2", IREG, IREG, NONE)
-MINI_OP(OP_ZEXT_I4,  "zext_i4", IREG, IREG, NONE)
+MINI_OP(OP_ZEXT_I4,  "zext_i4", LREG, IREG, NONE)
 MINI_OP(OP_CNE,      "cne", NONE, NONE, NONE)
+MINI_OP(OP_TRUNC_I4, "trunc_i4", IREG, LREG, NONE)
 /* to implement the upper half of long32 add and sub */
 MINI_OP(OP_ADD_OVF_CARRY,   "add_ovf_carry", IREG, IREG, IREG)
 MINI_OP(OP_SUB_OVF_CARRY,   "sub_ovf_carry", IREG, IREG, IREG)
@@ -596,12 +572,9 @@ MINI_OP(OP_ABS,     "abs", FREG, FREG, NONE)
 MINI_OP(OP_TAN,     "tan", FREG, FREG, NONE)
 MINI_OP(OP_ATAN,    "atan", FREG, FREG, NONE)
 MINI_OP(OP_SQRT,    "sqrt", FREG, FREG, NONE)
+MINI_OP(OP_ROUND,   "round", FREG, FREG, NONE)
 /* to optimize strings */
-MINI_OP(OP_GETCHR, "getchar", NONE, NONE, NONE)
-MINI_OP(OP_STR_CHAR_ADDR, "str_char_addr", NONE, NONE, NONE)
 MINI_OP(OP_STRLEN, "strlen", IREG, IREG, NONE)
-MINI_OP(OP_GETTYPE, "gettype", NONE, NONE, NONE)
-MINI_OP(OP_GETHASHCODE, "gethashcode", NONE, NONE, NONE)
 MINI_OP(OP_NEWARR, "newarr", IREG, IREG, NONE)
 MINI_OP(OP_LDLEN, "ldlen", IREG, IREG, NONE)
 MINI_OP(OP_BOUNDS_CHECK, "bounds_check", NONE, IREG, IREG)
@@ -611,14 +584,11 @@ MINI_OP(OP_LDELEMA2D, "getldelema2", NONE, NONE, NONE)
 MINI_OP(OP_MEMCPY, "memcpy", NONE, NONE, NONE)
 /* inlined small memset with constant length */
 MINI_OP(OP_MEMSET, "memset", NONE, NONE, NONE)
-/* type check that support custom remoting types */
-MINI_OP(OP_CISINST, "cisinst", NONE, NONE, NONE)
-MINI_OP(OP_CCASTCLASS, "ccastclass", NONE, NONE, NONE)
 MINI_OP(OP_SAVE_LMF, "save_lmf", NONE, NONE, NONE)
 MINI_OP(OP_RESTORE_LMF, "restore_lmf", NONE, NONE, NONE)
-/* mkrefany/refanyval for generic sharing */
-MINI_OP(OP_MKREFANY_REGS, "mkrefany_regs", NONE, NONE, NONE)
-MINI_OP(OP_REFANYVAL_REG, "refanyval_reg", NONE, NONE, NONE)
+
+/* write barrier */
+MINI_OP(OP_CARD_TABLE_WBARRIER, "card_table_wbarrier", NONE, IREG, IREG)
 
 /* arch-dep tls access */
 MINI_OP(OP_TLS_GET,            "tls_get", IREG, NONE, NONE)
@@ -631,7 +601,7 @@ MINI_OP(OP_NOT_NULL, "not_null", NONE, IREG, NONE)
 
 /* SIMD opcodes. */
 
-#ifdef MONO_ARCH_SUPPORT_SIMD_INTRINSICS
+#if defined(TARGET_X86) || defined(TARGET_AMD64)
 
 MINI_OP(OP_ADDPS, "addps", XREG, XREG, XREG)
 MINI_OP(OP_DIVPS, "divps", XREG, XREG, XREG)
@@ -653,12 +623,29 @@ MINI_OP(OP_DUPPS_HIGH, "dupps_high", XREG, XREG, NONE)
 MINI_OP(OP_RSQRTPS, "rsqrtps", XREG, XREG, NONE)
 MINI_OP(OP_SQRTPS, "sqrtps", XREG, XREG, NONE)
 MINI_OP(OP_RCPPS, "rcpps", XREG, XREG, NONE)
-MINI_OP(OP_SHUFLEPS, "shuffleps", XREG, XREG, NONE)
 
 MINI_OP(OP_PSHUFLEW_HIGH, "pshufflew_high", XREG, XREG, NONE)
 MINI_OP(OP_PSHUFLEW_LOW, "pshufflew_low", XREG, XREG, NONE)
 MINI_OP(OP_PSHUFLED, "pshuffled", XREG, XREG, NONE)
 
+MINI_OP(OP_ADDPD, "addpd", XREG, XREG, XREG)
+MINI_OP(OP_DIVPD, "divpd", XREG, XREG, XREG)
+MINI_OP(OP_MULPD, "mulpd", XREG, XREG, XREG)
+MINI_OP(OP_SUBPD, "subpd", XREG, XREG, XREG)
+MINI_OP(OP_MAXPD, "maxpd", XREG, XREG, XREG)
+MINI_OP(OP_MINPD, "minpd", XREG, XREG, XREG)
+MINI_OP(OP_COMPPD, "comppd", XREG, XREG, XREG)
+MINI_OP(OP_ANDPD, "andpd", XREG, XREG, XREG)
+MINI_OP(OP_ANDNPD, "andnpd", XREG, XREG, XREG)
+MINI_OP(OP_ORPD, "orpd", XREG, XREG, XREG)
+MINI_OP(OP_XORPD, "xorpd", XREG, XREG, XREG)
+MINI_OP(OP_HADDPD, "haddpd", XREG, XREG, XREG)
+MINI_OP(OP_HSUBPD, "hsubpd", XREG, XREG, XREG)
+MINI_OP(OP_ADDSUBPD, "addsubpd", XREG, XREG, XREG)
+MINI_OP(OP_DUPPD, "duppd", XREG, XREG, NONE)
+
+MINI_OP(OP_SQRTPD, "sqrtpd", XREG, XREG, NONE)
+
 MINI_OP(OP_EXTRACT_MASK, "extract_mask", IREG, XREG, NONE)
 
 MINI_OP(OP_PAND, "pand", XREG, XREG, XREG)
@@ -668,10 +655,12 @@ MINI_OP(OP_PXOR, "pxor", XREG, XREG, XREG)
 MINI_OP(OP_PADDB, "paddb", XREG, XREG, XREG)
 MINI_OP(OP_PADDW, "paddw", XREG, XREG, XREG)
 MINI_OP(OP_PADDD, "paddd", XREG, XREG, XREG)
+MINI_OP(OP_PADDQ, "paddq", XREG, XREG, XREG)
 
 MINI_OP(OP_PSUBB, "psubb", XREG, XREG, XREG)
 MINI_OP(OP_PSUBW, "psubw", XREG, XREG, XREG)
 MINI_OP(OP_PSUBD, "psubd", XREG, XREG, XREG)
+MINI_OP(OP_PSUBQ, "psubq", XREG, XREG, XREG)
 
 MINI_OP(OP_PMAXB_UN, "pmaxb_un", XREG, XREG, XREG)
 MINI_OP(OP_PMAXW_UN, "pmaxw_un", XREG, XREG, XREG)
@@ -695,10 +684,12 @@ MINI_OP(OP_PMIND, "pmind", XREG, XREG, XREG)
 MINI_OP(OP_PCMPEQB, "pcmpeqb", XREG, XREG, XREG)
 MINI_OP(OP_PCMPEQW, "pcmpeqw", XREG, XREG, XREG)
 MINI_OP(OP_PCMPEQD, "pcmpeqd", XREG, XREG, XREG)
+MINI_OP(OP_PCMPEQQ, "pcmpeqq", XREG, XREG, XREG)
 
 MINI_OP(OP_PCMPGTB, "pcmpgtb", XREG, XREG, XREG)
 MINI_OP(OP_PCMPGTW, "pcmpgtw", XREG, XREG, XREG)
 MINI_OP(OP_PCMPGTD, "pcmpgtd", XREG, XREG, XREG)
+MINI_OP(OP_PCMPGTQ, "pcmpgtq", XREG, XREG, XREG)
 
 MINI_OP(OP_PSUM_ABS_DIFF, "psumabsdiff", XREG, XREG, XREG)
 
@@ -707,36 +698,36 @@ MINI_OP(OP_UNPACK_LOWW, "unpack_loww", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_LOWD, "unpack_lowd", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_LOWQ, "unpack_lowq", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_LOWPS, "unpack_lowps", XREG, XREG, XREG)
+MINI_OP(OP_UNPACK_LOWPD, "unpack_lowpd", XREG, XREG, XREG)
 
 MINI_OP(OP_UNPACK_HIGHB, "unpack_highb", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_HIGHW, "unpack_highw", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_HIGHD, "unpack_highd", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_HIGHQ, "unpack_highq", XREG, XREG, XREG)
 MINI_OP(OP_UNPACK_HIGHPS, "unpack_highps", XREG, XREG, XREG)
+MINI_OP(OP_UNPACK_HIGHPD, "unpack_highpd", XREG, XREG, XREG)
 
 MINI_OP(OP_PACKW, "packw", XREG, XREG, XREG)
 MINI_OP(OP_PACKD, "packd", XREG, XREG, XREG)
 
+MINI_OP(OP_PACKW_UN, "packw_un", XREG, XREG, XREG)
+MINI_OP(OP_PACKD_UN, "packd_un", XREG, XREG, XREG)
+
 MINI_OP(OP_PADDB_SAT, "paddb_sat", XREG, XREG, XREG)
 MINI_OP(OP_PADDB_SAT_UN, "paddb_sat_un", XREG, XREG, XREG)
 
 MINI_OP(OP_PADDW_SAT, "paddw_sat", XREG, XREG, XREG)
 MINI_OP(OP_PADDW_SAT_UN, "paddw_sat_un", XREG, XREG, XREG)
 
-MINI_OP(OP_PADDD_SAT, "paddd_sat", XREG, XREG, XREG)
-MINI_OP(OP_PADDD_SAT_UN, "paddd_sat_un", XREG, XREG, XREG)
-
 MINI_OP(OP_PSUBB_SAT, "psubb_sat", XREG, XREG, XREG)
 MINI_OP(OP_PSUBB_SAT_UN, "psubb_sat_un", XREG, XREG, XREG)
 
 MINI_OP(OP_PSUBW_SAT, "psubw_sat", XREG, XREG, XREG)
 MINI_OP(OP_PSUBW_SAT_UN, "psubw_sat_un", XREG, XREG, XREG)
 
-MINI_OP(OP_PSUBD_SAT, "psubd_sat", XREG, XREG, XREG)
-MINI_OP(OP_PSUBD_SAT_UN, "psubd_sat_un", XREG, XREG, XREG)
-
 MINI_OP(OP_PMULW, "pmulw", XREG, XREG, XREG)
 MINI_OP(OP_PMULD, "pmuld", XREG, XREG, XREG)
+MINI_OP(OP_PMULQ, "pmulq", XREG, XREG, XREG)
 
 MINI_OP(OP_PMULW_HIGH_UN, "pmul_high_un", XREG, XREG, XREG)
 MINI_OP(OP_PMULW_HIGH, "pmul_high", XREG, XREG, XREG)
@@ -754,27 +745,60 @@ MINI_OP(OP_PSHLW_REG, "pshlw_reg", XREG, XREG, XREG)
 MINI_OP(OP_PSHRD, "pshrd", XREG, XREG, NONE)
 MINI_OP(OP_PSHRD_REG, "pshrd_reg", XREG, XREG, XREG)
 
+MINI_OP(OP_PSHRQ, "pshrq", XREG, XREG, NONE)
+MINI_OP(OP_PSHRQ_REG, "pshrq_reg", XREG, XREG, XREG)
+
 MINI_OP(OP_PSARD, "psard", XREG, XREG, NONE)
 MINI_OP(OP_PSARD_REG, "psard_reg", XREG, XREG, XREG)
 
 MINI_OP(OP_PSHLD, "pshld", XREG, XREG, NONE)
 MINI_OP(OP_PSHLD_REG, "pshld_reg", XREG, XREG, XREG)
 
+MINI_OP(OP_PSHLQ, "pshlq", XREG, XREG, NONE)
+MINI_OP(OP_PSHLQ_REG, "pshlq_reg", XREG, XREG, XREG)
+
 MINI_OP(OP_EXTRACT_I4, "extract_i4", IREG, XREG, NONE)
 MINI_OP(OP_ICONV_TO_R8_RAW, "iconv_to_r8_raw", FREG, IREG, NONE)
-MINI_OP(OP_LOADX_R4, "loadx_r4", FREG, IREG, NONE)
 
-MINI_OP(OP_PUSH_R4, "push_r4", NONE, FREG, NONE)
-MINI_OP(OP_LOADX_STACK, "loadx_stack", XREG, NONE, NONE)
+MINI_OP(OP_EXTRACT_I2, "extract_i2", IREG, XREG, NONE)
+MINI_OP(OP_EXTRACT_U2, "extract_u2", IREG, XREG, NONE)
+MINI_OP(OP_EXTRACT_I1, "extract_i1", IREG, XREG, NONE)
+MINI_OP(OP_EXTRACT_U1, "extract_u1", IREG, XREG, NONE)
+MINI_OP(OP_EXTRACT_R8, "extract_r8", FREG, XREG, NONE)
+MINI_OP(OP_EXTRACT_I8, "extract_i8", LREG, XREG, NONE)
+
+MINI_OP(OP_INSERT_I2, "insert_i2", XREG, XREG, IREG)
+
+MINI_OP(OP_EXTRACTX_U2, "extractx_u2", IREG, XREG, NONE)
+
+/*these slow ops are modeled around the availability of a fast 2 bytes insert op*/
+/*insertx_u1_slow takes old value and new value as source regs */
+MINI_OP(OP_INSERTX_U1_SLOW, "insertx_u1_slow", XREG, IREG, IREG)
+/*insertx_i4_slow takes target xreg and new value as source regs */
+MINI_OP(OP_INSERTX_I4_SLOW, "insertx_i4_slow", XREG, XREG, IREG)
+
+MINI_OP(OP_INSERTX_R4_SLOW, "insertx_r4_slow", XREG, XREG, FREG)
+MINI_OP(OP_INSERTX_R8_SLOW, "insertx_r8_slow", XREG, XREG, FREG)
+MINI_OP(OP_INSERTX_I8_SLOW, "insertx_i8_slow", XREG, XREG, LREG)
 
 MINI_OP(OP_FCONV_TO_R8_X, "fconv_to_r8_x", XREG, FREG, NONE)
 MINI_OP(OP_XCONV_R8_TO_I4, "xconv_r8_to_i4", IREG, XREG, NONE)
 MINI_OP(OP_ICONV_TO_X, "iconv_to_x", XREG, IREG, NONE)
 
+MINI_OP(OP_EXPAND_I1, "expand_i1", XREG, IREG, NONE)
+MINI_OP(OP_EXPAND_I2, "expand_i2", XREG, IREG, NONE)
+MINI_OP(OP_EXPAND_I4, "expand_i4", XREG, IREG, NONE)
+MINI_OP(OP_EXPAND_R4, "expand_r4", XREG, FREG, NONE)
+MINI_OP(OP_EXPAND_I8, "expand_i8", XREG, IREG, NONE)
+MINI_OP(OP_EXPAND_R8, "expand_r8", XREG, FREG, NONE)
+
+MINI_OP(OP_PREFETCH_MEMBASE, "prefetch_membase", NONE, IREG, NONE)
+
 #endif
 
 MINI_OP(OP_XMOVE,   "xmove", XREG, XREG, NONE)
 MINI_OP(OP_XZERO,   "xzero", XREG, NONE, NONE)
+MINI_OP(OP_XPHI,       "xphi", XREG, NONE, NONE)
 
 /* Atomic specific
 
@@ -800,10 +824,8 @@ MINI_OP(OP_ATOMIC_ADD_IMM_NEW_I8, "atomic_add_imm_new_i8", IREG, IREG, NONE)
 MINI_OP(OP_ATOMIC_EXCHANGE_I8, "atomic_exchange_i8", IREG, IREG, IREG)
 MINI_OP(OP_MEMORY_BARRIER, "memory_barrier", NONE, NONE, NONE)
 
-/* CompareExchange where the value to store is a constant */
-/* backend->data holds the constant value */
-MINI_OP(OP_ATOMIC_CAS_IMM_I4, "atomic_cas_imm_i4", IREG, IREG, IREG)
-MINI_OP(OP_ATOMIC_CAS_IMM_I8, "atomic_cas_imm_i8", IREG, IREG, IREG)
+MINI_OP3(OP_ATOMIC_CAS_I4, "atomic_cas_i4", IREG, IREG, IREG, IREG)
+MINI_OP3(OP_ATOMIC_CAS_I8, "atomic_cas_i8", IREG, IREG, IREG, IREG)
 
 /* Conditional move opcodes.
  * Must be in the same order as the matching CEE_B... opcodes
@@ -836,17 +858,56 @@ MINI_OP(OP_CMOV_LGT_UN, "cmov_lgt_un", IREG, IREG, IREG)
 MINI_OP(OP_CMOV_LLE_UN, "cmov_lle_un", IREG, IREG, IREG)
 MINI_OP(OP_CMOV_LLT_UN, "cmov_llt_un", IREG, IREG, IREG)
 
+/* Debugging support */
+/* 
+ * Marks the start of the live range of the variable in inst_c0, that is the
+ * first instruction where the variable has a value.
+ */
+MINI_OP(OP_LIVERANGE_START, "liverange_start", NONE, NONE, NONE)
+/* 
+ * Marks the end of the live range of the variable in inst_c0, that is the
+ * first instruction where the variable no longer has a value.
+ */
+MINI_OP(OP_LIVERANGE_END, "liverange_end", NONE, NONE, NONE)
+
+/* GC support */
+/*
+ * mono_arch_output_basic_block () will set the backend.pc_offset field to the current pc
+ * offset.
+ */
+MINI_OP(OP_GC_LIVENESS_DEF, "gc_liveness_def", NONE, NONE, NONE)
+MINI_OP(OP_GC_LIVENESS_USE, "gc_liveness_use", NONE, NONE, NONE)
+
+/*
+ * This marks the location inside a basic block where a GC tracked spill slot has been
+ * defined. The spill slot is assumed to be alive until the end of the bblock.
+ */
+MINI_OP(OP_GC_SPILL_SLOT_LIVENESS_DEF, "gc_spill_slot_liveness_def", NONE, NONE, NONE)
+
+/*
+ * This marks the location inside a basic block where a GC tracked param area slot has
+ * been defined. The slot is assumed to be alive until the next call.
+ */
+MINI_OP(OP_GC_PARAM_SLOT_LIVENESS_DEF, "gc_param_slot_liveness_def", NONE, NONE, NONE)
+
 /* Arch specific opcodes */
-#if defined(__i386__) || defined(__x86_64__)
-MINI_OP(OP_X86_TEST_NULL,          "x86_test_null", NONE, NONE, NONE)
+/* #if defined(__native_client_codegen__) || defined(__native_client__) */
+/* We have to define these in terms of the TARGET defines, not NaCl defines */
+/* because genmdesc.pl doesn't have multiple defines per platform.          */
+#if defined(TARGET_AMD64) || defined(TARGET_X86)
+MINI_OP(OP_NACL_GC_SAFE_POINT,     "nacl_gc_safe_point", IREG, NONE, NONE)
+#endif
+
+#if defined(TARGET_X86) || defined(TARGET_AMD64)
+MINI_OP(OP_X86_TEST_NULL,          "x86_test_null", NONE, IREG, NONE)
 MINI_OP(OP_X86_COMPARE_MEMBASE_REG,"x86_compare_membase_reg", NONE, IREG, IREG)
 MINI_OP(OP_X86_COMPARE_MEMBASE_IMM,"x86_compare_membase_imm", NONE, IREG, NONE)
 MINI_OP(OP_X86_COMPARE_MEM_IMM,    "x86_compare_mem_imm", NONE, NONE, NONE)
 MINI_OP(OP_X86_COMPARE_MEMBASE8_IMM,"x86_compare_membase8_imm", NONE, IREG, NONE)
 MINI_OP(OP_X86_COMPARE_REG_MEMBASE,"x86_compare_reg_membase", NONE, IREG, IREG)
-MINI_OP(OP_X86_INC_REG,            "x86_inc_reg", NONE, NONE, NONE)
+MINI_OP(OP_X86_INC_REG,            "x86_inc_reg", IREG, IREG, NONE)
 MINI_OP(OP_X86_INC_MEMBASE,        "x86_inc_membase", NONE, IREG, NONE)
-MINI_OP(OP_X86_DEC_REG,            "x86_dec_reg", NONE, NONE, NONE)
+MINI_OP(OP_X86_DEC_REG,            "x86_dec_reg", IREG, IREG, NONE)
 MINI_OP(OP_X86_DEC_MEMBASE,        "x86_dec_membase", NONE, IREG, NONE)
 MINI_OP(OP_X86_ADD_MEMBASE_IMM,    "x86_add_membase_imm", NONE, IREG, NONE)
 MINI_OP(OP_X86_SUB_MEMBASE_IMM,    "x86_sub_membase_imm", NONE, IREG, NONE)
@@ -860,9 +921,9 @@ MINI_OP(OP_X86_OR_MEMBASE_REG,     "x86_or_membase_reg", NONE, IREG, IREG)
 MINI_OP(OP_X86_XOR_MEMBASE_REG,    "x86_xor_membase_reg", NONE, IREG, IREG)
 MINI_OP(OP_X86_MUL_MEMBASE_REG,    "x86_mul_membase_reg", NONE, IREG, IREG)
 
-MINI_OP(OP_X86_ADD_REG_MEMBASE,    "x86_add_reg_membase", NONE, IREG, IREG)
-MINI_OP(OP_X86_SUB_REG_MEMBASE,    "x86_sub_reg_membase", NONE, IREG, IREG)
-MINI_OP(OP_X86_MUL_REG_MEMBASE,    "x86_mul_reg_membase", NONE, IREG, IREG)
+MINI_OP(OP_X86_ADD_REG_MEMBASE,    "x86_add_reg_membase", IREG, IREG, IREG)
+MINI_OP(OP_X86_SUB_REG_MEMBASE,    "x86_sub_reg_membase", IREG, IREG, IREG)
+MINI_OP(OP_X86_MUL_REG_MEMBASE,    "x86_mul_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_X86_AND_REG_MEMBASE,    "x86_and_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_X86_OR_REG_MEMBASE,     "x86_or_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_X86_XOR_REG_MEMBASE,    "x86_xor_reg_membase", IREG, IREG, IREG)
@@ -870,28 +931,23 @@ MINI_OP(OP_X86_XOR_REG_MEMBASE,    "x86_xor_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_X86_PUSH_MEMBASE,       "x86_push_membase", NONE, IREG, NONE)
 MINI_OP(OP_X86_PUSH_IMM,           "x86_push_imm", NONE, NONE, NONE)
 MINI_OP(OP_X86_PUSH,               "x86_push", NONE, IREG, NONE)
-MINI_OP(OP_X86_PUSH_FP,            "x86_push_fp", NONE, NONE, NONE)
 MINI_OP(OP_X86_PUSH_OBJ,           "x86_push_obj", NONE, IREG, NONE)
 MINI_OP(OP_X86_PUSH_GOT_ENTRY,     "x86_push_got_entry", NONE, IREG, NONE)
 MINI_OP(OP_X86_LEA,                "x86_lea", IREG, IREG, IREG)
 MINI_OP(OP_X86_LEA_MEMBASE,        "x86_lea_membase", IREG, IREG, NONE)
-MINI_OP(OP_X86_XCHG,               "x86_xchg", NONE, NONE, NONE)
+MINI_OP(OP_X86_XCHG,               "x86_xchg", NONE, IREG, IREG)
 MINI_OP(OP_X86_FPOP,               "x86_fpop", NONE, FREG, NONE)
-MINI_OP(OP_X86_FP_LOAD_I8,         "x86_fp_load_i8", NONE, NONE, NONE)
-MINI_OP(OP_X86_FP_LOAD_I4,         "x86_fp_load_i4", NONE, NONE, NONE)
+MINI_OP(OP_X86_FP_LOAD_I8,         "x86_fp_load_i8", FREG, IREG, NONE)
+MINI_OP(OP_X86_FP_LOAD_I4,         "x86_fp_load_i4", FREG, IREG, NONE)
 MINI_OP(OP_X86_SETEQ_MEMBASE,      "x86_seteq_membase", NONE, IREG, NONE)
 MINI_OP(OP_X86_SETNE_MEMBASE,      "x86_setne_membase", NONE, IREG, NONE)
-MINI_OP(OP_X86_SHRD,               "x86_shrd", IREG, IREG, IREG)
 MINI_OP(OP_X86_FXCH,               "x86_fxch", NONE, NONE, NONE)
-MINI_OP(OP_X86_OUTARG_ALIGN_STACK, "x86_outarg_align_stack", NONE, NONE, NONE)
 #endif
 
-#if defined(__x86_64__)
-MINI_OP(OP_AMD64_TEST_NULL,              "amd64_test_null", NONE, NONE, NONE)
+#if defined(TARGET_AMD64)
+MINI_OP(OP_AMD64_TEST_NULL,              "amd64_test_null", NONE, IREG, NONE)
 MINI_OP(OP_AMD64_SET_XMMREG_R4,          "amd64_set_xmmreg_r4", FREG, FREG, NONE)
 MINI_OP(OP_AMD64_SET_XMMREG_R8,          "amd64_set_xmmreg_r8", FREG, FREG, NONE)
-MINI_OP(OP_AMD64_OUTARG_XMMREG_R4,       "amd64_outarg_xmmreg_r4", NONE, NONE, NONE)
-MINI_OP(OP_AMD64_OUTARG_XMMREG_R8,       "amd64_outarg_xmmreg_r8", NONE, NONE, NONE)
 MINI_OP(OP_AMD64_ICOMPARE_MEMBASE_REG,   "amd64_icompare_membase_reg", NONE, IREG, IREG)
 MINI_OP(OP_AMD64_ICOMPARE_MEMBASE_IMM,   "amd64_icompare_membase_imm", NONE, IREG, NONE)
 MINI_OP(OP_AMD64_ICOMPARE_REG_MEMBASE,   "amd64_icompare_reg_membase", NONE, IREG, IREG)
@@ -913,39 +969,29 @@ MINI_OP(OP_AMD64_OR_MEMBASE_IMM,         "amd64_or_membase_imm", NONE, IREG, NON
 MINI_OP(OP_AMD64_XOR_MEMBASE_IMM,        "amd64_xor_membase_imm", NONE, IREG, NONE)
 MINI_OP(OP_AMD64_MUL_MEMBASE_IMM,        "amd64_mul_membase_imm", NONE, IREG, NONE)
 
-MINI_OP(OP_AMD64_ADD_REG_MEMBASE,        "amd64_add_reg_membase", NONE, IREG, IREG)
-MINI_OP(OP_AMD64_SUB_REG_MEMBASE,        "amd64_sub_reg_membase", NONE, IREG, IREG)
+MINI_OP(OP_AMD64_ADD_REG_MEMBASE,        "amd64_add_reg_membase", IREG, IREG, IREG)
+MINI_OP(OP_AMD64_SUB_REG_MEMBASE,        "amd64_sub_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_AMD64_AND_REG_MEMBASE,        "amd64_and_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_AMD64_OR_REG_MEMBASE,         "amd64_or_reg_membase", IREG, IREG, IREG)
 MINI_OP(OP_AMD64_XOR_REG_MEMBASE,        "amd64_xor_reg_membase", IREG, IREG, IREG)
-MINI_OP(OP_AMD64_MUL_REG_MEMBASE,        "amd64_mul_reg_membase", NONE, IREG, IREG)
+MINI_OP(OP_AMD64_MUL_REG_MEMBASE,        "amd64_mul_reg_membase", IREG, IREG, IREG)
 
-MINI_OP(OP_AMD64_OUTARG_ALIGN_STACK,     "amd64_outarg_align_stack", NONE, NONE, NONE)
-MINI_OP(OP_AMD64_LOADI8_MEMINDEX,        "amd64_loadi8_memindex", NONE, NONE, NONE)
+MINI_OP(OP_AMD64_LOADI8_MEMINDEX,        "amd64_loadi8_memindex", IREG, IREG, IREG)
 MINI_OP(OP_AMD64_SAVE_SP_TO_LMF,         "amd64_save_sp_to_lmf", NONE, NONE, NONE)
 #endif
 
-#if  defined(__ppc__) || defined(__powerpc__) || defined(__ppc64__)
+#if  defined(__ppc__) || defined(__powerpc__) || defined(__ppc64__) || defined(TARGET_POWERPC)
 MINI_OP(OP_PPC_SUBFIC,             "ppc_subfic", IREG, IREG, NONE)
 MINI_OP(OP_PPC_SUBFZE,             "ppc_subfze", IREG, IREG, NONE)
 MINI_OP(OP_CHECK_FINITE,           "ppc_check_finite", NONE, IREG, NONE)
 #endif
 
-#if defined(__arm__)
+#if defined(TARGET_ARM)
 MINI_OP(OP_ARM_RSBS_IMM,            "arm_rsbs_imm", IREG, IREG, NONE)
 MINI_OP(OP_ARM_RSC_IMM,             "arm_rsc_imm", IREG, IREG, NONE)
 #endif
 
 #if defined(__sparc__) || defined(sparc)
-MINI_OP(OP_SPARC_OUTARG_REGPAIR,   "sparc_outarg_regpair", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_MEM,       "sparc_outarg_mem", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_MEMPAIR,   "sparc_outarg_mempair", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_SPLIT_REG_STACK, "sparc_outarg_split_reg_stack", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_FLOAT_REG, "sparc_outarg_float_reg", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_DOUBLE_REG, "sparc_outarg_double_reg", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_FLOAT,      "sparc_outarg_float", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_OUTARG_REGPAIR_FLOAT, "sparc_outarg_float", NONE, NONE, NONE)
-MINI_OP(OP_SPARC_SETFREG_FLOAT,   "sparc_setfreg_float", NONE, NONE, NONE)
 MINI_OP(OP_SPARC_BRZ,              "sparc_brz", NONE, NONE, NONE)
 MINI_OP(OP_SPARC_BRLEZ,            "sparc_brlez", NONE, NONE, NONE)
 MINI_OP(OP_SPARC_BRLZ,             "sparc_brlz", NONE, NONE, NONE)
@@ -1005,79 +1051,78 @@ MINI_OP(OP_IA64_STOREU8,        "ia64_storeu8", NONE, NONE, NONE)
 MINI_OP(OP_IA64_STORER4,        "ia64_storer4", NONE, NONE, NONE)
 MINI_OP(OP_IA64_STORER8,        "ia64_storer8", NONE, NONE, NONE)
 
-MINI_OP(OP_IA64_CMP4_EQ,        "ia64_cmp4_eq", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_NE,        "ia64_cmp4_ne", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LE,        "ia64_cmp4_le", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LT,        "ia64_cmp4_lt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GE,        "ia64_cmp4_ge", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GT,        "ia64_cmp4_gt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LE_UN,     "ia64_cmp4_le_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LT_UN,     "ia64_cmp4_lt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GE_UN,     "ia64_cmp4_ge_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GT_UN,     "ia64_cmp4_gt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_EQ,         "ia64_cmp_eq", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_NE,         "ia64_cmp_ne", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LE,         "ia64_cmp_le", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LT,         "ia64_cmp_lt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GE,         "ia64_cmp_ge", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GT,         "ia64_cmp_gt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LT_UN,      "ia64_cmp_lt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GT_UN,      "ia64_cmp_gt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GE_UN,      "ia64_cmp_ge_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LE_UN,      "ia64_cmp_le_un", NONE, NONE, NONE)
-
-MINI_OP(OP_IA64_CMP4_EQ_IMM,        "ia64_cmp4_eq_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_NE_IMM,        "ia64_cmp4_ne_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LE_IMM,        "ia64_cmp4_le_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LT_IMM,        "ia64_cmp4_lt_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GE_IMM,        "ia64_cmp4_ge_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GT_IMM,        "ia64_cmp4_gt_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LE_UN_IMM,     "ia64_cmp4_le_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_LT_UN_IMM,     "ia64_cmp4_lt_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GE_UN_IMM,     "ia64_cmp4_ge_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP4_GT_UN_IMM,     "ia64_cmp4_gt_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_EQ_IMM,         "ia64_cmp_eq_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_NE_IMM,         "ia64_cmp_ne_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LE_IMM,         "ia64_cmp_le_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LT_IMM,         "ia64_cmp_lt_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GE_IMM,         "ia64_cmp_ge_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GT_IMM,         "ia64_cmp_gt_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LT_UN_IMM,      "ia64_cmp_lt_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GT_UN_IMM,      "ia64_cmp_gt_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_GE_UN_IMM,      "ia64_cmp_ge_un_imm", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CMP_LE_UN_IMM,      "ia64_cmp_le_un_imm", NONE, NONE, NONE)
-
-MINI_OP(OP_IA64_FCMP_EQ,         "ia64_fcmp_eq", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_NE,         "ia64_fcmp_ne", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_LE,         "ia64_fcmp_le", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_LT,         "ia64_fcmp_lt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_GE,         "ia64_fcmp_ge", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_GT,         "ia64_fcmp_gt", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_LT_UN,      "ia64_fcmp_lt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_GT_UN,      "ia64_fcmp_gt_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_GE_UN,      "ia64_fcmp_ge_un", NONE, NONE, NONE)
-MINI_OP(OP_IA64_FCMP_LE_UN,      "ia64_fcmp_le_un", NONE, NONE, NONE)
+MINI_OP(OP_IA64_CMP4_EQ,        "ia64_cmp4_eq", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_NE,        "ia64_cmp4_ne", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_LE,        "ia64_cmp4_le", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_LT,        "ia64_cmp4_lt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_GE,        "ia64_cmp4_ge", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_GT,        "ia64_cmp4_gt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_LE_UN,     "ia64_cmp4_le_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_LT_UN,     "ia64_cmp4_lt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_GE_UN,     "ia64_cmp4_ge_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP4_GT_UN,     "ia64_cmp4_gt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_EQ,         "ia64_cmp_eq", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_NE,         "ia64_cmp_ne", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_LE,         "ia64_cmp_le", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_LT,         "ia64_cmp_lt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_GE,         "ia64_cmp_ge", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_GT,         "ia64_cmp_gt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_LT_UN,      "ia64_cmp_lt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_GT_UN,      "ia64_cmp_gt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_GE_UN,      "ia64_cmp_ge_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_CMP_LE_UN,      "ia64_cmp_le_un", NONE, IREG, IREG)
+
+MINI_OP(OP_IA64_CMP4_EQ_IMM,        "ia64_cmp4_eq_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_NE_IMM,        "ia64_cmp4_ne_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_LE_IMM,        "ia64_cmp4_le_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_LT_IMM,        "ia64_cmp4_lt_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_GE_IMM,        "ia64_cmp4_ge_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_GT_IMM,        "ia64_cmp4_gt_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_LE_UN_IMM,     "ia64_cmp4_le_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_LT_UN_IMM,     "ia64_cmp4_lt_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_GE_UN_IMM,     "ia64_cmp4_ge_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP4_GT_UN_IMM,     "ia64_cmp4_gt_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_EQ_IMM,         "ia64_cmp_eq_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_NE_IMM,         "ia64_cmp_ne_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_LE_IMM,         "ia64_cmp_le_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_LT_IMM,         "ia64_cmp_lt_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_GE_IMM,         "ia64_cmp_ge_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_GT_IMM,         "ia64_cmp_gt_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_LT_UN_IMM,      "ia64_cmp_lt_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_GT_UN_IMM,      "ia64_cmp_gt_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_GE_UN_IMM,      "ia64_cmp_ge_un_imm", NONE, NONE, IREG)
+MINI_OP(OP_IA64_CMP_LE_UN_IMM,      "ia64_cmp_le_un_imm", NONE, NONE, IREG)
+
+MINI_OP(OP_IA64_FCMP_EQ,         "ia64_fcmp_eq", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_NE,         "ia64_fcmp_ne", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_LE,         "ia64_fcmp_le", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_LT,         "ia64_fcmp_lt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_GE,         "ia64_fcmp_ge", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_GT,         "ia64_fcmp_gt", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_LT_UN,      "ia64_fcmp_lt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_GT_UN,      "ia64_fcmp_gt_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_GE_UN,      "ia64_fcmp_ge_un", NONE, IREG, IREG)
+MINI_OP(OP_IA64_FCMP_LE_UN,      "ia64_fcmp_le_un", NONE, IREG, IREG)
 
 MINI_OP(OP_IA64_BR_COND,        "ia64_br_cond", NONE, NONE, NONE)
 MINI_OP(OP_IA64_COND_EXC,       "ia64_cond_exc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_CSET,           "ia64_cset", NONE, NONE, NONE)
-
-MINI_OP(OP_IA64_OUTARG_R4,      "ia64_outarg_r4", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STOREI1_MEMBASE_INC_REG, "ia64_storei1_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STOREI2_MEMBASE_INC_REG, "ia64_storei2_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STOREI4_MEMBASE_INC_REG, "ia64_storei4_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STOREI8_MEMBASE_INC_REG, "ia64_storei8_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STORER4_MEMBASE_INC_REG, "ia64_storer4_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_STORER8_MEMBASE_INC_REG, "ia64_storer8_membase_inc_reg", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADI1_MEMBASE_INC,"ia64_loadi1_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADU1_MEMBASE_INC,"ia64_loadu1_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADI2_MEMBASE_INC,"ia64_loadi2_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADU2_MEMBASE_INC,"ia64_loadu2_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADI4_MEMBASE_INC,"ia64_loadi4_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADU4_MEMBASE_INC,"ia64_loadu4_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADI8_MEMBASE_INC,"ia64_loadi8_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADR4_MEMBASE_INC,"ia64_loadr4_membase_inc", NONE, NONE, NONE)
-MINI_OP(OP_IA64_LOADR8_MEMBASE_INC,"ia64_loadr8_membase_inc", NONE, NONE, NONE)
+MINI_OP(OP_IA64_CSET,           "ia64_cset", IREG, NONE, NONE)
+
+MINI_OP(OP_IA64_STOREI1_MEMBASE_INC_REG, "ia64_storei1_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_STOREI2_MEMBASE_INC_REG, "ia64_storei2_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_STOREI4_MEMBASE_INC_REG, "ia64_storei4_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_STOREI8_MEMBASE_INC_REG, "ia64_storei8_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_STORER4_MEMBASE_INC_REG, "ia64_storer4_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_STORER8_MEMBASE_INC_REG, "ia64_storer8_membase_inc_reg", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADI1_MEMBASE_INC,"ia64_loadi1_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADU1_MEMBASE_INC,"ia64_loadu1_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADI2_MEMBASE_INC,"ia64_loadi2_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADU2_MEMBASE_INC,"ia64_loadu2_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADI4_MEMBASE_INC,"ia64_loadi4_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADU4_MEMBASE_INC,"ia64_loadu4_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADI8_MEMBASE_INC,"ia64_loadi8_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADR4_MEMBASE_INC,"ia64_loadr4_membase_inc", IREG, IREG, NONE)
+MINI_OP(OP_IA64_LOADR8_MEMBASE_INC,"ia64_loadr8_membase_inc", IREG, IREG, NONE)
 #endif
 
 #if defined(__alpha__)
@@ -1105,65 +1150,68 @@ MINI_OP(OP_ALPHA_TRAPB, "alpha_trapb")
 #endif
 
 #if defined(__mips__)
-MINI_OP(OP_LONG_SHRUN_32,   "long_shrun_32", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BEQ,   "mips_beq", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BGEZ,  "mips_bgez", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BGTZ,  "mips_bgtz", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BLEZ,  "mips_blez", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BLTZ,  "mips_bltz", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_BNE,   "mips_bne", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_CVTSD, "mips_cvtsd", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBEQ,  "mips_fbeq", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBGE,  "mips_fbge", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBGT,  "mips_fbgt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBLE,  "mips_fble", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBLT,  "mips_fblt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_FBNE,  "mips_fbne", NONE, NONE, NONE)
+MINI_OP(OP_MIPS_BEQ,   "mips_beq", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_BGEZ,  "mips_bgez", NONE, IREG, NONE)
+MINI_OP(OP_MIPS_BGTZ,  "mips_bgtz", NONE, IREG, NONE)
+MINI_OP(OP_MIPS_BLEZ,  "mips_blez", NONE, IREG, NONE)
+MINI_OP(OP_MIPS_BLTZ,  "mips_bltz", NONE, IREG, NONE)
+MINI_OP(OP_MIPS_BNE,   "mips_bne", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_CVTSD, "mips_cvtsd", FREG, FREG, NONE)
+MINI_OP(OP_MIPS_FBEQ,  "mips_fbeq", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBGE,  "mips_fbge", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBGE_UN,  "mips_fbge_un", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBGT,  "mips_fbgt", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBGT_UN,  "mips_fbgt_un", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBLE,  "mips_fble", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBLE_UN,  "mips_fble_un", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBLT,  "mips_fblt", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBLT_UN,  "mips_fblt_un", NONE, FREG, FREG)
+MINI_OP(OP_MIPS_FBNE,  "mips_fbne", NONE, FREG, FREG)
 MINI_OP(OP_MIPS_FBFALSE, "mips_fbfalse", NONE, NONE, NONE)
 MINI_OP(OP_MIPS_FBTRUE, "mips_fbtrue", NONE, NONE, NONE)
 MINI_OP(OP_MIPS_LWC1,  "mips_lwc1", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_MTC1S, "mips_mtc1_s", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_MFC1S, "mips_mfc1_s", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_MTC1D, "mips_mtc1_d", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_MFC1D, "mips_mfc1_d", NONE, NONE, NONE)
+MINI_OP(OP_MIPS_MTC1S, "mips_mtc1_s", FREG, IREG, NONE)
+MINI_OP(OP_MIPS_MTC1S_2, "mips_mtc1_s2", FREG, IREG, IREG)
+MINI_OP(OP_MIPS_MFC1S, "mips_mfc1_s", IREG, FREG, NONE)
+MINI_OP(OP_MIPS_MTC1D, "mips_mtc1_d", FREG, IREG, NONE)
+MINI_OP(OP_MIPS_MFC1D, "mips_mfc1_d", IREG, FREG, NONE)
 MINI_OP(OP_MIPS_NOP,   "mips_nop", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_SLTI,  "mips_slti", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_SLT,   "mips_slt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_SLTIU, "mips_sltiu", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_SLTU,  "mips_sltu", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_XORI,  "mips_xori", NONE, NONE, NONE)
-
-MINI_OP(OP_MIPS_COND_EXC_EQ, "mips_cond_exc_eq", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_GE, "mips_cond_exc_ge", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_GT, "mips_cond_exc_gt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_LE, "mips_cond_exc_le", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_LT, "mips_cond_exc_lt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_NE_UN, "mips_cond_exc_ne_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_GE_UN, "mips_cond_exc_ge_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_GT_UN, "mips_cond_exc_gt_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_LE_UN, "mips_cond_exc_le_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_LT_UN, "mips_cond_exc_lt_un", NONE, NONE, NONE)
-
-MINI_OP(OP_MIPS_COND_EXC_OV, "mips_cond_exc_ov", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_NO, "mips_cond_exc_no", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_C, "mips_cond_exc_c", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_NC, "mips_cond_exc_nc", NONE, NONE, NONE)
-
-MINI_OP(OP_MIPS_COND_EXC_IEQ, "mips_cond_exc_ieq", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_IGE, "mips_cond_exc_ige", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_IGT, "mips_cond_exc_igt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_ILE, "mips_cond_exc_ile", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_ILT, "mips_cond_exc_ilt", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_INE_UN, "mips_cond_exc_ine_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_IGE_UN, "mips_cond_exc_ige_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_IGT_UN, "mips_cond_exc_igt_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_ILE_UN, "mips_cond_exc_ile_un", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_ILT_UN, "mips_cond_exc_ilt_un", NONE, NONE, NONE)
-
-MINI_OP(OP_MIPS_COND_EXC_IOV, "mips_cond_exc_iov", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_INO, "mips_cond_exc_ino", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_IC, "mips_cond_exc_ic", NONE, NONE, NONE)
-MINI_OP(OP_MIPS_COND_EXC_INC, "mips_cond_exc_inc", NONE, NONE, NONE)
+MINI_OP(OP_MIPS_SLTI,  "mips_slti", IREG, IREG, NONE)
+MINI_OP(OP_MIPS_SLT,   "mips_slt", IREG, IREG, IREG)
+MINI_OP(OP_MIPS_SLTIU, "mips_sltiu", IREG, IREG, NONE)
+MINI_OP(OP_MIPS_SLTU,  "mips_sltu", IREG, IREG, IREG)
+
+MINI_OP(OP_MIPS_COND_EXC_EQ, "mips_cond_exc_eq", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_GE, "mips_cond_exc_ge", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_GT, "mips_cond_exc_gt", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_LE, "mips_cond_exc_le", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_LT, "mips_cond_exc_lt", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_NE_UN, "mips_cond_exc_ne_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_GE_UN, "mips_cond_exc_ge_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_GT_UN, "mips_cond_exc_gt_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_LE_UN, "mips_cond_exc_le_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_LT_UN, "mips_cond_exc_lt_un", NONE, IREG, IREG)
+
+MINI_OP(OP_MIPS_COND_EXC_OV, "mips_cond_exc_ov", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_NO, "mips_cond_exc_no", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_C, "mips_cond_exc_c", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_NC, "mips_cond_exc_nc", NONE, IREG, IREG)
+
+MINI_OP(OP_MIPS_COND_EXC_IEQ, "mips_cond_exc_ieq", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_IGE, "mips_cond_exc_ige", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_IGT, "mips_cond_exc_igt", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_ILE, "mips_cond_exc_ile", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_ILT, "mips_cond_exc_ilt", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_INE_UN, "mips_cond_exc_ine_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_IGE_UN, "mips_cond_exc_ige_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_IGT_UN, "mips_cond_exc_igt_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_ILE_UN, "mips_cond_exc_ile_un", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_ILT_UN, "mips_cond_exc_ilt_un", NONE, IREG, IREG)
+
+MINI_OP(OP_MIPS_COND_EXC_IOV, "mips_cond_exc_iov", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_INO, "mips_cond_exc_ino", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_IC, "mips_cond_exc_ic", NONE, IREG, IREG)
+MINI_OP(OP_MIPS_COND_EXC_INC, "mips_cond_exc_inc", NONE, IREG, IREG)
 
 #endif
 
@@ -1222,3 +1270,8 @@ MINI_OP(OP_HPPA_STORER4_RIGHT, "hppa_storer4_right", NONE, NONE, NONE)
 
 MINI_OP(OP_HPPA_SETF4REG, "hppa_setf4reg", NONE, NONE, NONE)
 #endif
+
+/* Same as OUTARG_VT, but has a dreg */
+#ifdef ENABLE_LLVM
+MINI_OP(OP_LLVM_OUTARG_VT,     "llvm_outarg_vt", IREG, VREG, NONE)
+#endif