Przeglądaj źródła

st/mesa: Fix assertions for copying texture image to finalized miptree.

The layer dimension of array textures is not subject to mipmap minification.
OTOH we were missing an assertion for the depth dimension.

Fixes assertion failures with piglit {f,v}s-textureSize-sampler1DArrayShadow.
For some reason, they only resulted in piglit 'warn' results for me, not
failures.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=56211

NOTE: This is a candidate for the stable branches.

Signed-off-by: Michel Dänzer <michel.daenzer@amd.com>
Reviewed-by: Brian Paul <brianp@vmware.com>
Tested-by: Andreas Boll <andreas.boll.dev@gmail.com>
tags/gles3-fmt-v1
Michel Dänzer 13 lat temu
rodzic
commit
eee1ff423c
1 zmienionych plików z 4 dodań i 1 usunięć
  1. 4
    1
      src/mesa/state_tracker/st_cb_texture.c

+ 4
- 1
src/mesa/state_tracker/st_cb_texture.c Wyświetl plik

@@ -1120,7 +1120,10 @@ copy_image_data_to_texture(struct st_context *st,

assert(src_level <= stImage->pt->last_level);
assert(u_minify(stImage->pt->width0, src_level) == stImage->base.Width);
assert(u_minify(stImage->pt->height0, src_level) == stImage->base.Height);
assert(stImage->pt->target == PIPE_TEXTURE_1D_ARRAY ||
u_minify(stImage->pt->height0, src_level) == stImage->base.Height);
assert(stImage->pt->target == PIPE_TEXTURE_2D_ARRAY ||
u_minify(stImage->pt->depth0, src_level) == stImage->base.Depth);

st_texture_image_copy(st->pipe,
stObj->pt, dstLevel, /* dest texture, level */

Ładowanie…
Anuluj
Zapisz