Browse Source

ir_function_inlining: Re-add the "s/return/retval =/" functionality.

I ripped it out with the cloning changes yesterday, and should have
tested and noticed that there were now returns all over.
tags/mesa-7.9-rc1
Eric Anholt 15 years ago
parent
commit
f66ba4f357
3 changed files with 41 additions and 2 deletions
  1. 23
    1
      ir_function_inlining.cpp
  2. 14
    0
      ir_hierarchical_visitor.cpp
  3. 4
    1
      ir_hierarchical_visitor.h

+ 23
- 1
ir_function_inlining.cpp View File

@@ -91,6 +91,26 @@ do_function_inlining(exec_list *instructions)
return v.progress;
}

static void
replace_return_with_assignment(ir_instruction *ir, void *data)
{
ir_variable *retval = (ir_variable *)data;
ir_return *ret = ir->as_return();

if (ret) {
if (ret->value) {
ir_rvalue *lhs = new ir_dereference_variable(retval);
ret->insert_before(new ir_assignment(lhs, ret->value, NULL));
ret->remove();
} else {
/* un-valued return has to be the last return, or we shouldn't
* have reached here. (see can_inline()).
*/
assert(!ret->next->is_tail_sentinal());
}
}
}

ir_rvalue *
ir_call::generate_inline(ir_instruction *next_ir)
{
@@ -145,8 +165,10 @@ ir_call::generate_inline(ir_instruction *next_ir)
/* Generate the inlined body of the function. */
foreach_iter(exec_list_iterator, iter, callee->body) {
ir_instruction *ir = (ir_instruction *)iter.get();
ir_instruction *new_ir = ir->clone(ht);

next_ir->insert_before(ir->clone(ht));
next_ir->insert_before(new_ir);
visit_tree(new_ir, replace_return_with_assignment, retval);
}

/* Copy back the value of any 'out' parameters from the function body

+ 14
- 0
ir_hierarchical_visitor.cpp View File

@@ -268,3 +268,17 @@ ir_hierarchical_visitor::run(exec_list *instructions)
break;
}
}


void
visit_tree(ir_instruction *ir,
void (*callback)(class ir_instruction *ir, void *data),
void *data)
{
ir_hierarchical_visitor v;

v.callback = callback;
v.data = data;

ir->accept(&v);
}

+ 4
- 1
ir_hierarchical_visitor.h View File

@@ -139,7 +139,6 @@ public:
*/
void run(struct exec_list *instructions);

protected:
/**
* Callback function that is invoked on entry to each node visited.
*
@@ -156,4 +155,8 @@ protected:
void *data;
};

void visit_tree(ir_instruction *ir,
void (*callback)(class ir_instruction *ir, void *data),
void *data);

#endif /* IR_HIERARCHICAL_VISITOR_H */

Loading…
Cancel
Save