summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStéphane Marchesin <marcheu@chromium.org>2011-07-06 11:44:19 -0700
committerStéphane Marchesin <marcheu@chromium.org>2011-07-06 12:00:47 -0700
commit053af6ac8cda226a62844fc014ed9f133557c111 (patch)
tree33f726fa1eb4580bb3ff11302c6247ae9b83de4e
parent07e5295b6fe77253ea38dbc0d649b20e7275373a (diff)
i915g: Fix optimization, also make it more generic.
-rw-r--r--src/gallium/drivers/i915/i915_fpc_optimize.c28
1 files changed, 26 insertions, 2 deletions
diff --git a/src/gallium/drivers/i915/i915_fpc_optimize.c b/src/gallium/drivers/i915/i915_fpc_optimize.c
index 5c60d952de2..738468d8ff8 100644
--- a/src/gallium/drivers/i915/i915_fpc_optimize.c
+++ b/src/gallium/drivers/i915/i915_fpc_optimize.c
@@ -54,6 +54,22 @@ static boolean same_src_reg(struct i915_full_src_register* d1, struct i915_full_
d1->Register.Negate == d2->Register.Negate);
}
+static boolean is_unswizzled(struct i915_full_src_register* r,
+ int sx,
+ int sy,
+ int sz,
+ int sw)
+{
+ if (sx && r->Register.SwizzleX != TGSI_SWIZZLE_X)
+ return FALSE;
+ if (sy && r->Register.SwizzleY != TGSI_SWIZZLE_Y)
+ return FALSE;
+ if (sz && r->Register.SwizzleZ != TGSI_SWIZZLE_Z)
+ return FALSE;
+ if (sw && r->Register.SwizzleW != TGSI_SWIZZLE_W)
+ return FALSE;
+ return FALSE;
+}
/*
* Optimize away things like:
@@ -72,11 +88,15 @@ static void i915_fpc_optimize_mov_after_mul(union i915_full_token* current, unio
current->FullInstruction.Dst[0].Register.WriteMask == TGSI_WRITEMASK_XYZ &&
next->FullInstruction.Dst[0].Register.WriteMask == TGSI_WRITEMASK_W &&
same_dst_reg(&next->FullInstruction.Dst[0], &next->FullInstruction.Dst[0]) &&
- same_src_reg(&next->FullInstruction.Src[0], &current->FullInstruction.Src[1]) )
+ same_src_reg(&next->FullInstruction.Src[0], &current->FullInstruction.Src[1]) &&
+ is_unswizzled(&current->FullInstruction.Src[0], 1, 1, 1, 0) &&
+ is_unswizzled(&current->FullInstruction.Src[1], 1, 1, 1, 0) &&
+ is_unswizzled(&next->FullInstruction.Src[0], 0, 0, 0, 1) )
{
next->FullInstruction.Instruction.Opcode = TGSI_OPCODE_NOP;
current->FullInstruction.Dst[0].Register.WriteMask = TGSI_WRITEMASK_XYZW;
current->FullInstruction.Src[0].Register.SwizzleW = TGSI_SWIZZLE_ONE;
+ current->FullInstruction.Src[1].Register.SwizzleW = TGSI_SWIZZLE_W;
return;
}
@@ -87,11 +107,15 @@ static void i915_fpc_optimize_mov_after_mul(union i915_full_token* current, unio
current->FullInstruction.Dst[0].Register.WriteMask == TGSI_WRITEMASK_XYZ &&
next->FullInstruction.Dst[0].Register.WriteMask == TGSI_WRITEMASK_W &&
same_dst_reg(&next->FullInstruction.Dst[0], &next->FullInstruction.Dst[0]) &&
- same_src_reg(&next->FullInstruction.Src[0], &current->FullInstruction.Src[0]) )
+ same_src_reg(&next->FullInstruction.Src[0], &current->FullInstruction.Src[0]) &&
+ is_unswizzled(&current->FullInstruction.Src[0], 1, 1, 1, 0) &&
+ is_unswizzled(&current->FullInstruction.Src[1], 1, 1, 1, 0) &&
+ is_unswizzled(&next->FullInstruction.Src[0], 0, 0, 0, 1) )
{
next->FullInstruction.Instruction.Opcode = TGSI_OPCODE_NOP;
current->FullInstruction.Dst[0].Register.WriteMask = TGSI_WRITEMASK_XYZW;
current->FullInstruction.Src[1].Register.SwizzleW = TGSI_SWIZZLE_ONE;
+ current->FullInstruction.Src[0].Register.SwizzleW = TGSI_SWIZZLE_W;
return;
}
}