mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-05 07:28:11 +02:00
glsl: Don't make a name for the function return variable
If the name is just going to get dropped, don't bother making it. If the name is made, release it sooner (rather than later). No change Valgrind massif results for a trimmed apitrace of dota2. Signed-off-by: Ian Romanick <ian.d.romanick@intel.com> Reviewed-by: Matt Turner <mattst88@gmail.com>
This commit is contained in:
parent
c87d09d7f0
commit
0b47252999
1 changed files with 7 additions and 4 deletions
|
|
@ -408,14 +408,17 @@ generate_call(exec_list *instructions, ir_function_signature *sig,
|
|||
ir_dereference_variable *deref = NULL;
|
||||
if (!sig->return_type->is_void()) {
|
||||
/* Create a new temporary to hold the return value. */
|
||||
char *const name = ir_variable::temporaries_allocate_names
|
||||
? ralloc_asprintf(ctx, "%s_retval", sig->function_name())
|
||||
: NULL;
|
||||
|
||||
ir_variable *var;
|
||||
|
||||
var = new(ctx) ir_variable(sig->return_type,
|
||||
ralloc_asprintf(ctx, "%s_retval",
|
||||
sig->function_name()),
|
||||
ir_var_temporary);
|
||||
var = new(ctx) ir_variable(sig->return_type, name, ir_var_temporary);
|
||||
instructions->push_tail(var);
|
||||
|
||||
ralloc_free(name);
|
||||
|
||||
deref = new(ctx) ir_dereference_variable(var);
|
||||
}
|
||||
ir_call *call = new(ctx) ir_call(sig, deref, actual_parameters);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue