summaryrefslogtreecommitdiffstats
path: root/src/mesa/state_tracker/st_format.h
diff options
context:
space:
mode:
authorMarek Olšák <maraeo@gmail.com>2013-05-10 02:03:15 +0200
committerMarek Olšák <maraeo@gmail.com>2013-05-15 20:22:48 +0200
commit639d0f73c137a76ae76501da4e09cdd0e33d4c37 (patch)
tree7130a53dc90ae864bb3f9a504fbbbd9441766b4d /src/mesa/state_tracker/st_format.h
parent5a3fac4d2667b5d46058564151142fec158f5f82 (diff)
downloadexternal_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.h4
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