[Mesa-dev] [PATCH 9/9] nir: don't turn ieq/ine into inot if used by an if
Timothy Arceri
timothy.arceri at collabora.com
Tue Jan 10 09:41:58 UTC 2017
Otherwise we will end up with an extra instruction to compare the
result of the inot.
On BDW:
total instructions in shared programs: 13060620 -> 13060481 (-0.00%)
instructions in affected programs: 103379 -> 103240 (-0.13%)
helped: 127
HURT: 0
total cycles in shared programs: 256590950 -> 256587408 (-0.00%)
cycles in affected programs: 11324730 -> 11321188 (-0.03%)
helped: 114
HURT: 21
---
src/compiler/nir/nir_opt_algebraic.py | 4 ++--
src/compiler/nir/nir_search_helpers.h | 6 ++++++
2 files changed, 8 insertions(+), 2 deletions(-)
diff --git a/src/compiler/nir/nir_opt_algebraic.py b/src/compiler/nir/nir_opt_algebraic.py
index 1852a4d..a557f7b 100644
--- a/src/compiler/nir/nir_opt_algebraic.py
+++ b/src/compiler/nir/nir_opt_algebraic.py
@@ -267,9 +267,9 @@ optimizations = [
(('~frcp', ('frsq', a)), ('fsqrt', a), '!options->lower_fsqrt'),
# Boolean simplifications
(('ieq', 'a at bool', True), a),
- (('ine', 'a at bool', True), ('inot', a)),
+ (('ine(is_not_used_by_if)', 'a at bool', True), ('inot', a)),
(('ine', 'a at bool', False), a),
- (('ieq', 'a at bool', False), ('inot', 'a')),
+ (('ieq(is_not_used_by_if)', 'a at bool', False), ('inot', 'a')),
(('bcsel', a, True, False), a),
(('bcsel', a, False, True), ('inot', a)),
(('bcsel at 32', a, 1.0, 0.0), ('b2f', a)),
diff --git a/src/compiler/nir/nir_search_helpers.h b/src/compiler/nir/nir_search_helpers.h
index 313f232..0048618 100644
--- a/src/compiler/nir/nir_search_helpers.h
+++ b/src/compiler/nir/nir_search_helpers.h
@@ -128,4 +128,10 @@ is_used_more_than_once(nir_alu_instr *instr)
return true;
}
+static inline bool
+is_not_used_by_if(nir_alu_instr *instr)
+{
+ return list_empty(&instr->dest.dest.ssa.if_uses);
+}
+
#endif /* _NIR_SEARCH_ */
--
2.9.3
More information about the mesa-dev
mailing list