[Mesa-dev] [PATCH 19/20] mesa/main/pack_tmp.h: Add float conversion support
Iago Toral Quiroga
itoral at igalia.com
Tue Nov 18 00:44:07 PST 2014
From: Samuel Iglesias Gonsalvez <siglesias at igalia.com>
We will use this in a later patch to refactor _mesa_pack_rgba_span_float.
Signed-off-by: Samuel Iglesias Gonsalvez <siglesias at igalia.com>
---
src/mesa/main/pack_tmp.h | 75 +++++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 74 insertions(+), 1 deletion(-)
diff --git a/src/mesa/main/pack_tmp.h b/src/mesa/main/pack_tmp.h
index 0d4eb38..c6882db 100644
--- a/src/mesa/main/pack_tmp.h
+++ b/src/mesa/main/pack_tmp.h
@@ -31,6 +31,79 @@ FN_NAME(struct gl_context *ctx,
int i;
switch (dstFormat) {
+#ifdef FLOAT_SRC_CONVERT
+ case GL_RED:
+ for (i=0;i<n;i++)
+ dst[i] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ break;
+ case GL_GREEN:
+ for (i=0;i<n;i++)
+ dst[i] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ break;
+ case GL_BLUE:
+ for (i=0;i<n;i++)
+ dst[i] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ break;
+ case GL_ALPHA:
+ for (i=0;i<n;i++)
+ dst[i] = FLOAT_SRC_CONVERT(rgba[i][ACOMP]);
+ break;
+ case GL_LUMINANCE:
+ for (i=0;i<n;i++)
+ dst[i] = FLOAT_SRC_CONVERT(luminance[i]);
+ break;
+ case GL_LUMINANCE_ALPHA:
+ for (i=0;i<n;i++) {
+ dst[i*2+0] = FLOAT_SRC_CONVERT(luminance[i]);
+ dst[i*2+1] = FLOAT_SRC_CONVERT(rgba[i][ACOMP]);
+ }
+ break;
+ case GL_RG:
+ for (i=0;i<n;i++) {
+ dst[i*2+0] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ dst[i*2+1] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ }
+ break;
+ case GL_RGB:
+ for (i=0;i<n;i++) {
+ dst[i*3+0] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ dst[i*3+1] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ dst[i*3+2] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ }
+ break;
+ case GL_RGBA:
+ for (i=0;i<n;i++) {
+ dst[i*4+0] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ dst[i*4+1] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ dst[i*4+2] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ dst[i*4+3] = FLOAT_SRC_CONVERT(rgba[i][ACOMP]);
+ }
+ break;
+ case GL_BGR:
+ for (i=0;i<n;i++) {
+ dst[i*3+0] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ dst[i*3+1] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ dst[i*3+2] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ }
+ break;
+ case GL_BGRA:
+ for (i=0;i<n;i++) {
+ dst[i*4+0] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ dst[i*4+1] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ dst[i*4+2] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ dst[i*4+3] = FLOAT_SRC_CONVERT(rgba[i][ACOMP]);
+ }
+ break;
+ case GL_ABGR_EXT:
+ for (i=0;i<n;i++) {
+ dst[i*4+0] = FLOAT_SRC_CONVERT(rgba[i][ACOMP]);
+ dst[i*4+1] = FLOAT_SRC_CONVERT(rgba[i][BCOMP]);
+ dst[i*4+2] = FLOAT_SRC_CONVERT(rgba[i][GCOMP]);
+ dst[i*4+3] = FLOAT_SRC_CONVERT(rgba[i][RCOMP]);
+ }
+ break;
+#endif
+#ifdef SRC_CONVERT
case GL_RED_INTEGER_EXT:
for (i=0;i<n;i++) {
dst[i] = SRC_CONVERT(rgba[i][RCOMP]);
@@ -112,7 +185,7 @@ FN_NAME(struct gl_context *ctx,
dst[i*2+1] = SRC_CONVERT(rgba[i][ACOMP]);
}
break;
-
+#endif
default:
_mesa_problem(ctx,
"Unsupported format (%s)",
--
1.9.1
More information about the mesa-dev
mailing list