nir: Recognize max(min(a, 1.0), 0.0) as fsat(a).
authorKenneth Graunke <kenneth@whitecape.org>
Thu, 11 Jun 2015 08:59:44 +0000 (01:59 -0700)
committerKenneth Graunke <kenneth@whitecape.org>
Thu, 25 Jun 2015 09:12:32 +0000 (02:12 -0700)
We already recognize min(max(a, 0.0), 1.0) as a saturate, but neglected
this variant (which is also handled by the GLSL IR pass).

shader-db results on Broadwell:
total instructions in shared programs: 7363046 -> 7362788 (-0.00%)
instructions in affected programs:     11928 -> 11670 (-2.16%)
helped:                                64
HURT:                                  0

Signed-off-by: Kenneth Graunke <kenneth@whitecape.org>
Reviewed-by: Iago Toral Quiroga <itoral@igalia.com>
src/glsl/nir/nir_opt_algebraic.py

index eace791f5b0c5fec749f5174c86f01dabb7ff7cc..3068445cbfe862cc555d5fc0d4ad81dc1048e3e9 100644 (file)
@@ -101,6 +101,7 @@ optimizations = [
    (('umin', a, a), a),
    (('umax', a, a), a),
    (('fmin', ('fmax', a, 0.0), 1.0), ('fsat', a), '!options->lower_fsat'),
+   (('fmax', ('fmin', a, 1.0), 0.0), ('fsat', a), '!options->lower_fsat'),
    (('fsat', a), ('fmin', ('fmax', a, 0.0), 1.0), 'options->lower_fsat'),
    (('fsat', ('fsat', a)), ('fsat', a)),
    (('fmin', ('fmax', ('fmin', ('fmax', a, 0.0), 1.0), 0.0), 1.0), ('fmin', ('fmax', a, 0.0), 1.0)),