aboutsummaryrefslogtreecommitdiffstats
path: root/src/compiler/nir/nir_lower_to_source_mods.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/compiler/nir/nir_lower_to_source_mods.c')
-rw-r--r--src/compiler/nir/nir_lower_to_source_mods.c53
1 files changed, 13 insertions, 40 deletions
diff --git a/src/compiler/nir/nir_lower_to_source_mods.c b/src/compiler/nir/nir_lower_to_source_mods.c
index 3315a18670b..63ef4043fe2 100644
--- a/src/compiler/nir/nir_lower_to_source_mods.c
+++ b/src/compiler/nir/nir_lower_to_source_mods.c
@@ -78,13 +78,13 @@ nir_lower_to_source_mods_block(nir_block *block,
case nir_type_float:
if (!(options & nir_lower_float_source_mods))
continue;
- if (parent->op != nir_op_fmov)
+ if (parent->op != nir_op_fabs && parent->op != nir_op_fneg)
continue;
break;
case nir_type_int:
if (!(options & nir_lower_int_source_mods))
continue;
- if (parent->op != nir_op_imov)
+ if (parent->op != nir_op_iabs && parent->op != nir_op_ineg)
continue;
break;
default:
@@ -98,10 +98,19 @@ nir_lower_to_source_mods_block(nir_block *block,
if (!parent->src[0].src.is_ssa)
continue;
- if (!lower_abs && parent->src[0].abs)
+ if (!lower_abs && (parent->op == nir_op_fabs &&
+ parent->op == nir_op_iabs))
continue;
nir_instr_rewrite_src(instr, &alu->src[i].src, parent->src[0].src);
+
+ /* Apply any modifiers that come from the parent opcode */
+ if (parent->op == nir_op_fneg || parent->op == nir_op_ineg)
+ alu_src_consume_negate(&alu->src[i]);
+ if (parent->op == nir_op_fabs || parent->op == nir_op_iabs)
+ alu_src_consume_abs(&alu->src[i]);
+
+ /* Apply modifiers from the parent source */
if (parent->src[0].negate)
alu_src_consume_negate(&alu->src[i]);
if (parent->src[0].abs)
@@ -120,41 +129,6 @@ nir_lower_to_source_mods_block(nir_block *block,
progress = true;
}
- if (options & nir_lower_float_source_mods) {
- switch (alu->op) {
- case nir_op_fsat:
- alu->op = nir_op_fmov;
- alu->dest.saturate = true;
- break;
- case nir_op_fneg:
- alu->op = nir_op_fmov;
- alu->src[0].negate = !alu->src[0].negate;
- break;
- case nir_op_fabs:
- alu->op = nir_op_fmov;
- alu->src[0].abs = true;
- alu->src[0].negate = false;
- break;
- default:
- break;
- }
- }
-
- if (options & nir_lower_int_source_mods) {
- switch (alu->op) {
- case nir_op_ineg:
- alu->op = nir_op_imov;
- alu->src[0].negate = !alu->src[0].negate;
- break;
- case nir_op_iabs:
- alu->op = nir_op_imov;
- alu->src[0].abs = true;
- alu->src[0].negate = false;
- break;
- default:
- break;
- }
- }
/* We've covered sources. Now we're going to try and saturate the
* destination if we can.
*/
@@ -188,8 +162,7 @@ nir_lower_to_source_mods_block(nir_block *block,
continue;
}
- if (child_alu->op != nir_op_fsat &&
- !(child_alu->op == nir_op_fmov && child_alu->dest.saturate)) {
+ if (child_alu->op != nir_op_fsat) {
all_children_are_sat = false;
continue;
}