[Mesa-dev] [PATCH 04/31] i965/fs: Handle instruction predication in SIMD lowering pass.
Francisco Jerez
currojerez at riseup.net
Sat May 21 05:47:39 UTC 2016
---
src/mesa/drivers/dri/i965/brw_fs.cpp | 12 +++++++++++-
1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/src/mesa/drivers/dri/i965/brw_fs.cpp b/src/mesa/drivers/dri/i965/brw_fs.cpp
index e98c41d..3646c27 100644
--- a/src/mesa/drivers/dri/i965/brw_fs.cpp
+++ b/src/mesa/drivers/dri/i965/brw_fs.cpp
@@ -4772,12 +4772,12 @@ fs_visitor::lower_simd_width()
* instruction.
*/
const fs_builder lbld = ibld.group(lower_width, i);
+ const fs_builder cbld = lbld.group(copy_width, 0);
for (unsigned j = 0; j < inst->sources; j++) {
if (inst->src[j].file != BAD_FILE &&
!is_periodic(inst->src[j], lower_width)) {
/* Get the i-th copy_width-wide chunk of the source. */
- const fs_builder cbld = lbld.group(copy_width, 0);
const fs_reg src = offset(inst->src[j], cbld, i);
const unsigned src_size = inst->components_read(j);
@@ -4802,6 +4802,16 @@ fs_visitor::lower_simd_width()
split_inst.regs_written =
DIV_ROUND_UP(type_sz(inst->dst.type) * dst_size * lower_width,
REG_SIZE);
+
+ if (inst->predicate) {
+ /* Handle predication by copying the original contents of
+ * the destination into the temporary before emitting the
+ * lowered instruction.
+ */
+ for (unsigned k = 0; k < dst_size; ++k)
+ cbld.MOV(offset(split_inst.dst, lbld, k),
+ offset(inst->dst, cbld, n * k + i));
+ }
}
lbld.emit(split_inst);
--
2.7.3
More information about the mesa-dev
mailing list