diff options
author | Marek Olšák <maraeo@gmail.com> | 2013-05-10 02:03:15 +0200 |
---|---|---|
committer | Marek Olšák <maraeo@gmail.com> | 2013-05-15 20:22:48 +0200 |
commit | 639d0f73c137a76ae76501da4e09cdd0e33d4c37 (patch) | |
tree | 7130a53dc90ae864bb3f9a504fbbbd9441766b4d /src/mesa/state_tracker/st_format.h | |
parent | 5a3fac4d2667b5d46058564151142fec158f5f82 (diff) | |
download | external_mesa3d-639d0f73c137a76ae76501da4e09cdd0e33d4c37.zip external_mesa3d-639d0f73c137a76ae76501da4e09cdd0e33d4c37.tar.gz external_mesa3d-639d0f73c137a76ae76501da4e09cdd0e33d4c37.tar.bz2 |
st/mesa: handle texture_from_pixmap and other surface-based textures correctly
There were 2 issues with it:
1) The texture format which should be used for texturing was only set
in gl_texture_image::TexFormat, which wasn't used for sampler views.
2) Textures are sometimes reallocated under some circumstances
in st_finalize_texture, which is unacceptable if the texture comes
from a window system.
The issues are resolved as follows:
1) If surface_based is true (texture_from_pixmap, etc.), store the format
in a new variable st_texture_object::surface_format.
2) Don't reallocate a surface-based texture in st_finalize_texture.
Also don't use st_ChooseTextureFormat is st_context_teximage, because
the format is dictated by the caller.
This fixes the glx-tfp piglit test.
Reviewed-by: Adam Jackson <ajax@redhat.com>
Diffstat (limited to 'src/mesa/state_tracker/st_format.h')
-rw-r--r-- | src/mesa/state_tracker/st_format.h | 4 |
1 files changed, 0 insertions, 4 deletions
diff --git a/src/mesa/state_tracker/st_format.h b/src/mesa/state_tracker/st_format.h index 0a1c18d..6e97dcb 100644 --- a/src/mesa/state_tracker/st_format.h +++ b/src/mesa/state_tracker/st_format.h @@ -70,10 +70,6 @@ size_t st_QuerySamplesForFormat(struct gl_context *ctx, GLenum target, GLenum internalFormat, int samples[16]); -/* can we use a sampler view to translate these formats - only used to make TFP so far */ -extern GLboolean -st_sampler_compat_formats(enum pipe_format format1, enum pipe_format format2); extern void |