[Mesa-dev] [PATCH v4 5/7] mesa: update external textures when (re-)binding
Marek Olšák
maraeo at gmail.com
Sat Jan 14 13:49:04 UTC 2017
Reviewed-by: Marek Olšák <marek.olsak at amd.com>
On Dec 6, 2016 5:17 PM, "Philipp Zabel" <p.zabel at pengutronix.de> wrote:
> To comply with the requirement from the GL_OES_EGL_image_external
> extension that a call to glBindTexture guarantees that all further
> sampling will return values that correspond to the values in the
> external texture at or after the time that glBindTexture was called,
> do not bail out early from mesa_BindTextures if the target is
> external.
> This will later allow the state tracker to instruct the pipe driver
> to invalidate internal resources derived from the external texture.
>
> Signed-off-by: Philipp Zabel <p.zabel at pengutronix.de>
> ---
> src/mesa/main/texobj.c | 5 +++--
> 1 file changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/src/mesa/main/texobj.c b/src/mesa/main/texobj.c
> index e5b7070..25b959d 100644
> --- a/src/mesa/main/texobj.c
> +++ b/src/mesa/main/texobj.c
> @@ -1619,9 +1619,10 @@ bind_texture(struct gl_context *ctx,
> assert(targetIndex < NUM_TEXTURE_TARGETS);
>
> /* Check if this texture is only used by this context and is already
> bound.
> - * If so, just return.
> + * If so, just return. For GL_OES_image_external, rebinding the texture
> + * always must invalidate cached resources.
> */
> - {
> + if (targetIndex != TEXTURE_EXTERNAL_INDEX) {
> bool early_out;
> mtx_lock(&ctx->Shared->Mutex);
> early_out = ((ctx->Shared->RefCount == 1)
> --
> 2.10.2
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20170114/2235a1d8/attachment.html>
More information about the mesa-dev
mailing list