X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mono%2Fmini%2Fir-emit.h;h=8f7b81b30a217b43f87cf259b4fd02b59454e039;hb=9665e4dd6e2ea0afbb2a5d6df46b14bb6b81bdea;hp=391eefdc0d3233fd631f89fc2eb9187302c066e0;hpb=2d77b394441eef38c300c1ef0d997669a4d17dad;p=mono.git diff --git a/mono/mini/ir-emit.h b/mono/mini/ir-emit.h index 391eefdc0d3..8f7b81b30a2 100644 --- a/mono/mini/ir-emit.h +++ b/mono/mini/ir-emit.h @@ -86,6 +86,7 @@ alloc_dreg (MonoCompile *cfg, MonoStackType stack_type) return alloc_ireg_mp (cfg); case STACK_OBJ: return alloc_ireg_ref (cfg); + case STACK_R4: case STACK_R8: return alloc_freg (cfg); case STACK_I8: @@ -105,7 +106,7 @@ alloc_dreg (MonoCompile *cfg, MonoStackType stack_type) * JIT code still uses the left and right fields, so it has to stay. */ #define MONO_INST_NEW(cfg,dest,op) do { \ - (dest) = mono_mempool_alloc ((cfg)->mempool, sizeof (MonoInst)); \ + (dest) = (MonoInst *)mono_mempool_alloc ((cfg)->mempool, sizeof (MonoInst)); \ (dest)->inst_c0 = (dest)->inst_c1 = 0; \ (dest)->next = (dest)->prev = NULL; \ (dest)->opcode = (op); \ @@ -229,7 +230,7 @@ alloc_dreg (MonoCompile *cfg, MonoStackType stack_type) #define NEW_AOTCONST(cfg,dest,patch_type,cons) do { \ MONO_INST_NEW ((cfg), (dest), cfg->compile_aot ? OP_AOTCONST : OP_PCONST); \ (dest)->inst_p0 = (cons); \ - (dest)->inst_i1 = (gpointer)(patch_type); \ + (dest)->inst_i1 = (MonoInst *)(patch_type); \ (dest)->type = STACK_PTR; \ (dest)->dreg = alloc_dreg ((cfg), STACK_PTR); \ } while (0) @@ -259,6 +260,8 @@ alloc_dreg (MonoCompile *cfg, MonoStackType stack_type) #define NEW_LDSTRCONST(cfg,dest,image,token) NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_LDSTR, (image), (token), NULL, STACK_OBJ, mono_defaults.string_class) +#define NEW_LDSTRLITCONST(cfg,dest,val) NEW_AOTCONST ((cfg), (dest), MONO_PATCH_INFO_LDSTR_LIT, (val)) + #define NEW_TYPE_FROM_HANDLE_CONST(cfg,dest,image,token,generic_context) NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_TYPE_FROM_HANDLE, (image), (token), (generic_context), STACK_OBJ, mono_defaults.monotype_class) #define NEW_LDTOKENCONST(cfg,dest,image,token,generic_context) NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_LDTOKEN, (image), (token), (generic_context), STACK_PTR, NULL) @@ -302,15 +305,13 @@ alloc_dreg (MonoCompile *cfg, MonoStackType stack_type) #define NEW_JIT_ICALL_ADDRCONST(cfg,dest,name) NEW_AOTCONST ((cfg), (dest), MONO_PATCH_INFO_JIT_ICALL_ADDR, (name)) -#define GET_VARINFO_INST(cfg,num) ((cfg)->varinfo [(num)]->inst) - #define NEW_VARLOAD(cfg,dest,var,vartype) do { \ MONO_INST_NEW ((cfg), (dest), OP_MOVE); \ (dest)->opcode = mono_type_to_regmove ((cfg), (vartype)); \ type_to_eval_stack_type ((cfg), (vartype), (dest)); \ (dest)->klass = var->klass; \ (dest)->sreg1 = var->dreg; \ - (dest)->dreg = alloc_dreg ((cfg), (dest)->type); \ + (dest)->dreg = alloc_dreg ((cfg), (MonoStackType)(dest)->type); \ if ((dest)->opcode == OP_VMOVE) (dest)->klass = mono_class_from_mono_type ((vartype)); \ } while (0) @@ -338,8 +339,8 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) (dest)->klass = (var)->klass; \ (dest)->dreg = alloc_dreg ((cfg), STACK_MP); \ (cfg)->has_indirection = TRUE; \ - if (G_UNLIKELY (cfg->gsharedvt) && mini_is_gsharedvt_variable_type ((cfg), (var)->inst_vtype)) { handle_gsharedvt_ldaddr ((cfg)); } \ - if (SIZEOF_REGISTER == 4 && DECOMPOSE_INTO_REGPAIR ((var)->type)) { MonoInst *var1 = get_vreg_to_inst (cfg, (var)->dreg + 1); MonoInst *var2 = get_vreg_to_inst (cfg, (var)->dreg + 2); g_assert (var1); g_assert (var2); var1->flags |= MONO_INST_INDIRECT; var2->flags |= MONO_INST_INDIRECT; } \ + if (G_UNLIKELY (cfg->gsharedvt) && mini_is_gsharedvt_variable_type ((var)->inst_vtype)) { handle_gsharedvt_ldaddr ((cfg)); } \ + if (SIZEOF_REGISTER == 4 && DECOMPOSE_INTO_REGPAIR ((var)->type)) { MonoInst *var1 = get_vreg_to_inst (cfg, MONO_LVREG_LS ((var)->dreg)); MonoInst *var2 = get_vreg_to_inst (cfg, MONO_LVREG_MS ((var)->dreg)); g_assert (var1); g_assert (var2); var1->flags |= MONO_INST_INDIRECT; var2->flags |= MONO_INST_INDIRECT; } \ } while (0) #define NEW_VARSTORE(cfg,dest,var,vartype,inst) do { \ @@ -372,7 +373,7 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) (dest)->type = STACK_MP; \ (dest)->klass = cfg->ret->klass; \ (dest)->sreg1 = cfg->vret_addr->dreg; \ - (dest)->dreg = alloc_dreg ((cfg), (dest)->type); \ + (dest)->dreg = alloc_dreg ((cfg), (MonoStackType)(dest)->type); \ } while (0) #define NEW_ARGLOADA(cfg,dest,num) NEW_VARLOADA ((cfg), (dest), arg_array [(num)], param_types [(num)]) @@ -394,7 +395,7 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) #define NEW_LOAD_MEMBASE_TYPE(cfg,dest,ltype,base,offset) do { \ NEW_LOAD_MEMBASE ((cfg), (dest), mono_type_to_load_membase ((cfg), (ltype)), 0, (base), (offset)); \ type_to_eval_stack_type ((cfg), (ltype), (dest)); \ - (dest)->dreg = alloc_dreg ((cfg), (dest)->type); \ + (dest)->dreg = alloc_dreg ((cfg), (MonoStackType)(dest)->type); \ } while (0) #define NEW_STORE_MEMBASE_TYPE(cfg,dest,ltype,base,offset,sr) do { \ @@ -407,7 +408,7 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) } while (0) #define NEW_SEQ_POINT(cfg,dest,il_offset,intr_loc) do { \ - MONO_INST_NEW ((cfg), (dest), OP_SEQ_POINT); \ + MONO_INST_NEW ((cfg), (dest), cfg->gen_sdb_seq_points ? OP_SEQ_POINT : OP_IL_SEQ_POINT); \ (dest)->inst_imm = (il_offset); \ (dest)->flags = intr_loc ? MONO_INST_SINGLE_STEP_LOC : 0; \ } while (0) @@ -445,6 +446,8 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) #define EMIT_NEW_LDSTRCONST(cfg,dest,image,token) do { NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_LDSTR, (image), (token), NULL, STACK_OBJ, mono_defaults.string_class); MONO_ADD_INS ((cfg)->cbb, (dest)); } while (0) +#define EMIT_NEW_LDSTRLITCONST(cfg,dest,val) do { NEW_AOTCONST ((cfg), (dest), MONO_PATCH_INFO_LDSTR_LIT, (val)); MONO_ADD_INS ((cfg)->cbb, (dest)); } while (0) + #define EMIT_NEW_TYPE_FROM_HANDLE_CONST(cfg,dest,image,token,generic_context) do { NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_TYPE_FROM_HANDLE, (image), (token), (generic_context), STACK_OBJ, mono_defaults.monotype_class); MONO_ADD_INS ((cfg)->cbb, (dest)); } while (0) #define EMIT_NEW_LDTOKENCONST(cfg,dest,image,token,generic_context) do { NEW_AOTCONST_TOKEN ((cfg), (dest), MONO_PATCH_INFO_LDTOKEN, (image), (token), (generic_context), STACK_PTR, NULL); MONO_ADD_INS ((cfg)->cbb, (dest)); } while (0) @@ -600,6 +603,13 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) MONO_ADD_INS ((cfg)->cbb, inst); \ } while (0) +#define MONO_EMIT_NEW_DUMMY_INIT(cfg,dr,op) do { \ + MonoInst *inst; \ + MONO_INST_NEW ((cfg), (inst), (op)); \ + inst->dreg = dr; \ + MONO_ADD_INS ((cfg)->cbb, inst); \ + } while (0) + #ifdef MONO_ARCH_NEED_GOT_VAR #define MONO_EMIT_NEW_AOTCONST(cfg,dr,cons,patch_type) do { \ @@ -733,7 +743,7 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) * block_num: unique ID assigned at bblock creation */ #define NEW_BBLOCK(cfg,bblock) do { \ - (bblock) = mono_mempool_alloc0 ((cfg)->mempool, sizeof (MonoBasicBlock)); \ + (bblock) = (MonoBasicBlock *)mono_mempool_alloc0 ((cfg)->mempool, sizeof (MonoBasicBlock)); \ (bblock)->block_num = cfg->num_bblocks++; \ } while (0) @@ -744,8 +754,8 @@ handle_gsharedvt_ldaddr (MonoCompile *cfg) (b)->real_offset = cfg->real_offset; \ } while (0) -/* Emit a one-way conditional branch */ -/* +/* + * Emit a one-way conditional branch and start a new bblock. * The inst_false_bb field of the cond branch will not be set, the JIT code should be * prepared to deal with this. */ @@ -786,7 +796,7 @@ static int ccount = 0; MONO_ADD_INS ((cfg)->cbb, ins); \ MONO_START_BB ((cfg), falsebb); \ } else { \ - ins->inst_many_bb = mono_mempool_alloc (cfg->mempool, sizeof(gpointer)*2); \ + ins->inst_many_bb = (MonoBasicBlock **)mono_mempool_alloc (cfg->mempool, sizeof(gpointer)*2); \ ins->inst_true_bb = (truebb); \ ins->inst_false_bb = NULL; \ mono_link_bblock ((cfg), (cfg)->cbb, (truebb)); \ @@ -807,7 +817,7 @@ static int ccount = 0; #define MONO_EMIT_NEW_BRANCH_BLOCK2(cfg,op,truebb,falsebb) do { \ MonoInst *ins; \ MONO_INST_NEW ((cfg), (ins), (op)); \ - ins->inst_many_bb = mono_mempool_alloc (cfg->mempool, sizeof(gpointer)*2); \ + ins->inst_many_bb = (MonoBasicBlock **)mono_mempool_alloc (cfg->mempool, sizeof(gpointer)*2); \ ins->inst_true_bb = (truebb); \ ins->inst_false_bb = (falsebb); \ mono_link_bblock ((cfg), (cfg)->cbb, (truebb)); \ @@ -926,15 +936,15 @@ static int ccount = 0; if (!(cfg->opt & MONO_OPT_ABCREM)) { \ MONO_EMIT_NULL_CHECK (cfg, array_reg); \ if (COMPILE_LLVM (cfg)) \ - MONO_EMIT_DEFAULT_BOUNDS_CHECK ((cfg), (array_reg), G_STRUCT_OFFSET (array_type, array_length_field), (index_reg), TRUE); \ + MONO_EMIT_DEFAULT_BOUNDS_CHECK ((cfg), (array_reg), MONO_STRUCT_OFFSET (array_type, array_length_field), (index_reg), TRUE); \ else \ - MONO_ARCH_EMIT_BOUNDS_CHECK ((cfg), (array_reg), G_STRUCT_OFFSET (array_type, array_length_field), (index_reg)); \ + MONO_ARCH_EMIT_BOUNDS_CHECK ((cfg), (array_reg), MONO_STRUCT_OFFSET (array_type, array_length_field), (index_reg)); \ } else { \ MonoInst *ins; \ MONO_INST_NEW ((cfg), ins, OP_BOUNDS_CHECK); \ ins->sreg1 = array_reg; \ ins->sreg2 = index_reg; \ - ins->inst_imm = G_STRUCT_OFFSET (array_type, array_length_field); \ + ins->inst_imm = MONO_STRUCT_OFFSET (array_type, array_length_field); \ ins->flags |= MONO_INST_FAULT; \ MONO_ADD_INS ((cfg)->cbb, ins); \ (cfg)->flags |= MONO_CFG_HAS_ARRAY_ACCESS; \