summaryrefslogtreecommitdiffstats
path: root/src/glsl/opt_redundant_jumps.cpp
diff options
context:
space:
mode:
authorEric Anholt <eric@anholt.net>2012-05-29 16:18:37 -0700
committerEric Anholt <eric@anholt.net>2012-06-11 09:28:00 -0700
commit337d9c955b070224f7278524af54ddacd8bb0f17 (patch)
tree4235c18837cc1f81b0c2f008cc01ce7a6e3a39a8 /src/glsl/opt_redundant_jumps.cpp
parent279efce8bb7b6c802eb6c1de46971153ff6fdedb (diff)
downloadexternal_mesa3d-337d9c955b070224f7278524af54ddacd8bb0f17.zip
external_mesa3d-337d9c955b070224f7278524af54ddacd8bb0f17.tar.gz
external_mesa3d-337d9c955b070224f7278524af54ddacd8bb0f17.tar.bz2
glsl: Put a bunch of optimization visitors under anonymous namespaces.
Because these classes are used entirely from their own source files and not from separate DSOs, the linker gets to produce massively less code. This cuts about 13k of text in the libdricore case. In the non-libdricore case, the additional linkage information allows the compiler to inline some code, so libglsl.a size actually increases by about 300 bytes. For a dricore build, improves shader_runner runtime on glsl-fs-copy-propagation-texcoords-1 by 0.21% +/- 0.03% (n=353574, outliers removed). No statistically significant difference with n=322 on glslparsertest on a yofrankie shader intended to test compiler performance. Reviewed-by: Kenneth Graunke <kenneth@whitecape.org>
Diffstat (limited to 'src/glsl/opt_redundant_jumps.cpp')
-rw-r--r--src/glsl/opt_redundant_jumps.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/glsl/opt_redundant_jumps.cpp b/src/glsl/opt_redundant_jumps.cpp
index f350fa9..8606dcb 100644
--- a/src/glsl/opt_redundant_jumps.cpp
+++ b/src/glsl/opt_redundant_jumps.cpp
@@ -28,6 +28,8 @@
#include "ir.h"
+namespace {
+
class redundant_jumps_visitor : public ir_hierarchical_visitor {
public:
redundant_jumps_visitor()
@@ -42,6 +44,8 @@ public:
bool progress;
};
+} /* unnamed namespace */
+
/* We only care about the top level instructions, so don't descend
* into expressions.
*/