- for(i = 0, n = phase->n_data_ptr; i < n; ++i) {
- if(phase->data_ptr[i])
- phase->data_init(phase, NULL, phase->data_ptr[i]);
+ for (i = 0, n = phase->n_data_ptr; i < n; ++i) {
+ if (phase->data_ptr[i])
+ phase->data_init(phase, get_idx_irn(phase->irg, i), phase->data_ptr[i]);
+ }
+}
+
+void phase_reinit_block_irn_data(phase_t *phase, ir_node *block)
+{
+ int i, n;
+
+ if (! phase->data_init)
+ return;
+
+ for (i = 0, n = phase->n_data_ptr; i < n; ++i) {
+ if (phase->data_ptr[i]) {
+ ir_node *irn = get_idx_irn(phase->irg, i);
+ if (! is_Block(irn) && get_nodes_block(irn) == block)
+ phase->data_init(phase, irn, phase->data_ptr[i]);
+ }