diff options
author | Christian König <[email protected]> | 2013-03-26 15:09:27 +0100 |
---|---|---|
committer | Christian König <[email protected]> | 2013-04-10 10:41:29 +0200 |
commit | ccf3e8fc9b961c1aaa649ba19d35a5dae6e7ed6c (patch) | |
tree | d613434292f6434cada0c805879dc7b6b37ea76b /src/gallium/drivers/radeonsi | |
parent | 31f14f3def0ffb3851ae746304ece13f54e98af4 (diff) |
radeonsi: remove sampler writemask v3
v2: fix instrinsic name as well
v3: LLVM revision incremented as well
Signed-off-by: Christian König <[email protected]>
Reviewed-by: Michel Dänzer <[email protected]>
Diffstat (limited to 'src/gallium/drivers/radeonsi')
-rw-r--r-- | src/gallium/drivers/radeonsi/radeonsi_shader.c | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/src/gallium/drivers/radeonsi/radeonsi_shader.c b/src/gallium/drivers/radeonsi/radeonsi_shader.c index d33d9db5c82..bddf3bd1327 100644 --- a/src/gallium/drivers/radeonsi/radeonsi_shader.c +++ b/src/gallium/drivers/radeonsi/radeonsi_shader.c @@ -795,10 +795,6 @@ static void tex_fetch_args( unsigned count = 0; unsigned chan; - /* WriteMask */ - /* XXX: should be optimized using emit_data->inst->Dst[0].Register.WriteMask*/ - emit_data->args[0] = lp_build_const_int32(bld_base->base.gallivm, 0xf); - /* Fetch and project texture coordinates */ coords[3] = lp_build_emit_fetch(bld_base, emit_data->inst, 0, TGSI_CHAN_W); for (chan = 0; chan < 3; chan++ ) { @@ -904,20 +900,19 @@ static void tex_fetch_args( while (count < util_next_power_of_two(count)) address[count++] = LLVMGetUndef(LLVMInt32TypeInContext(gallivm->context)); - emit_data->args[1] = lp_build_gather_values(gallivm, address, count); + emit_data->args[0] = lp_build_gather_values(gallivm, address, count); /* Resource */ - emit_data->args[2] = si_shader_ctx->resources[emit_data->inst->Src[1].Register.Index]; + emit_data->args[1] = si_shader_ctx->resources[emit_data->inst->Src[1].Register.Index]; /* Sampler */ - emit_data->args[3] = si_shader_ctx->samplers[emit_data->inst->Src[1].Register.Index]; + emit_data->args[2] = si_shader_ctx->samplers[emit_data->inst->Src[1].Register.Index]; /* Dimensions */ - emit_data->args[4] = lp_build_const_int32(bld_base->base.gallivm, target); + emit_data->args[3] = lp_build_const_int32(bld_base->base.gallivm, target); + + emit_data->arg_count = 4; - emit_data->arg_count = 5; - /* XXX: To optimize, we could use a float or v2f32, if the last bits of - * the writemask are clear */ emit_data->dst_type = LLVMVectorType( LLVMFloatTypeInContext(bld_base->base.gallivm->context), 4); @@ -931,7 +926,7 @@ static void build_tex_intrinsic(const struct lp_build_tgsi_action * action, char intr_name[23]; sprintf(intr_name, "%sv%ui32", action->intr_name, - LLVMGetVectorSize(LLVMTypeOf(emit_data->args[1]))); + LLVMGetVectorSize(LLVMTypeOf(emit_data->args[0]))); emit_data->output[emit_data->chan] = build_intrinsic( base->gallivm->builder, intr_name, emit_data->dst_type, |