projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix irio not working correctly anymore after MacroBlocks were removed
[libfirm]
/
ir
/
opt
/
garbage_collect.c
diff --git
a/ir/opt/garbage_collect.c
b/ir/opt/garbage_collect.c
index
d065773
..
0d5161d
100644
(file)
--- a/
ir/opt/garbage_collect.c
+++ b/
ir/opt/garbage_collect.c
@@
-65,7
+65,6
@@
static void start_visit_node(ir_node *node)
if (get_irg_visited(irg) < get_max_irg_visited()) {
set_irg_visited(irg, get_max_irg_visited());
}
if (get_irg_visited(irg) < get_max_irg_visited()) {
set_irg_visited(irg, get_max_irg_visited());
}
- current_ir_graph = irg;
irg_walk_2(node, visit_node, NULL, NULL);
}
irg_walk_2(node, visit_node, NULL, NULL);
}
@@
-81,7
+80,7
@@
static void visit_initializer(ir_initializer_t *initializer)
case IR_INITIALIZER_COMPOUND: {
size_t i;
case IR_INITIALIZER_COMPOUND: {
size_t i;
- for(i = 0; i < initializer->compound.n_initializers; ++i) {
+ for
(i = 0; i < initializer->compound.n_initializers; ++i) {
ir_initializer_t *subinitializer
= initializer->compound.initializers[i];
visit_initializer(subinitializer);
ir_initializer_t *subinitializer
= initializer->compound.initializers[i];
visit_initializer(subinitializer);
@@
-144,8
+143,7
@@
static void garbage_collect_in_segment(ir_type *segment)
DB((dbg, LEVEL_1, " removing entity %+F\n", entity));
DB((dbg, LEVEL_1, " removing entity %+F\n", entity));
- /* TODO: this is O(n^2) improve our interfaces! */
- remove_class_member(get_entity_owner(entity), entity);
+ free_entity(entity);
}
}
}
}
@@
-178,7
+176,7
@@
void garbage_collect_entities(void)
if (entity_visited(entity))
continue;
if (entity_visited(entity))
continue;
- DB((dbg, LEVEL_1, " freeing method %+F\n",
entity));
+ DB((dbg, LEVEL_1, " freeing method %+F\n", entity));
remove_irp_irg(irg);
}
remove_irp_irg(irg);
}