X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Ftr%2Ftype.c;h=26882919045c67244bc37b83bc41d01276dbbcae;hb=17a2631c82913b3d4f94bfcbc64b41dd74bcb842;hp=d0820ac58f375993f9d6597187c2f664d8c1a0cc;hpb=b9d11a19d0b84d6824633806283af13546ce495d;p=libfirm diff --git a/ir/tr/type.c b/ir/tr/type.c index d0820ac58..268829190 100644 --- a/ir/tr/type.c +++ b/ir/tr/type.c @@ -406,50 +406,50 @@ set_type_state(ir_type *tp, type_state state) { int i; switch (get_type_tpop_code(tp)) { case tpo_class: - { - assert(get_type_size_bits(tp) > -1); - if (tp != get_glob_type()) { - int n_mem = get_class_n_members(tp); - for (i = 0; i < n_mem; i++) { - if (get_entity_offset_bits(get_class_member(tp, i)) <= -1) - { DDMT(tp); DDME(get_class_member(tp, i)); } - assert(get_entity_offset_bits(get_class_member(tp, i)) > -1); - /* TR ?? - assert(is_Method_type(get_entity_type(get_class_member(tp, i))) || - (get_entity_allocation(get_class_member(tp, i)) == allocation_automatic)); - */ + assert(get_type_size_bits(tp) > -1); + if (tp != get_glob_type()) { + int n_mem = get_class_n_members(tp); + for (i = 0; i < n_mem; i++) { + if (get_entity_offset_bits(get_class_member(tp, i)) <= -1) + { DDMT(tp); DDME(get_class_member(tp, i)); } + assert(get_entity_offset_bits(get_class_member(tp, i)) > -1); + /* TR ?? + assert(is_Method_type(get_entity_type(get_class_member(tp, i))) || + (get_entity_allocation(get_class_member(tp, i)) == allocation_automatic)); + */ + } } - } - } break; + break; case tpo_struct: - { - assert(get_type_size_bits(tp) > -1); - for (i = 0; i < get_struct_n_members(tp); i++) { - assert(get_entity_offset_bits(get_struct_member(tp, i)) > -1); - assert((get_entity_allocation(get_struct_member(tp, i)) == allocation_automatic)); - } - } break; + assert(get_type_size_bits(tp) > -1); + for (i = 0; i < get_struct_n_members(tp); i++) { + assert(get_entity_offset_bits(get_struct_member(tp, i)) > -1); + assert((get_entity_allocation(get_struct_member(tp, i)) == allocation_automatic)); + } + break; case tpo_union: - { /* ?? */ - } break; + /* ?? */ + break; case tpo_array: - { /* ?? + /* ?? Check order? Assure that only innermost dimension is dynamic? */ - } break; + break; case tpo_enumeration: - { - assert(get_type_mode != NULL); - for (i = 0; i < get_enumeration_n_enums(tp); i++) - assert(get_enumeration_enum(tp, i) != NULL); - } break; + assert(get_type_mode != NULL); + for (i = get_enumeration_n_enums(tp) - 1; i >= 0; --i) { + ir_enum_const *ec = get_enumeration_const(tp, i); + tarval *tv = get_enumeration_value(ec); + assert(tv != NULL && tv != tarval_bad); + } + break; default: break; } /* switch (tp) */ } if (state == layout_fixed) tp->flags |= tf_layout_fixed; else - tp->flags &= tf_layout_fixed; + tp->flags &= ~tf_layout_fixed; } unsigned long (get_type_visited)(const ir_type *tp) { @@ -955,7 +955,7 @@ void set_class_type_info(ir_type *clss, entity *ent) { clss->attr.ca.type_info = ent; } -const char *get_peculiarity_string(peculiarity p) { +const char *get_peculiarity_name(peculiarity p) { #define X(a) case a: return #a switch (p) { X(peculiarity_description); @@ -1153,6 +1153,7 @@ static INLINE ir_type * build_value_type(ident *name, int len, tp_ent_pair *tps) { int i; ir_type *res = new_type_struct(name); + res->flags |= tf_value_param_type; /* Remove type from type list. Must be treated differently than other types. */ remove_irp_type(res); for (i = 0; i < len; i++) { @@ -1160,6 +1161,7 @@ build_value_type(ident *name, int len, tp_ent_pair *tps) { ir_type *elt_type = tps[i].tp ? tps[i].tp : res; tps[i].ent = new_entity(res, mangle_u(name, get_type_ident(elt_type)), elt_type); + set_entity_allocation(tps[i].ent, allocation_parameter); } return res; } @@ -1696,11 +1698,11 @@ void set_array_size_bits(ir_type *tp, int size) { /* create a new type enumeration -- set the enumerators independently */ ir_type *new_d_type_enumeration(ident *name, int n_enums, dbg_info *db) { - ir_type *res = new_type(type_enumeration, NULL, name, db); + ir_type *res; - res->attr.ea.n_enums = n_enums; - res->attr.ea.enumer = xcalloc(n_enums, sizeof(res->attr.ea.enumer[0])); - res->attr.ea.enum_nameid = xcalloc(n_enums, sizeof(res->attr.ea.enum_nameid[0])); + assert(n_enums >= 0); + res = new_type(type_enumeration, NULL, name, db); + res->attr.ea.enumer = NEW_ARR_F(ir_enum_const, n_enums); hook_new_type(res); return res; } @@ -1714,39 +1716,46 @@ void free_enumeration_entities(ir_type *enumeration) { } void free_enumeration_attrs(ir_type *enumeration) { assert(enumeration && (enumeration->type_op == type_enumeration)); - free(enumeration->attr.ea.enumer); - free(enumeration->attr.ea.enum_nameid); + DEL_ARR_F(enumeration->attr.ea.enumer); } /* manipulate fields of enumeration type. */ -int get_enumeration_n_enums (const ir_type *enumeration) { +int get_enumeration_n_enums(const ir_type *enumeration) { assert(enumeration && (enumeration->type_op == type_enumeration)); - return enumeration->attr.ea.n_enums; + return ARR_LEN(enumeration->attr.ea.enumer); } -void set_enumeration_enum (ir_type *enumeration, int pos, tarval *con) { - assert(enumeration && (enumeration->type_op == type_enumeration)); - assert(pos >= 0 && pos < get_enumeration_n_enums(enumeration)); - enumeration->attr.ea.enumer[pos] = con; + +/* create a new constant */ +void set_enumeration_const(ir_type *enumeration, int pos, ident *nameid, tarval *con) { + assert(0 <= pos && pos < ARR_LEN(enumeration->attr.ea.enumer)); + enumeration->attr.ea.enumer[pos].nameid = nameid; + enumeration->attr.ea.enumer[pos].value = con; + enumeration->attr.ea.enumer[pos].owner = enumeration; } -tarval *get_enumeration_enum (const ir_type *enumeration, int pos) { + +ir_enum_const *get_enumeration_const(const ir_type *enumeration, int pos) { assert(enumeration && (enumeration->type_op == type_enumeration)); assert(pos >= 0 && pos < get_enumeration_n_enums(enumeration)); - return enumeration->attr.ea.enumer[pos]; + return &enumeration->attr.ea.enumer[pos]; } -void set_enumeration_nameid (ir_type *enumeration, int pos, ident *id) { - assert(enumeration && (enumeration->type_op == type_enumeration)); - assert(pos >= 0 && pos < get_enumeration_n_enums(enumeration)); - enumeration->attr.ea.enum_nameid[pos] = id; + +ir_type *get_enumeration_owner(const ir_enum_const *enum_cnst) { + return enum_cnst->owner; } -ident *get_enumeration_nameid (const ir_type *enumeration, int pos) { - assert(enumeration && (enumeration->type_op == type_enumeration)); - assert(pos >= 0 && pos < get_enumeration_n_enums(enumeration)); - return enumeration->attr.ea.enum_nameid[pos]; +void set_enumeration_value(ir_enum_const *enum_cnst, tarval *con) { + enum_cnst->value = con; } -const char *get_enumeration_name(const ir_type *enumeration, int pos) { - assert(enumeration && (enumeration->type_op == type_enumeration)); - assert(pos >= 0 && pos < get_enumeration_n_enums(enumeration)); - return get_id_str(enumeration->attr.ea.enum_nameid[pos]); +tarval *get_enumeration_value(const ir_enum_const *enum_cnst) { + return enum_cnst->value; +} +void set_enumeration_nameid(ir_enum_const *enum_cnst, ident *id) { + enum_cnst->nameid = id; +} +ident *get_enumeration_nameid(const ir_enum_const *enum_cnst) { + return enum_cnst->nameid; +} +const char *get_enumeration_name(const ir_enum_const *enum_cnst) { + return get_id_str(enum_cnst->nameid); } /* typecheck */ @@ -1926,12 +1935,17 @@ int is_compound_type(const ir_type *tp) { return tp->type_op->flags & TP_OP_FLAG_COMPOUND; } -/* Checks, whether a type is a frame ir_type */ +/* Checks, whether a type is a frame type */ int is_frame_type(const ir_type *tp) { return tp->flags & tf_frame_type; } -/* Checks, whether a type is a lowered ir_type */ +/* Checks, whether a type is a value parameter type */ +int is_value_param_type(const ir_type *tp) { + return tp->flags & tf_value_param_type; +} + +/* Checks, whether a type is a lowered type */ int is_lowered_type(const ir_type *tp) { return tp->flags & tf_lowered_type; } @@ -1975,7 +1989,7 @@ void set_default_size_bits(ir_type *tp, int size) { * at the start or the end of a frame type. * The frame type must have already an fixed layout. */ -entity *frame_alloc_area(type *frame_type, int size, int alignment, int at_start) +entity *frame_alloc_area(ir_type *frame_type, int size, int alignment, int at_start) { entity *area; ir_type *tp;