diff options
author | Topi Pohjolainen <[email protected]> | 2016-11-26 18:03:56 +0200 |
---|---|---|
committer | Topi Pohjolainen <[email protected]> | 2017-01-27 08:57:26 +0200 |
commit | a283a4ee2fba6c8efa4f4e4eeea6b3d7b21df4d0 (patch) | |
tree | f6729e86b366ace5de0dfd91a8cc2b10fdb284f3 | |
parent | 542bb8504991c91d50f2b0302c2d04f58003030f (diff) |
meta: Refactor texture format translation
Reviewed-by: Anuj Phogat <[email protected]>
Reviewed-by: Kenneth Graunke <[email protected]>
Signed-off-by: Topi Pohjolainen <[email protected]>
-rw-r--r-- | src/mesa/drivers/common/meta_tex_subimage.c | 9 | ||||
-rw-r--r-- | src/mesa/main/glformats.c | 15 | ||||
-rw-r--r-- | src/mesa/main/glformats.h | 4 |
3 files changed, 22 insertions, 6 deletions
diff --git a/src/mesa/drivers/common/meta_tex_subimage.c b/src/mesa/drivers/common/meta_tex_subimage.c index 703efcd669b..b8c422bfb72 100644 --- a/src/mesa/drivers/common/meta_tex_subimage.c +++ b/src/mesa/drivers/common/meta_tex_subimage.c @@ -72,7 +72,8 @@ create_texture_for_pbo(struct gl_context *ctx, const struct gl_pixelstore_attrib *packing, struct gl_buffer_object **tmp_pbo, GLuint *tmp_tex) { - uint32_t pbo_format; + const mesa_format pbo_format = + _mesa_tex_format_from_format_and_type(ctx, format, type); GLenum internal_format; unsigned row_stride; struct gl_buffer_object *buffer_obj; @@ -85,11 +86,7 @@ create_texture_for_pbo(struct gl_context *ctx, packing->Invert) return NULL; - pbo_format = _mesa_format_from_format_and_type(format, type); - if (_mesa_format_is_mesa_array_format(pbo_format)) - pbo_format = _mesa_format_from_array_format(pbo_format); - - if (!pbo_format || !ctx->TextureFormatSupported[pbo_format]) + if (pbo_format == MESA_FORMAT_NONE) return NULL; /* Account for SKIP_PIXELS, SKIP_ROWS, ALIGNMENT, and SKIP_IMAGES */ diff --git a/src/mesa/main/glformats.c b/src/mesa/main/glformats.c index a95909c9bc9..4f240206ff4 100644 --- a/src/mesa/main/glformats.c +++ b/src/mesa/main/glformats.c @@ -3632,6 +3632,21 @@ _mesa_format_from_format_and_type(GLenum format, GLenum type) unreachable("Unsupported format"); } +uint32_t +_mesa_tex_format_from_format_and_type(const struct gl_context *ctx, + GLenum gl_format, GLenum type) +{ + mesa_format format = _mesa_format_from_format_and_type(gl_format, type); + + if (_mesa_format_is_mesa_array_format(format)) + format = _mesa_format_from_array_format(format); + + if (format == MESA_FORMAT_NONE || !ctx->TextureFormatSupported[format]) + return MESA_FORMAT_NONE; + + return format; +} + /** * Returns true if \p internal_format is a sized internal format that * is marked "Color Renderable" in Table 8.10 of the ES 3.2 specification. diff --git a/src/mesa/main/glformats.h b/src/mesa/main/glformats.h index 763307f2593..5c9d8263ed1 100644 --- a/src/mesa/main/glformats.h +++ b/src/mesa/main/glformats.h @@ -148,6 +148,10 @@ _mesa_base_tex_format(const struct gl_context *ctx, GLint internalFormat ); extern uint32_t _mesa_format_from_format_and_type(GLenum format, GLenum type); +extern uint32_t +_mesa_tex_format_from_format_and_type(const struct gl_context *ctx, + GLenum gl_format, GLenum type); + extern bool _mesa_is_es3_color_renderable(GLenum internal_format); |