From 95e9d58bdb7df402d9035842c3fe76234a14c2da Mon Sep 17 00:00:00 2001 From: Jason Ekstrand Date: Wed, 20 Jul 2016 19:56:45 -0700 Subject: spirv/nir: Properly handle gather components Signed-off-by: Jason Ekstrand Reviewed-by: Kenneth Graunke Cc: "12.0" --- src/compiler/spirv/spirv_to_nir.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/compiler/spirv/spirv_to_nir.c b/src/compiler/spirv/spirv_to_nir.c index c32dfaa76ba..b1bb48be577 100644 --- a/src/compiler/spirv/spirv_to_nir.c +++ b/src/compiler/spirv/spirv_to_nir.c @@ -1368,14 +1368,23 @@ vtn_handle_texture(struct vtn_builder *b, SpvOp opcode, break; } - /* These all have an explicit depth value as their next source */ + unsigned gather_component = 0; switch (opcode) { case SpvOpImageSampleDrefImplicitLod: case SpvOpImageSampleDrefExplicitLod: case SpvOpImageSampleProjDrefImplicitLod: case SpvOpImageSampleProjDrefExplicitLod: + case SpvOpImageDrefGather: + /* These all have an explicit depth value as their next source */ (*p++) = vtn_tex_src(b, w[idx++], nir_tex_src_comparitor); break; + + case SpvOpImageGather: + /* This has a component as its next source */ + gather_component = + vtn_value(b, w[idx++], vtn_value_type_constant)->constant->value.u[0]; + break; + default: break; } @@ -1481,6 +1490,7 @@ vtn_handle_texture(struct vtn_builder *b, SpvOp opcode, instr->is_shadow = glsl_sampler_type_is_shadow(image_type); instr->is_new_style_shadow = instr->is_shadow && glsl_get_components(ret_type->type) == 1; + instr->component = gather_component; if (has_coord) { switch (instr->sampler_dim) { -- cgit v1.2.3