diff options
author | Francisco Jerez <currojerez@riseup.net> | 2015-03-18 21:19:28 +0200 |
---|---|---|
committer | Francisco Jerez <currojerez@riseup.net> | 2015-03-23 14:09:33 +0200 |
commit | 516d45f78a3bbab0288c49c0f876ebdf4ad05bff (patch) | |
tree | 9d19cbddfe51880b177ec140cf2e201a8a80d1df /src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp | |
parent | 430c6bf70e48c08ba4dc9e00f2b88e2230793010 (diff) | |
download | external_mesa3d-516d45f78a3bbab0288c49c0f876ebdf4ad05bff.zip external_mesa3d-516d45f78a3bbab0288c49c0f876ebdf4ad05bff.tar.gz external_mesa3d-516d45f78a3bbab0288c49c0f876ebdf4ad05bff.tar.bz2 |
i965/vec4: Some more trivial swizzle clean-up.
Reviewed-by: Matt Turner <mattst88@gmail.com>
Diffstat (limited to 'src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp')
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp | 15 |
1 files changed, 3 insertions, 12 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp b/src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp index f83b859..26a3b9f 100644 --- a/src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp +++ b/src/mesa/drivers/dri/i965/brw_vec4_visitor.cpp @@ -3334,18 +3334,9 @@ vec4_visitor::emit_scratch_write(bblock_t *block, vec4_instruction *inst, * weren't initialized, it will confuse live interval analysis, which will * make spilling fail to make progress. */ - src_reg temp = src_reg(this, glsl_type::vec4_type); - temp.type = inst->dst.type; - int first_writemask_chan = ffs(inst->dst.writemask) - 1; - int swizzles[4]; - for (int i = 0; i < 4; i++) - if (inst->dst.writemask & (1 << i)) - swizzles[i] = i; - else - swizzles[i] = first_writemask_chan; - temp.swizzle = BRW_SWIZZLE4(swizzles[0], swizzles[1], - swizzles[2], swizzles[3]); - + const src_reg temp = swizzle(retype(src_reg(this, glsl_type::vec4_type), + inst->dst.type), + brw_swizzle_for_mask(inst->dst.writemask)); dst_reg dst = dst_reg(brw_writemask(brw_vec8_grf(0, 0), inst->dst.writemask)); vec4_instruction *write = SCRATCH_WRITE(dst, temp, index); |