[Mesa-dev] [PATCH 2/6] i965/vec4: Use can_do_writemask in can_reswizzle
Jason Ekstrand
jason at jlekstrand.net
Wed Apr 6 04:11:09 UTC 2016
---
src/mesa/drivers/dri/i965/brw_vec4.cpp | 8 +++++---
1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/src/mesa/drivers/dri/i965/brw_vec4.cpp b/src/mesa/drivers/dri/i965/brw_vec4.cpp
index 4d0efa8..87b5ff9 100644
--- a/src/mesa/drivers/dri/i965/brw_vec4.cpp
+++ b/src/mesa/drivers/dri/i965/brw_vec4.cpp
@@ -965,10 +965,12 @@ vec4_instruction::can_reswizzle(const struct brw_device_info *devinfo,
int swizzle_mask)
{
/* Gen6 MATH instructions can not execute in align16 mode, so swizzles
- * or writemasking are not allowed.
+ * are not allowed.
*/
- if (devinfo->gen == 6 && is_math() &&
- (swizzle != BRW_SWIZZLE_XYZW || dst_writemask != WRITEMASK_XYZW))
+ if (devinfo->gen == 6 && is_math() && swizzle != BRW_SWIZZLE_XYZW)
+ return false;
+
+ if (!can_do_writemask(devinfo) && dst_writemask != WRITEMASK_XYZW)
return false;
/* If this instruction sets anything not referenced by swizzle, then we'd
--
2.5.0.400.gff86faf
More information about the mesa-dev
mailing list