On Tue, Jun 26, 2012 at 2:35 PM, Brian Paul <bri...@vmware.com> wrote: > On 06/25/2012 06:34 PM, Jordan Justen wrote: >> >> pack_int_cases_tmp.h is included in two places: >> _mesa_pack_rgba_span_from_ints with GLint rgba[][4] >> and >> _mesa_pack_rgba_span_from_uints with GLuint rgba[][4] >> >> Signed-off-by: Jordan Justen<jordan.l.jus...@intel.com> >> --- >> src/mesa/main/pack.c | 6 + >> src/mesa/main/pack_int_cases_tmp.h | 304 >> ++++++++++++++++++++++++++++++++++++ >> 2 files changed, 310 insertions(+) >> create mode 100644 src/mesa/main/pack_int_cases_tmp.h >> >> diff --git a/src/mesa/main/pack.c b/src/mesa/main/pack.c >> index 9fb8771..613d68b 100644 >> --- a/src/mesa/main/pack.c >> +++ b/src/mesa/main/pack.c >> @@ -530,6 +530,9 @@ _mesa_pack_rgba_span_from_uints(struct gl_context >> *ctx, GLuint n, GLuint rgba[][ >> pack_byte_from_uint_rgba(ctx, dstAddr, dstFormat, rgba, n); >> break; >> >> + /* Packed integer cases */ >> +#include "pack_int_cases_tmp.h" >> + >> default: >> _mesa_problem(ctx, >> "Unsupported type (%s) for format (%s)", >> @@ -615,6 +618,9 @@ _mesa_pack_rgba_span_from_ints(struct gl_context *ctx, >> GLuint n, GLint rgba[][4] >> pack_byte_from_int_rgba(ctx, dstAddr, dstFormat, rgba, n); >> break; >> >> + /* Packed integer cases */ >> +#include "pack_int_cases_tmp.h" >> + >> default: >> _mesa_problem(ctx, >> "Unsupported type (%s) for format (%s)", >> diff --git a/src/mesa/main/pack_int_cases_tmp.h >> b/src/mesa/main/pack_int_cases_tmp.h >> new file mode 100644 >> index 0000000..c1f15e9 >> --- /dev/null >> +++ b/src/mesa/main/pack_int_cases_tmp.h >> @@ -0,0 +1,304 @@ >> +/* >> + * Mesa 3-D graphics library >> + * >> + * Copyright (C) 1999-2008 Brian Paul All Rights Reserved. >> + * Copyright (C) 2009-2010 VMware, Inc. All Rights Reserved. >> + * >> + * Permission is hereby granted, free of charge, to any person obtaining >> a >> + * copy of this software and associated documentation files (the >> "Software"), >> + * to deal in the Software without restriction, including without >> limitation >> + * the rights to use, copy, modify, merge, publish, distribute, >> sublicense, >> + * and/or sell copies of the Software, and to permit persons to whom the >> + * Software is furnished to do so, subject to the following conditions: >> + * >> + * The above copyright notice and this permission notice shall be >> included >> + * in all copies or substantial portions of the Software. >> + * >> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, >> EXPRESS >> + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF >> MERCHANTABILITY, >> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT >> SHALL >> + * THEA AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, >> WHETHER IN >> + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN >> + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE >> SOFTWARE. >> + */ >> + >> +/* >> + * These case statements are used two places: >> + * pack.c:_mesa_pack_rgba_span_from_ints with GLint rgba[][4] >> + * and >> + * pack.c:_mesa_pack_rgba_span_from_uints with GLuint rgba[][4] >> + */ >> + >> + case GL_UNSIGNED_BYTE_3_3_2: >> + if ((dstFormat == GL_RGB) || (dstFormat == GL_RGB_INTEGER)) { >> + GLubyte *dst = (GLubyte *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 7)<< 5) >> + | (CLAMP(rgba[i][GCOMP], 0, 7)<< 2) >> + | (CLAMP(rgba[i][BCOMP], 0, 3) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_BYTE_2_3_3_REV: >> + if ((dstFormat == GL_RGB) || (dstFormat == GL_RGB_INTEGER)) { >> + GLubyte *dst = (GLubyte *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 7) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 7)<< 3) >> + | (CLAMP(rgba[i][BCOMP], 0, 3)<< 6); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_5_6_5: >> + if ((dstFormat == GL_RGB) || (dstFormat == GL_RGB_INTEGER)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 31)<< 11) >> + | (CLAMP(rgba[i][GCOMP], 0, 63)<< 5) >> + | (CLAMP(rgba[i][BCOMP], 0, 31) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_5_6_5_REV: >> + if ((dstFormat == GL_RGB) || (dstFormat == GL_RGB_INTEGER)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 31) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 63)<< 5) >> + | (CLAMP(rgba[i][BCOMP], 0, 31)<< 11); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_4_4_4_4: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 15)<< 12) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][BCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][ACOMP], 0, 15) ); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 15)<< 12) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][RCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][ACOMP], 0, 15) ); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 15)<< 12) >> + | (CLAMP(rgba[i][BCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][RCOMP], 0, 15) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_4_4_4_4_REV: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 15) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][BCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][ACOMP], 0, 15)<< 12); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 15) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][RCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][ACOMP], 0, 15)<< 12); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 15) ) >> + | (CLAMP(rgba[i][BCOMP], 0, 15)<< 4) >> + | (CLAMP(rgba[i][GCOMP], 0, 15)<< 8) >> + | (CLAMP(rgba[i][RCOMP], 0, 15)<< 12); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_5_5_5_1: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 31)<< 11) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 6) >> + | (CLAMP(rgba[i][BCOMP], 0, 31)<< 1) >> + | (CLAMP(rgba[i][ACOMP], 0, 1) ); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 31)<< 11) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 6) >> + | (CLAMP(rgba[i][RCOMP], 0, 31)<< 1) >> + | (CLAMP(rgba[i][ACOMP], 0, 1) ); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 31)<< 11) >> + | (CLAMP(rgba[i][BCOMP], 0, 31)<< 6) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 1) >> + | (CLAMP(rgba[i][RCOMP], 0, 1) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_SHORT_1_5_5_5_REV: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 31) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 5) >> + | (CLAMP(rgba[i][BCOMP], 0, 31)<< 10) >> + | (CLAMP(rgba[i][ACOMP], 0, 1)<< 15); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 31) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 5) >> + | (CLAMP(rgba[i][RCOMP], 0, 31)<< 10) >> + | (CLAMP(rgba[i][ACOMP], 0, 1)<< 15); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLushort *dst = (GLushort *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 31) ) >> + | (CLAMP(rgba[i][BCOMP], 0, 31)<< 5) >> + | (CLAMP(rgba[i][GCOMP], 0, 31)<< 10) >> + | (CLAMP(rgba[i][RCOMP], 0, 1)<< 15); >> + } >> + } >> + break; >> + case GL_UNSIGNED_INT_8_8_8_8: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 255)<< 24) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][BCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][ACOMP], 0, 255) ); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 255)<< 24) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][RCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][ACOMP], 0, 255) ); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 255)<< 24) >> + | (CLAMP(rgba[i][BCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][RCOMP], 0, 255) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_INT_8_8_8_8_REV: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 255) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][BCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][ACOMP], 0, 255)<< 24); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 255) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][RCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][ACOMP], 0, 255)<< 24); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 255) ) >> + | (CLAMP(rgba[i][BCOMP], 0, 255)<< 8) >> + | (CLAMP(rgba[i][GCOMP], 0, 255)<< 16) >> + | (CLAMP(rgba[i][RCOMP], 0, 255)<< 24); >> + } >> + } >> + break; >> + case GL_UNSIGNED_INT_10_10_10_2: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 1023)<< 22) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 12) >> + | (CLAMP(rgba[i][BCOMP], 0, 1023)<< 2) >> + | (CLAMP(rgba[i][ACOMP], 0, 3) ); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 1023)<< 22) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 12) >> + | (CLAMP(rgba[i][RCOMP], 0, 1023)<< 2) >> + | (CLAMP(rgba[i][ACOMP], 0, 3) ); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 1023)<< 22) >> + | (CLAMP(rgba[i][BCOMP], 0, 1023)<< 12) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 2) >> + | (CLAMP(rgba[i][RCOMP], 0, 3) ); >> + } >> + } >> + break; >> + case GL_UNSIGNED_INT_2_10_10_10_REV: >> + if ((dstFormat == GL_RGBA) || (dstFormat == GL_RGBA_INTEGER_EXT)) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][RCOMP], 0, 1023) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 10) >> + | (CLAMP(rgba[i][BCOMP], 0, 1023)<< 20) >> + | (CLAMP(rgba[i][ACOMP], 0, 3)<< 30); >> + } >> + } >> + else if ((dstFormat == GL_BGRA) || (dstFormat == GL_BGRA_INTEGER)) >> { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][BCOMP], 0, 1023) ) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 10) >> + | (CLAMP(rgba[i][RCOMP], 0, 1023)<< 20) >> + | (CLAMP(rgba[i][ACOMP], 0, 3)<< 30); >> + } >> + } >> + else if (dstFormat == GL_ABGR_EXT) { >> + GLuint *dst = (GLuint *) dstAddr; >> + for (i=0;i<n;i++) { >> + dst[i] = (CLAMP(rgba[i][ACOMP], 0, 1023) ) >> + | (CLAMP(rgba[i][BCOMP], 0, 1023)<< 10) >> + | (CLAMP(rgba[i][GCOMP], 0, 1023)<< 20) >> + | (CLAMP(rgba[i][RCOMP], 0, 3)<< 30); >> + } >> + } >> + break; >> + > > > It's kind of weird to have a bunch of switch cases like this in a header > file.
I agree. I dislike putting code in a .h file. (But, apparently, I dislike duplicating the code even more. :) It would be a good place for a C++ template function... > Couldn't the code be put into an ordinary function? Then return true/false > to indicate if the type was handled there. Okay, I can do that. -Jordan _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev