X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=src%2Fglsl%2Fopt_dead_functions.cpp;fp=src%2Fglsl%2Fopt_dead_functions.cpp;h=7c64c618c0ca4b683bccb0d21063de55547462ee;hb=c75427f4c8767e131e5fb3de44fbc9d904cb992d;hp=51c77e3b9476150562ee21b8cfe177cdc0a9aee0;hpb=11af045ea8080435de0be74d8765190287b64f8b;p=mesa.git diff --git a/src/glsl/opt_dead_functions.cpp b/src/glsl/opt_dead_functions.cpp index 51c77e3b947..7c64c618c0c 100644 --- a/src/glsl/opt_dead_functions.cpp +++ b/src/glsl/opt_dead_functions.cpp @@ -50,6 +50,7 @@ public: ir_dead_functions_visitor() { this->mem_ctx = ralloc_context(NULL); + this->seen_another_function_signature = false; } ~ir_dead_functions_visitor() @@ -64,6 +65,8 @@ public: bool (*predicate)(ir_instruction *ir); + bool seen_another_function_signature; + /* List of signature_entry */ exec_list signature_list; void *mem_ctx; @@ -94,7 +97,13 @@ ir_dead_functions_visitor::visit_enter(ir_function_signature *ir) entry->used = true; } - + /* If this is the first signature to look at, no need to descend to see + * if it has calls to another function signature. + */ + if (!this->seen_another_function_signature) { + this->seen_another_function_signature = true; + return visit_continue_with_parent; + } return visit_continue; }