From: Brian Paul Date: Mon, 1 Apr 2013 22:44:50 +0000 (-0600) Subject: gallium/hud: try L8 texture for font if I8 format isn't supported X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a9ae7e9c28335e5c0822fdd7e456780e5ea01d45;p=mesa.git gallium/hud: try L8 texture for font if I8 format isn't supported --- diff --git a/src/gallium/auxiliary/hud/font.c b/src/gallium/auxiliary/hud/font.c index 5c4a4d07e5d..6747874eedc 100644 --- a/src/gallium/auxiliary/hud/font.c +++ b/src/gallium/auxiliary/hud/font.c @@ -377,17 +377,26 @@ util_font_create_fixed_8x13(struct pipe_context *pipe, struct pipe_resource tex_templ, *tex; struct pipe_transfer *transfer = NULL; char *map; + enum pipe_format tex_format; int i; - if (!screen->is_format_supported(screen, PIPE_FORMAT_I8_UNORM, - PIPE_TEXTURE_RECT, 0, - PIPE_BIND_SAMPLER_VIEW)) { + if (screen->is_format_supported(screen, PIPE_FORMAT_I8_UNORM, + PIPE_TEXTURE_RECT, 0, + PIPE_BIND_SAMPLER_VIEW)) { + tex_format = PIPE_FORMAT_I8_UNORM; + } + else if (screen->is_format_supported(screen, PIPE_FORMAT_L8_UNORM, + PIPE_TEXTURE_RECT, 0, + PIPE_BIND_SAMPLER_VIEW)) { + tex_format = PIPE_FORMAT_L8_UNORM; + } + else { return FALSE; } memset(&tex_templ, 0, sizeof(tex_templ)); tex_templ.target = PIPE_TEXTURE_RECT; - tex_templ.format = PIPE_FORMAT_I8_UNORM; + tex_templ.format = tex_format; tex_templ.width0 = 128; tex_templ.height0 = 256; tex_templ.depth0 = 1;