diff options
author | Francisco Jerez <currojerez@riseup.net> | 2015-08-17 01:53:48 +0300 |
---|---|---|
committer | Francisco Jerez <currojerez@riseup.net> | 2015-08-20 12:26:53 +0300 |
commit | b97d8c95a91773dc002e3ba42bd02e84a00eada3 (patch) | |
tree | 59bca617dba2a9a513b5d9827338813d8c5ad1bb /src/mesa/drivers/dri/i965/brw_wm_surface_state.c | |
parent | 47e0d5b9b28b0753adda70cbfb3ad111ba6169a8 (diff) | |
download | external_mesa3d-b97d8c95a91773dc002e3ba42bd02e84a00eada3.zip external_mesa3d-b97d8c95a91773dc002e3ba42bd02e84a00eada3.tar.gz external_mesa3d-b97d8c95a91773dc002e3ba42bd02e84a00eada3.tar.bz2 |
mesa: Don't lose track of the shader image layer originally specified by the user.
The spec requires that all layers of the image starting from the 0-th
are bound to the image unit regardless of the Layer parameter when
Layered is true, so I was setting gl_image_unit::Layer to zero in that
case for the convenience of the driver back-end. However the
ES31-CTS.shader_image_load_store.basic-api-bind conformance test
checks that the layer value returned by glGetInteger is the same that
was originally specified, regardless of the value of layered. Rename
Layer to _Layer as is usual for other derived state and keep track of
the original layer value as gl_image_unit::Layer.
Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
Diffstat (limited to 'src/mesa/drivers/dri/i965/brw_wm_surface_state.c')
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_wm_surface_state.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_wm_surface_state.c b/src/mesa/drivers/dri/i965/brw_wm_surface_state.c index 7e9a52c..8213f4e 100644 --- a/src/mesa/drivers/dri/i965/brw_wm_surface_state.c +++ b/src/mesa/drivers/dri/i965/brw_wm_surface_state.c @@ -1117,7 +1117,7 @@ update_texture_image_param(struct brw_context *brw, minify(mt->logical_depth0, u->Level) : mt->logical_depth0); - intel_miptree_get_image_offset(mt, u->Level, u->Layer, + intel_miptree_get_image_offset(mt, u->Level, u->_Layer, ¶m->offset[0], ¶m->offset[1]); @@ -1202,7 +1202,7 @@ update_image_surface(struct brw_context *brw, access != GL_READ_ONLY); } else { - const unsigned min_layer = obj->MinLayer + u->Layer; + const unsigned min_layer = obj->MinLayer + u->_Layer; const unsigned min_level = obj->MinLevel + u->Level; const unsigned num_layers = (!u->Layered ? 1 : obj->Target == GL_TEXTURE_CUBE_MAP ? 6 : |