aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJason Ekstrand <[email protected]>2015-11-06 14:49:15 -0800
committerJason Ekstrand <[email protected]>2015-11-06 15:09:57 -0800
commit5ba281e794fbc215adfedd44b73a628cdf39a513 (patch)
tree6cbb217af5819d9b3b39902eac41939cafa55f19 /src
parent220261a0c9d4f08e060f02d9cc61219360c2d3f9 (diff)
nir/spirv: Add a helper for determining if a block is externally visable
Diffstat (limited to 'src')
-rw-r--r--src/glsl/nir/spirv_to_nir.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/glsl/nir/spirv_to_nir.c b/src/glsl/nir/spirv_to_nir.c
index 7c9567dd8b7..fc85c19a7a7 100644
--- a/src/glsl/nir/spirv_to_nir.c
+++ b/src/glsl/nir/spirv_to_nir.c
@@ -1199,6 +1199,14 @@ static nir_ssa_def *vtn_vector_extract_dynamic(struct vtn_builder *b,
nir_ssa_def *src,
nir_ssa_def *index);
+static bool
+variable_is_external_block(nir_variable *var)
+{
+ return var->interface_type &&
+ (var->data.mode == nir_var_uniform ||
+ var->data.mode == nir_var_shader_storage);
+}
+
static struct vtn_ssa_value *
vtn_variable_load(struct vtn_builder *b, nir_deref_var *src,
struct vtn_type *src_type)
@@ -1206,7 +1214,7 @@ vtn_variable_load(struct vtn_builder *b, nir_deref_var *src,
nir_deref *src_tail = get_deref_tail(src);
struct vtn_ssa_value *val;
- if (src->var->interface_type && src->var->data.mode == nir_var_uniform)
+ if (variable_is_external_block(src->var))
val = vtn_block_load(b, src, src_type, src_tail);
else
val = _vtn_variable_load(b, src, src_tail);
@@ -1549,7 +1557,8 @@ vtn_handle_variables(struct vtn_builder *b, SpvOp opcode,
* actually access the variable, so we need to keep around the original
* type of the variable.
*/
- if (base->var->interface_type && base->var->data.mode == nir_var_uniform)
+
+ if (variable_is_external_block(base->var))
val->deref_type = vtn_value(b, w[3], vtn_value_type_deref)->deref_type;
else
val->deref_type = deref_type;