<div dir="ltr">Reviewed-by: Jason Ekstrand <<a href="mailto:jason.ekstrand@intel.com">jason.ekstrand@intel.com</a>><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Sep 15, 2014 at 11:28 PM, Dave Airlie <span dir="ltr"><<a href="mailto:airlied@gmail.com" target="_blank">airlied@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">From: Richard Sandiford <<a href="mailto:rsandifo@linux.vnet.ibm.com">rsandifo@linux.vnet.ibm.com</a>><br>
<br>
The associated UNORM format already existed.<br>
<br>
This means that each LnAn format has a reversed counterpart,<br>
which is necessary for handling big-endian mesa<->gallium mappings.<br>
<br>
[airlied: rebased onto current master]<br>
<br>
Signed-off-by: Richard Sandiford <<a href="mailto:rsandifo@linux.vnet.ibm.com">rsandifo@linux.vnet.ibm.com</a>><br>
Reviewed-by: Brian Paul <<a href="mailto:brianp@vmware.com">brianp@vmware.com</a>><br>
Signed-off-by: Dave Airlie <<a href="mailto:airlied@redhat.com">airlied@redhat.com</a>><br>
---<br>
src/mesa/drivers/dri/i965/brw_surface_formats.c | 2 ++<br>
src/mesa/main/format_pack.c | 37 +++++++++++++++++++++++++<br>
src/mesa/main/format_unpack.c | 29 +++++++++++++++++++<br>
src/mesa/main/formats.c | 10 +++++++<br>
src/mesa/main/formats.csv | 2 ++<br>
src/mesa/main/formats.h | 2 ++<br>
src/mesa/main/texformat.c | 3 ++<br>
src/mesa/swrast/s_texfetch.c | 2 ++<br>
src/mesa/swrast/s_texfetch_tmp.h | 24 ++++++++++++++++<br>
9 files changed, 111 insertions(+)<br>
<br>
diff --git a/src/mesa/drivers/dri/i965/brw_surface_formats.c b/src/mesa/drivers/dri/i965/brw_surface_formats.c<br>
index 974f2df..b726c27 100644<br>
--- a/src/mesa/drivers/dri/i965/brw_surface_formats.c<br>
+++ b/src/mesa/drivers/dri/i965/brw_surface_formats.c<br>
@@ -371,6 +371,7 @@ brw_format_for_mesa_format(mesa_format mesa_format)<br>
[MESA_FORMAT_R8G8B8A8_SRGB] = BRW_SURFACEFORMAT_R8G8B8A8_UNORM_SRGB,<br>
[MESA_FORMAT_L_SRGB8] = BRW_SURFACEFORMAT_L8_UNORM_SRGB,<br>
[MESA_FORMAT_L8A8_SRGB] = BRW_SURFACEFORMAT_L8A8_UNORM_SRGB,<br>
+ [MESA_FORMAT_A8L8_SRGB] = 0,<br>
[MESA_FORMAT_SRGB_DXT1] = BRW_SURFACEFORMAT_DXT1_RGB_SRGB,<br>
[MESA_FORMAT_SRGBA_DXT1] = BRW_SURFACEFORMAT_BC1_UNORM_SRGB,<br>
[MESA_FORMAT_SRGBA_DXT3] = BRW_SURFACEFORMAT_BC2_UNORM_SRGB,<br>
@@ -495,6 +496,7 @@ brw_format_for_mesa_format(mesa_format mesa_format)<br>
[MESA_FORMAT_A_SNORM8] = 0,<br>
[MESA_FORMAT_L_SNORM8] = 0,<br>
[MESA_FORMAT_L8A8_SNORM] = 0,<br>
+ [MESA_FORMAT_A8L8_SNORM] = 0,<br>
[MESA_FORMAT_I_SNORM8] = 0,<br>
[MESA_FORMAT_A_SNORM16] = 0,<br>
[MESA_FORMAT_L_SNORM16] = 0,<br>
diff --git a/src/mesa/main/format_pack.c b/src/mesa/main/format_pack.c<br>
index 6cbf859..231fd6c 100644<br>
--- a/src/mesa/main/format_pack.c<br>
+++ b/src/mesa/main/format_pack.c<br>
@@ -1129,6 +1129,16 @@ pack_ubyte_L8A8_SRGB(const GLubyte src[4], void *dst)<br>
*d = PACK_COLOR_88(src[ACOMP], l);<br>
}<br>
<br>
+/* MESA_FORMAT_A8L8_SRGB */<br>
+<br>
+static void<br>
+pack_ubyte_A8L8_SRGB(const GLubyte src[4], void *dst)<br>
+{<br>
+ GLushort *d = ((GLushort *) dst);<br>
+ GLubyte l = util_format_linear_to_srgb_8unorm(src[RCOMP]);<br>
+ *d = PACK_COLOR_88(l, src[ACOMP]);<br>
+}<br>
+<br>
static void<br>
pack_float_L8A8_SRGB(const GLfloat src[4], void *dst)<br>
{<br>
@@ -1138,6 +1148,15 @@ pack_float_L8A8_SRGB(const GLfloat src[4], void *dst)<br>
*d = PACK_COLOR_88(a, l);<br>
}<br>
<br>
+static void<br>
+pack_float_A8L8_SRGB(const GLfloat src[4], void *dst)<br>
+{<br>
+ GLushort *d = ((GLushort *) dst);<br>
+ GLubyte a, l = util_format_linear_float_to_srgb_8unorm(src[RCOMP]);<br>
+ CLAMPED_FLOAT_TO_UBYTE(a, src[ACOMP]);<br>
+ *d = PACK_COLOR_88(l, a);<br>
+}<br>
+<br>
<br>
/* MESA_FORMAT_RGBA_FLOAT32 */<br>
<br>
@@ -1563,6 +1582,20 @@ pack_float_L8A8_SNORM(const GLfloat src[4], void *dst)<br>
<br>
<br>
/*<br>
+ * MESA_FORMAT_A8L8_SNORM<br>
+ */<br>
+<br>
+static void<br>
+pack_float_A8L8_SNORM(const GLfloat src[4], void *dst)<br>
+{<br>
+ GLushort *d = (GLushort *) dst;<br>
+ GLbyte l = FLOAT_TO_BYTE(CLAMP(src[RCOMP], -1.0f, 1.0f));<br>
+ GLbyte a = FLOAT_TO_BYTE(CLAMP(src[ACOMP], -1.0f, 1.0f));<br>
+ *d = (l << 8) | a;<br>
+}<br>
+<br>
+<br>
+/*<br>
* MESA_FORMAT_A_SNORM16<br>
*/<br>
<br>
@@ -1936,6 +1969,7 @@ _mesa_get_pack_ubyte_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_R8G8B8A8_SRGB] = pack_ubyte_R8G8B8A8_SRGB;<br>
table[MESA_FORMAT_L_SRGB8] = pack_ubyte_L_SRGB8;<br>
table[MESA_FORMAT_L8A8_SRGB] = pack_ubyte_L8A8_SRGB;<br>
+ table[MESA_FORMAT_A8L8_SRGB] = pack_ubyte_A8L8_SRGB;<br>
/* n/a */<br>
table[MESA_FORMAT_SRGB_DXT1] = NULL; /* pack_ubyte_SRGB_DXT1; */<br>
table[MESA_FORMAT_SRGBA_DXT1] = NULL; /* pack_ubyte_SRGBA_DXT1; */<br>
@@ -1989,6 +2023,7 @@ _mesa_get_pack_ubyte_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_A_SNORM8] = NULL;<br>
table[MESA_FORMAT_L_SNORM8] = NULL;<br>
table[MESA_FORMAT_L8A8_SNORM] = NULL;<br>
+ table[MESA_FORMAT_A8L8_SNORM] = NULL;<br>
table[MESA_FORMAT_I_SNORM8] = NULL;<br>
table[MESA_FORMAT_A_SNORM16] = NULL;<br>
table[MESA_FORMAT_L_SNORM16] = NULL;<br>
@@ -2099,6 +2134,7 @@ _mesa_get_pack_float_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_R8G8B8A8_SRGB] = pack_float_R8G8B8A8_SRGB;<br>
table[MESA_FORMAT_L_SRGB8] = pack_float_L_SRGB8;<br>
table[MESA_FORMAT_L8A8_SRGB] = pack_float_L8A8_SRGB;<br>
+ table[MESA_FORMAT_A8L8_SRGB] = pack_float_A8L8_SRGB;<br>
<br>
/* n/a */<br>
table[MESA_FORMAT_SRGB_DXT1] = NULL;<br>
@@ -2153,6 +2189,7 @@ _mesa_get_pack_float_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_A_SNORM8] = pack_float_A_SNORM8;<br>
table[MESA_FORMAT_L_SNORM8] = pack_float_L_SNORM8;<br>
table[MESA_FORMAT_L8A8_SNORM] = pack_float_L8A8_SNORM;<br>
+ table[MESA_FORMAT_A8L8_SNORM] = pack_float_A8L8_SNORM;<br>
table[MESA_FORMAT_I_SNORM8] = pack_float_L_SNORM8; /* reused */<br>
table[MESA_FORMAT_A_SNORM16] = pack_float_A_SNORM16;<br>
table[MESA_FORMAT_L_SNORM16] = pack_float_L_SNORM16;<br>
diff --git a/src/mesa/main/format_unpack.c b/src/mesa/main/format_unpack.c<br>
index b84ed02..eed92d8 100644<br>
--- a/src/mesa/main/format_unpack.c<br>
+++ b/src/mesa/main/format_unpack.c<br>
@@ -809,6 +809,19 @@ unpack_L8A8_SRGB(const void *src, GLfloat dst[][4], GLuint n)<br>
}<br>
<br>
static void<br>
+unpack_A8L8_SRGB(const void *src, GLfloat dst[][4], GLuint n)<br>
+{<br>
+ const GLushort *s = (const GLushort *) src;<br>
+ GLuint i;<br>
+ for (i = 0; i < n; i++) {<br>
+ dst[i][RCOMP] =<br>
+ dst[i][GCOMP] =<br>
+ dst[i][BCOMP] = util_format_srgb_8unorm_to_linear_float(s[i] >> 8);<br>
+ dst[i][ACOMP] = UBYTE_TO_FLOAT(s[i] & 0xff); /* linear! */<br>
+ }<br>
+}<br>
+<br>
+static void<br>
unpack_SRGB_DXT1(const void *src, GLfloat dst[][4], GLuint n)<br>
{<br>
}<br>
@@ -1965,6 +1978,20 @@ unpack_L8A8_SNORM(const void *src, GLfloat dst[][4], GLuint n)<br>
}<br>
}<br>
<br>
+<br>
+static void<br>
+unpack_A8L8_SNORM(const void *src, GLfloat dst[][4], GLuint n)<br>
+{<br>
+ const GLshort *s = ((const GLshort *) src);<br>
+ GLuint i;<br>
+ for (i = 0; i < n; i++) {<br>
+ dst[i][RCOMP] =<br>
+ dst[i][GCOMP] =<br>
+ dst[i][BCOMP] = BYTE_TO_FLOAT_TEX( (GLbyte) (s[i] >> 8) );<br>
+ dst[i][ACOMP] = BYTE_TO_FLOAT_TEX( (GLbyte) (s[i] & 0xff) );<br>
+ }<br>
+}<br>
+<br>
static void<br>
unpack_I_SNORM8(const void *src, GLfloat dst[][4], GLuint n)<br>
{<br>
@@ -2364,6 +2391,7 @@ get_unpack_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_R8G8B8A8_SRGB] = unpack_R8G8B8A8_SRGB;<br>
table[MESA_FORMAT_L_SRGB8] = unpack_L_SRGB8;<br>
table[MESA_FORMAT_L8A8_SRGB] = unpack_L8A8_SRGB;<br>
+ table[MESA_FORMAT_A8L8_SRGB] = unpack_A8L8_SRGB;<br>
table[MESA_FORMAT_SRGB_DXT1] = unpack_SRGB_DXT1;<br>
table[MESA_FORMAT_SRGBA_DXT1] = unpack_SRGBA_DXT1;<br>
table[MESA_FORMAT_SRGBA_DXT3] = unpack_SRGBA_DXT3;<br>
@@ -2483,6 +2511,7 @@ get_unpack_rgba_function(mesa_format format)<br>
table[MESA_FORMAT_A_SNORM8] = unpack_A_SNORM8;<br>
table[MESA_FORMAT_L_SNORM8] = unpack_L_SNORM8;<br>
table[MESA_FORMAT_L8A8_SNORM] = unpack_L8A8_SNORM;<br>
+ table[MESA_FORMAT_A8L8_SNORM] = unpack_A8L8_SNORM;<br>
table[MESA_FORMAT_I_SNORM8] = unpack_I_SNORM8;<br>
table[MESA_FORMAT_A_SNORM16] = unpack_A_SNORM16;<br>
table[MESA_FORMAT_L_SNORM16] = unpack_L_SNORM16;<br>
diff --git a/src/mesa/main/formats.c b/src/mesa/main/formats.c<br>
index db22a45..8fd36a0 100644<br>
--- a/src/mesa/main/formats.c<br>
+++ b/src/mesa/main/formats.c<br>
@@ -360,6 +360,7 @@ _mesa_get_format_color_encoding(mesa_format format)<br>
case MESA_FORMAT_R8G8B8A8_SRGB:<br>
case MESA_FORMAT_L_SRGB8:<br>
case MESA_FORMAT_L8A8_SRGB:<br>
+ case MESA_FORMAT_A8L8_SRGB:<br>
case MESA_FORMAT_SRGB_DXT1:<br>
case MESA_FORMAT_SRGBA_DXT1:<br>
case MESA_FORMAT_SRGBA_DXT3:<br>
@@ -428,6 +429,9 @@ _mesa_get_srgb_format_linear(mesa_format format)<br>
case MESA_FORMAT_L8A8_SRGB:<br>
format = MESA_FORMAT_L8A8_UNORM;<br>
break;<br>
+ case MESA_FORMAT_A8L8_SRGB:<br>
+ format = MESA_FORMAT_A8L8_UNORM;<br>
+ break;<br>
case MESA_FORMAT_SRGB_DXT1:<br>
format = MESA_FORMAT_RGB_DXT1;<br>
break;<br>
@@ -919,6 +923,7 @@ _mesa_format_to_type_and_comps(mesa_format format,<br>
return;<br>
case MESA_FORMAT_R8G8_SNORM:<br>
case MESA_FORMAT_L8A8_SNORM:<br>
+ case MESA_FORMAT_A8L8_SNORM:<br>
*datatype = GL_BYTE;<br>
*comps = 2;<br>
return;<br>
@@ -970,6 +975,7 @@ _mesa_format_to_type_and_comps(mesa_format format,<br>
*comps = 1;<br>
return;<br>
case MESA_FORMAT_L8A8_SRGB:<br>
+ case MESA_FORMAT_A8L8_SRGB:<br>
*datatype = GL_UNSIGNED_BYTE;<br>
*comps = 2;<br>
return;<br>
@@ -1475,6 +1481,7 @@ _mesa_format_matches_format_and_type(mesa_format mesa_format,<br>
case MESA_FORMAT_L8A8_SRGB:<br>
return format == GL_LUMINANCE_ALPHA && type == GL_UNSIGNED_BYTE && littleEndian;<br>
case MESA_FORMAT_A8L8_UNORM:<br>
+ case MESA_FORMAT_A8L8_SRGB:<br>
return GL_FALSE;<br>
<br>
case MESA_FORMAT_L16A16_UNORM:<br>
@@ -1797,6 +1804,9 @@ _mesa_format_matches_format_and_type(mesa_format mesa_format,<br>
case MESA_FORMAT_L8A8_SNORM:<br>
return format == GL_LUMINANCE_ALPHA && type == GL_BYTE &&<br>
littleEndian && !swapBytes;<br>
+ case MESA_FORMAT_A8L8_SNORM:<br>
+ return format == GL_LUMINANCE_ALPHA && type == GL_BYTE &&<br>
+ !littleEndian && !swapBytes;<br>
case MESA_FORMAT_I_SNORM8:<br>
return format == GL_RED && type == GL_BYTE;<br>
case MESA_FORMAT_A_SNORM16:<br>
diff --git a/src/mesa/main/formats.csv b/src/mesa/main/formats.csv<br>
index 4d542b7..b4d16de 100644<br>
--- a/src/mesa/main/formats.csv<br>
+++ b/src/mesa/main/formats.csv<br>
@@ -119,6 +119,7 @@ MESA_FORMAT_G16R16_SNORM , packed, 1, 1, sn16, sn16, ,<br>
MESA_FORMAT_R8G8_SNORM , packed, 1, 1, sn8 , sn8 , , , xy01, rgb<br>
MESA_FORMAT_G8R8_SNORM , packed, 1, 1, sn8 , sn8 , , , yx01, rgb<br>
MESA_FORMAT_L8A8_SNORM , packed, 1, 1, sn8 , sn8 , , , xxxy, rgb<br>
+MESA_FORMAT_A8L8_SNORM , packed, 1, 1, sn8 , sn8 , , , yyyx, rgb<br>
<br>
# Array signed/normalized formats<br>
MESA_FORMAT_A_SNORM8 , array , 1, 1, sn8 , , , , 000x, rgb<br>
@@ -141,6 +142,7 @@ MESA_FORMAT_B8G8R8X8_SRGB , packed, 1, 1, un8 , un8 , un8 , x8<br>
MESA_FORMAT_R8G8B8A8_SRGB , packed, 1, 1, un8 , un8 , un8 , un8 , xyzw, srgb<br>
MESA_FORMAT_R8G8B8X8_SRGB , packed, 1, 1, un8 , un8 , un8 , x8 , xyz1, srgb<br>
MESA_FORMAT_L8A8_SRGB , packed, 1, 1, un8 , un8 , , , xxxy, srgb<br>
+MESA_FORMAT_A8L8_SRGB , packed, 1, 1, un8 , un8 , , , yyyx, srgb<br>
<br>
# Array sRGB formats<br>
MESA_FORMAT_L_SRGB8 , array , 1, 1, un8 , , , , xxx1, srgb<br>
diff --git a/src/mesa/main/formats.h b/src/mesa/main/formats.h<br>
index d6253bf..8671738 100644<br>
--- a/src/mesa/main/formats.h<br>
+++ b/src/mesa/main/formats.h<br>
@@ -265,6 +265,7 @@ typedef enum<br>
MESA_FORMAT_R8G8_SNORM, /* GGGG GGGG RRRR RRRR */<br>
MESA_FORMAT_G8R8_SNORM, /* RRRR RRRR GGGG GGGG */<br>
MESA_FORMAT_L8A8_SNORM, /* AAAA AAAA LLLL LLLL */<br>
+ MESA_FORMAT_A8L8_SNORM, /* LLLL LLLL AAAA AAAA */<br>
<br>
/* Array signed/normalized formats */<br>
MESA_FORMAT_A_SNORM8, /* byte[i] = A */<br>
@@ -287,6 +288,7 @@ typedef enum<br>
MESA_FORMAT_R8G8B8A8_SRGB, /* AAAA AAAA BBBB BBBB GGGG GGGG RRRR RRRR */<br>
MESA_FORMAT_R8G8B8X8_SRGB, /* xxxx xxxx BBBB BBBB GGGG GGGG RRRR RRRR */<br>
MESA_FORMAT_L8A8_SRGB, /* AAAA AAAA LLLL LLLL */<br>
+ MESA_FORMAT_A8L8_SRGB, /* LLLL LLLL AAAA AAAA */<br>
<br>
/* Array sRGB formats */<br>
MESA_FORMAT_L_SRGB8, /* ubyte[i] = L */<br>
diff --git a/src/mesa/main/texformat.c b/src/mesa/main/texformat.c<br>
index 6d3b805..09e307c 100644<br>
--- a/src/mesa/main/texformat.c<br>
+++ b/src/mesa/main/texformat.c<br>
@@ -485,6 +485,7 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,<br>
case GL_LUMINANCE_ALPHA_SNORM:<br>
case GL_LUMINANCE8_ALPHA8_SNORM:<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_L8A8_SNORM);<br>
+ RETURN_IF_SUPPORTED(MESA_FORMAT_A8L8_SNORM);<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_A8B8G8R8_SNORM);<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_R8G8B8A8_SNORM);<br>
break;<br>
@@ -555,6 +556,7 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,<br>
case GL_SLUMINANCE_ALPHA_EXT:<br>
case GL_SLUMINANCE8_ALPHA8_EXT:<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_L8A8_SRGB);<br>
+ RETURN_IF_SUPPORTED(MESA_FORMAT_A8L8_SRGB);<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_B8G8R8A8_SRGB);<br>
break;<br>
case GL_COMPRESSED_SLUMINANCE_EXT:<br>
@@ -563,6 +565,7 @@ _mesa_choose_tex_format(struct gl_context *ctx, GLenum target,<br>
break;<br>
case GL_COMPRESSED_SLUMINANCE_ALPHA_EXT:<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_L8A8_SRGB);<br>
+ RETURN_IF_SUPPORTED(MESA_FORMAT_A8L8_SRGB);<br>
RETURN_IF_SUPPORTED(MESA_FORMAT_B8G8R8A8_SRGB);<br>
break;<br>
case GL_COMPRESSED_SRGB_EXT:<br>
diff --git a/src/mesa/swrast/s_texfetch.c b/src/mesa/swrast/s_texfetch.c<br>
index 38d71ca..dfba190 100644<br>
--- a/src/mesa/swrast/s_texfetch.c<br>
+++ b/src/mesa/swrast/s_texfetch.c<br>
@@ -210,6 +210,7 @@ texfetch_funcs[] =<br>
FETCH_FUNCS(R8G8_SNORM),<br>
FETCH_NULL(G8R8_SNORM),<br>
FETCH_FUNCS(L8A8_SNORM),<br>
+ FETCH_FUNCS(A8L8_SNORM),<br>
<br>
/* Array signed/normalized formats */<br>
FETCH_FUNCS(A_SNORM8),<br>
@@ -232,6 +233,7 @@ texfetch_funcs[] =<br>
FETCH_FUNCS(R8G8B8A8_SRGB),<br>
FETCH_FUNCS(R8G8B8X8_SRGB),<br>
FETCH_FUNCS(L8A8_SRGB),<br>
+ FETCH_FUNCS(A8L8_SRGB),<br>
<br>
/* Array sRGB formats */<br>
FETCH_FUNCS(L_SRGB8),<br>
diff --git a/src/mesa/swrast/s_texfetch_tmp.h b/src/mesa/swrast/s_texfetch_tmp.h<br>
index 3923e2b..81ae045 100644<br>
--- a/src/mesa/swrast/s_texfetch_tmp.h<br>
+++ b/src/mesa/swrast/s_texfetch_tmp.h<br>
@@ -817,6 +817,18 @@ FETCH(L8A8_SRGB)(const struct swrast_texture_image *texImage,<br>
<br>
<br>
static void<br>
+FETCH(A8L8_SRGB)(const struct swrast_texture_image *texImage,<br>
+ GLint i, GLint j, GLint k, GLfloat *texel)<br>
+{<br>
+ const GLushort s = *TEXEL_ADDR(GLushort, texImage, i, j, k, 2);<br>
+ texel[RCOMP] =<br>
+ texel[GCOMP] =<br>
+ texel[BCOMP] = nonlinear_to_linear(s >> 8);<br>
+ texel[ACOMP] = UBYTE_TO_FLOAT(s & 0xff); /* linear */<br>
+}<br>
+<br>
+<br>
+static void<br>
FETCH(RGBA_SINT8)(const struct swrast_texture_image *texImage,<br>
GLint i, GLint j, GLint k, GLfloat *texel)<br>
{<br>
@@ -961,6 +973,18 @@ FETCH(L8A8_SNORM)(const struct swrast_texture_image *texImage,<br>
<br>
<br>
static void<br>
+FETCH(A8L8_SNORM)(const struct swrast_texture_image *texImage,<br>
+ GLint i, GLint j, GLint k, GLfloat *texel)<br>
+{<br>
+ const GLushort s = *TEXEL_ADDR(GLshort, texImage, i, j, k, 1);<br>
+ texel[RCOMP] =<br>
+ texel[GCOMP] =<br>
+ texel[BCOMP] = BYTE_TO_FLOAT_TEX( (GLbyte) (s >> 8) );<br>
+ texel[ACOMP] = BYTE_TO_FLOAT_TEX( (GLbyte) (s & 0xff) );<br>
+}<br>
+<br>
+<br>
+static void<br>
FETCH(X8B8G8R8_SNORM)(const struct swrast_texture_image *texImage,<br>
GLint i, GLint j, GLint k, GLfloat *texel)<br>
{<br>
<span class="HOEnZb"><font color="#888888">--<br>
1.9.3<br>
<br>
_______________________________________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/mesa-dev" target="_blank">http://lists.freedesktop.org/mailman/listinfo/mesa-dev</a><br>
</font></span></blockquote></div><br></div>