mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-10 21:10:16 +01:00
glsl: Don't constant-fold in a constant in place of a function outval.
This commit is contained in:
parent
6606fde3ec
commit
428a3cd2d5
1 changed files with 22 additions and 0 deletions
|
|
@ -49,6 +49,7 @@ public:
|
|||
}
|
||||
|
||||
virtual ir_visitor_status visit_enter(ir_assignment *ir);
|
||||
virtual ir_visitor_status visit_enter(ir_call *ir);
|
||||
|
||||
virtual void handle_rvalue(ir_rvalue **rvalue);
|
||||
|
||||
|
|
@ -100,6 +101,27 @@ ir_constant_folding_visitor::visit_enter(ir_assignment *ir)
|
|||
return visit_continue_with_parent;
|
||||
}
|
||||
|
||||
ir_visitor_status
|
||||
ir_constant_folding_visitor::visit_enter(ir_call *ir)
|
||||
{
|
||||
exec_list_iterator sig_iter = ir->get_callee()->parameters.iterator();
|
||||
foreach_iter(exec_list_iterator, iter, *ir) {
|
||||
ir_rvalue *param_rval = (ir_rvalue *)iter.get();
|
||||
ir_variable *sig_param = (ir_variable *)sig_iter.get();
|
||||
|
||||
if (sig_param->mode == ir_var_in) {
|
||||
ir_rvalue *new_param = param_rval;
|
||||
|
||||
handle_rvalue(&new_param);
|
||||
if (new_param != param_rval) {
|
||||
param_rval->replace_with(new_param);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return visit_continue_with_parent;
|
||||
}
|
||||
|
||||
bool
|
||||
do_constant_folding(exec_list *instructions)
|
||||
{
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue