summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Airlie <airlied@redhat.com>2015-04-08 10:00:27 +1000
committerDave Airlie <airlied@redhat.com>2015-04-14 08:04:41 +1000
commitcc5860e40787b3afe36856674f028e830685271b (patch)
tree0424ae9decd5d372e46b963bb132c77964568c7b
parent5ed79312ed99f3b141c35569b9767f82f5ba0a93 (diff)
downloadexternal_mesa3d-cc5860e40787b3afe36856674f028e830685271b.zip
external_mesa3d-cc5860e40787b3afe36856674f028e830685271b.tar.gz
external_mesa3d-cc5860e40787b3afe36856674f028e830685271b.tar.bz2
st/mesa: align cube map arrays layers
We create textures internally for texsubimage, and we use the values from sub image to create a new texture, however we don't align these to valid sizes, and cube map arrays must have an array size aligned to 6. This fixes texsubimage cube_map_array on CAYMAN at least, (it was causing GPU hang and bad values), it probably also fixes it on radeonsi and evergreen. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=89957 Tested-by: Tom Stellard <thomas.stellard@amd.com> Cc: mesa-stable@lists.freedesktop.org Reviewed-by: Marek Olšák <marek.olsak@amd.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r--src/mesa/state_tracker/st_texture.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/mesa/state_tracker/st_texture.c b/src/mesa/state_tracker/st_texture.c
index ca7c83c..de4a6eb 100644
--- a/src/mesa/state_tracker/st_texture.c
+++ b/src/mesa/state_tracker/st_texture.c
@@ -177,7 +177,7 @@ st_gl_texture_dims_to_pipe_dims(GLenum texture,
*widthOut = widthIn;
*heightOut = heightIn;
*depthOut = 1;
- *layersOut = depthIn;
+ *layersOut = util_align_npot(depthIn, 6);
break;
default:
assert(0 && "Unexpected texture in st_gl_texture_dims_to_pipe_dims()");