gallivm: fix texture function name (key) when using txf/ld
authorRoland Scheidegger <sroland@vmware.com>
Sat, 28 Mar 2015 01:57:13 +0000 (02:57 +0100)
committerRoland Scheidegger <sroland@vmware.com>
Sat, 28 Mar 2015 01:58:43 +0000 (02:58 +0100)
When using the texel fetch functions rather than ordinary texturing,
the arguments are all int vecs instead of float vecs, not to mention
the actual function would look completely different. Hence this must
be included in the texture function name (which serves as the key)
otherwise things crash badly when a shader accesses the same texture
and sampler unit with both txf/ld and ordinary texturing instructions
with otherwise matching keys.

src/gallium/auxiliary/gallivm/lp_bld_sample_soa.c

index 9e74bd6f5d9e2835a899301988a1a87fcbfb35e4..598d5fcdb3c6103fcdb91d0f57aaee6fd6c3be06 100644 (file)
@@ -2900,7 +2900,8 @@ lp_build_sample_soa_code(struct gallivm_state *gallivm,
 #define LP_SAMPLER_FUNC_EXPLICITDERIVS  (1 << 2)
 #define LP_SAMPLER_FUNC_SHADOW          (1 << 3)
 #define LP_SAMPLER_FUNC_OFFSETS         (1 << 4)
-#define LP_SAMPLER_FUNC_LOD_PROPERTY_SHIFT 5
+#define LP_SAMPLER_FUNC_FETCH           (1 << 5)
+#define LP_SAMPLER_FUNC_LOD_PROPERTY_SHIFT 6
 
 
 static inline void
@@ -3091,6 +3092,9 @@ lp_build_sample_soa_func(struct gallivm_state *gallivm,
    else if (derivs) {
       sampler_bits |= LP_SAMPLER_FUNC_EXPLICITDERIVS;
    }
+   if (is_fetch) {
+      sampler_bits |= LP_SAMPLER_FUNC_FETCH;
+   }
    sampler_bits |= lod_property << LP_SAMPLER_FUNC_LOD_PROPERTY_SHIFT;
 
    util_snprintf(func_name, sizeof(func_name), "texfunc_res_%d_sam_%d_%x",
@@ -3142,7 +3146,6 @@ lp_build_sample_soa_func(struct gallivm_state *gallivm,
          }
       }
 
-      ret_type = LLVMVoidTypeInContext(gallivm->context);
       val_type[0] = val_type[1] = val_type[2] = val_type[3] =
          lp_build_vec_type(gallivm, type);
       ret_type = LLVMStructTypeInContext(gallivm->context, val_type, 4, 0);