summaryrefslogtreecommitdiffstats
path: root/src/intel/compiler
diff options
context:
space:
mode:
authorJason Ekstrand <[email protected]>2017-10-04 13:20:52 -0700
committerJason Ekstrand <[email protected]>2017-10-05 11:54:49 -0700
commit7463d5058009d1e9d9d01292f894271a26a062b8 (patch)
tree015fa8766886f6b863714013ed1a3066a1f172cd /src/intel/compiler
parentb91ecee04ab2a5b23ff2418b4d709252878cf894 (diff)
intel/compiler: Don't propagate cmod into integer multiplies
No shader-db change on Sky Lake. Reviewed-by: Matt Turner <[email protected]> Cc: [email protected]
Diffstat (limited to 'src/intel/compiler')
-rw-r--r--src/intel/compiler/brw_fs_cmod_propagation.cpp17
-rw-r--r--src/intel/compiler/brw_vec4_cmod_propagation.cpp17
2 files changed, 34 insertions, 0 deletions
diff --git a/src/intel/compiler/brw_fs_cmod_propagation.cpp b/src/intel/compiler/brw_fs_cmod_propagation.cpp
index db63e942b75..4625d69f89e 100644
--- a/src/intel/compiler/brw_fs_cmod_propagation.cpp
+++ b/src/intel/compiler/brw_fs_cmod_propagation.cpp
@@ -150,6 +150,23 @@ opt_cmod_propagation_local(const gen_device_info *devinfo, bblock_t *block)
if (scan_inst->saturate)
break;
+ /* From the Sky Lake PRM, Vol 2a, "Multiply":
+ *
+ * "When multiplying integer data types, if one of the sources
+ * is a DW, the resulting full precision data is stored in
+ * the accumulator. However, if the destination data type is
+ * either W or DW, the low bits of the result are written to
+ * the destination register and the remaining high bits are
+ * discarded. This results in undefined Overflow and Sign
+ * flags. Therefore, conditional modifiers and saturation
+ * (.sat) cannot be used in this case."
+ *
+ * We just disallow cmod propagation on all integer multiplies.
+ */
+ if (!brw_reg_type_is_floating_point(scan_inst->dst.type) &&
+ scan_inst->opcode == BRW_OPCODE_MUL)
+ break;
+
/* Otherwise, try propagating the conditional. */
enum brw_conditional_mod cond =
inst->src[0].negate ? brw_swap_cmod(inst->conditional_mod)
diff --git a/src/intel/compiler/brw_vec4_cmod_propagation.cpp b/src/intel/compiler/brw_vec4_cmod_propagation.cpp
index 05e65168193..0d72d82a578 100644
--- a/src/intel/compiler/brw_vec4_cmod_propagation.cpp
+++ b/src/intel/compiler/brw_vec4_cmod_propagation.cpp
@@ -137,6 +137,23 @@ opt_cmod_propagation_local(bblock_t *block)
if (scan_inst->saturate)
break;
+ /* From the Sky Lake PRM, Vol 2a, "Multiply":
+ *
+ * "When multiplying integer data types, if one of the sources
+ * is a DW, the resulting full precision data is stored in
+ * the accumulator. However, if the destination data type is
+ * either W or DW, the low bits of the result are written to
+ * the destination register and the remaining high bits are
+ * discarded. This results in undefined Overflow and Sign
+ * flags. Therefore, conditional modifiers and saturation
+ * (.sat) cannot be used in this case.
+ *
+ * We just disallow cmod propagation on all integer multiplies.
+ */
+ if (!brw_reg_type_is_floating_point(scan_inst->dst.type) &&
+ scan_inst->opcode == BRW_OPCODE_MUL)
+ break;
+
/* Otherwise, try propagating the conditional. */
enum brw_conditional_mod cond =
inst->src[0].negate ? brw_swap_cmod(inst->conditional_mod)