diff options
author | Marek Olšák <[email protected]> | 2018-08-20 21:33:24 -0400 |
---|---|---|
committer | Marek Olšák <[email protected]> | 2018-09-04 14:01:43 -0400 |
commit | 725e8ad5590749ca2fa4bd89e1e8007fd20b114e (patch) | |
tree | edd8ca4c10bcb14bd6428cc17cbf28435747e5d8 /src/mesa/state_tracker | |
parent | d49904085a1c4054da247a54d3787ec34ef7c900 (diff) |
st/mesa: help fix stencil border color for GL_DEPTH_STENCIL textures
GL_STENCIL_INDEX uses GL_INTENSITY for the border color, which is nicer
to hardware that doesn't read the stencil border value from the X channel.
This fixes a bunch of dEQP tests on Vega & Raven.
Cc: 18.1 18.2 <[email protected]>
Diffstat (limited to 'src/mesa/state_tracker')
-rw-r--r-- | src/mesa/state_tracker/st_atom_sampler.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/mesa/state_tracker/st_atom_sampler.c b/src/mesa/state_tracker/st_atom_sampler.c index 289856cd72d..27e4da31581 100644 --- a/src/mesa/state_tracker/st_atom_sampler.c +++ b/src/mesa/state_tracker/st_atom_sampler.c @@ -163,6 +163,9 @@ st_convert_sampler(const struct st_context *st, const GLboolean is_integer = texobj->_IsIntegerFormat; GLenum texBaseFormat = _mesa_base_tex_image(texobj)->_BaseFormat; + if (texobj->StencilSampling) + texBaseFormat = GL_STENCIL_INDEX; + if (st->apply_texture_swizzle_to_border_color) { const struct st_texture_object *stobj = st_texture_object_const(texobj); /* XXX: clean that up to not use the sampler view at all */ |