2 * Mesa 3-D graphics library
4 * Copyright (c) 2011 VMware, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
27 #include "format_unpack.h"
29 #include "../../gallium/auxiliary/util/u_format_rgb9e5.h"
30 #include "../../gallium/auxiliary/util/u_format_r11g11b10f.h"
33 /** Helper struct for MESA_FORMAT_Z32_FLOAT_X24S8 */
41 /* Expand 1, 2, 3, 4, 5, 6-bit values to fill 8 bits */
43 #define EXPAND_1_8(X) ( (X) ? 0xff : 0x0 )
45 #define EXPAND_2_8(X) ( ((X) << 6) | ((X) << 4) | ((X) << 2) | (X) )
47 #define EXPAND_3_8(X) ( ((X) << 5) | ((X) << 2) | ((X) >> 1) )
49 #define EXPAND_4_8(X) ( ((X) << 4) | (X) )
51 #define EXPAND_5_8(X) ( ((X) << 3) | ((X) >> 2) )
53 #define EXPAND_6_8(X) ( ((X) << 2) | ((X) >> 4) )
57 * Convert an 8-bit sRGB value from non-linear space to a
58 * linear RGB value in [0, 1].
59 * Implemented with a 256-entry lookup table.
62 _mesa_nonlinear_to_linear(GLubyte cs8
)
64 static GLfloat table
[256];
65 static GLboolean tableReady
= GL_FALSE
;
67 /* compute lookup table now */
69 for (i
= 0; i
< 256; i
++) {
70 const GLfloat cs
= UBYTE_TO_FLOAT(i
);
72 table
[i
] = cs
/ 12.92f
;
75 table
[i
] = (GLfloat
) pow((cs
+ 0.055) / 1.055, 2.4);
84 /**********************************************************************/
85 /* Unpack, returning GLfloat colors */
86 /**********************************************************************/
88 typedef void (*unpack_rgba_func
)(const void *src
, GLfloat dst
[][4], GLuint n
);
92 unpack_RGBA8888(const void *src
, GLfloat dst
[][4], GLuint n
)
94 const GLuint
*s
= ((const GLuint
*) src
);
96 for (i
= 0; i
< n
; i
++) {
97 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
98 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
99 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
100 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
105 unpack_RGBA8888_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
107 const GLuint
*s
= ((const GLuint
*) src
);
109 for (i
= 0; i
< n
; i
++) {
110 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
111 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
112 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
113 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
118 unpack_ARGB8888(const void *src
, GLfloat dst
[][4], GLuint n
)
120 const GLuint
*s
= ((const GLuint
*) src
);
122 for (i
= 0; i
< n
; i
++) {
123 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
124 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
125 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
126 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
131 unpack_ARGB8888_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
133 const GLuint
*s
= ((const GLuint
*) src
);
135 for (i
= 0; i
< n
; i
++) {
136 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
137 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
138 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
139 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
144 unpack_RGBX8888(const void *src
, GLfloat dst
[][4], GLuint n
)
146 const GLuint
*s
= ((const GLuint
*) src
);
148 for (i
= 0; i
< n
; i
++) {
149 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
150 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
151 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
152 dst
[i
][ACOMP
] = 1.0f
;
157 unpack_RGBX8888_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
159 const GLuint
*s
= ((const GLuint
*) src
);
161 for (i
= 0; i
< n
; i
++) {
162 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
163 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
164 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
165 dst
[i
][ACOMP
] = 1.0f
;
170 unpack_XRGB8888(const void *src
, GLfloat dst
[][4], GLuint n
)
172 const GLuint
*s
= ((const GLuint
*) src
);
174 for (i
= 0; i
< n
; i
++) {
175 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
176 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
177 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] ) & 0xff );
178 dst
[i
][ACOMP
] = 1.0f
;
183 unpack_XRGB8888_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
185 const GLuint
*s
= ((const GLuint
*) src
);
187 for (i
= 0; i
< n
; i
++) {
188 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 8) & 0xff );
189 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 16) & 0xff );
190 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( (s
[i
] >> 24) );
191 dst
[i
][ACOMP
] = 1.0f
;
196 unpack_RGB888(const void *src
, GLfloat dst
[][4], GLuint n
)
198 const GLubyte
*s
= (const GLubyte
*) src
;
200 for (i
= 0; i
< n
; i
++) {
201 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+2] );
202 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+1] );
203 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+0] );
204 dst
[i
][ACOMP
] = 1.0F
;
209 unpack_BGR888(const void *src
, GLfloat dst
[][4], GLuint n
)
211 const GLubyte
*s
= (const GLubyte
*) src
;
213 for (i
= 0; i
< n
; i
++) {
214 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+0] );
215 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+1] );
216 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( s
[i
*3+2] );
217 dst
[i
][ACOMP
] = 1.0F
;
222 unpack_RGB565(const void *src
, GLfloat dst
[][4], GLuint n
)
224 const GLushort
*s
= ((const GLushort
*) src
);
226 for (i
= 0; i
< n
; i
++) {
227 dst
[i
][RCOMP
] = ((s
[i
] >> 11) & 0x1f) * (1.0F
/ 31.0F
);
228 dst
[i
][GCOMP
] = ((s
[i
] >> 5 ) & 0x3f) * (1.0F
/ 63.0F
);
229 dst
[i
][BCOMP
] = ((s
[i
] ) & 0x1f) * (1.0F
/ 31.0F
);
230 dst
[i
][ACOMP
] = 1.0F
;
235 unpack_RGB565_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
237 const GLushort
*s
= ((const GLushort
*) src
);
239 for (i
= 0; i
< n
; i
++) {
240 GLuint t
= (s
[i
] >> 8) | (s
[i
] << 8); /* byte swap */
241 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( ((t
>> 8) & 0xf8) | ((t
>> 13) & 0x7) );
242 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( ((t
>> 3) & 0xfc) | ((t
>> 9) & 0x3) );
243 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( ((t
<< 3) & 0xf8) | ((t
>> 2) & 0x7) );
244 dst
[i
][ACOMP
] = 1.0F
;
249 unpack_ARGB4444(const void *src
, GLfloat dst
[][4], GLuint n
)
251 const GLushort
*s
= ((const GLushort
*) src
);
253 for (i
= 0; i
< n
; i
++) {
254 dst
[i
][RCOMP
] = ((s
[i
] >> 8) & 0xf) * (1.0F
/ 15.0F
);
255 dst
[i
][GCOMP
] = ((s
[i
] >> 4) & 0xf) * (1.0F
/ 15.0F
);
256 dst
[i
][BCOMP
] = ((s
[i
] ) & 0xf) * (1.0F
/ 15.0F
);
257 dst
[i
][ACOMP
] = ((s
[i
] >> 12) & 0xf) * (1.0F
/ 15.0F
);
262 unpack_ARGB4444_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
264 const GLushort
*s
= ((const GLushort
*) src
);
266 for (i
= 0; i
< n
; i
++) {
267 dst
[i
][RCOMP
] = ((s
[i
] ) & 0xf) * (1.0F
/ 15.0F
);
268 dst
[i
][GCOMP
] = ((s
[i
] >> 12) & 0xf) * (1.0F
/ 15.0F
);
269 dst
[i
][BCOMP
] = ((s
[i
] >> 8) & 0xf) * (1.0F
/ 15.0F
);
270 dst
[i
][ACOMP
] = ((s
[i
] >> 4) & 0xf) * (1.0F
/ 15.0F
);
275 unpack_RGBA5551(const void *src
, GLfloat dst
[][4], GLuint n
)
277 const GLushort
*s
= ((const GLushort
*) src
);
279 for (i
= 0; i
< n
; i
++) {
280 dst
[i
][RCOMP
] = ((s
[i
] >> 11) & 0x1f) * (1.0F
/ 31.0F
);
281 dst
[i
][GCOMP
] = ((s
[i
] >> 6) & 0x1f) * (1.0F
/ 31.0F
);
282 dst
[i
][BCOMP
] = ((s
[i
] >> 1) & 0x1f) * (1.0F
/ 31.0F
);
283 dst
[i
][ACOMP
] = ((s
[i
] ) & 0x01) * 1.0F
;
288 unpack_ARGB1555(const void *src
, GLfloat dst
[][4], GLuint n
)
290 const GLushort
*s
= ((const GLushort
*) src
);
292 for (i
= 0; i
< n
; i
++) {
293 dst
[i
][RCOMP
] = ((s
[i
] >> 10) & 0x1f) * (1.0F
/ 31.0F
);
294 dst
[i
][GCOMP
] = ((s
[i
] >> 5) & 0x1f) * (1.0F
/ 31.0F
);
295 dst
[i
][BCOMP
] = ((s
[i
] >> 0) & 0x1f) * (1.0F
/ 31.0F
);
296 dst
[i
][ACOMP
] = ((s
[i
] >> 15) & 0x01) * 1.0F
;
301 unpack_ARGB1555_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
303 const GLushort
*s
= ((const GLushort
*) src
);
305 for (i
= 0; i
< n
; i
++) {
306 GLushort tmp
= (s
[i
] << 8) | (s
[i
] >> 8); /* byteswap */
307 dst
[i
][RCOMP
] = ((tmp
>> 10) & 0x1f) * (1.0F
/ 31.0F
);
308 dst
[i
][GCOMP
] = ((tmp
>> 5) & 0x1f) * (1.0F
/ 31.0F
);
309 dst
[i
][BCOMP
] = ((tmp
>> 0) & 0x1f) * (1.0F
/ 31.0F
);
310 dst
[i
][ACOMP
] = ((tmp
>> 15) & 0x01) * 1.0F
;
315 unpack_AL44(const void *src
, GLfloat dst
[][4], GLuint n
)
317 const GLubyte
*s
= ((const GLubyte
*) src
);
319 for (i
= 0; i
< n
; i
++) {
322 dst
[i
][BCOMP
] = (s
[i
] & 0xf) * (1.0F
/ 15.0F
);
323 dst
[i
][ACOMP
] = ((s
[i
] >> 4) & 0xf) * (1.0F
/ 15.0F
);
328 unpack_AL88(const void *src
, GLfloat dst
[][4], GLuint n
)
330 const GLushort
*s
= ((const GLushort
*) src
);
332 for (i
= 0; i
< n
; i
++) {
335 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( s
[i
] & 0xff );
336 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 8 );
341 unpack_AL88_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
343 const GLushort
*s
= ((const GLushort
*) src
);
345 for (i
= 0; i
< n
; i
++) {
348 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 8 );
349 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( s
[i
] & 0xff );
354 unpack_AL1616(const void *src
, GLfloat dst
[][4], GLuint n
)
356 const GLuint
*s
= ((const GLuint
*) src
);
358 for (i
= 0; i
< n
; i
++) {
361 dst
[i
][BCOMP
] = USHORT_TO_FLOAT( s
[i
] & 0xffff );
362 dst
[i
][ACOMP
] = USHORT_TO_FLOAT( s
[i
] >> 16 );
367 unpack_AL1616_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
369 const GLuint
*s
= ((const GLuint
*) src
);
371 for (i
= 0; i
< n
; i
++) {
374 dst
[i
][BCOMP
] = USHORT_TO_FLOAT( s
[i
] >> 16 );
375 dst
[i
][ACOMP
] = USHORT_TO_FLOAT( s
[i
] & 0xffff );
380 unpack_RGB332(const void *src
, GLfloat dst
[][4], GLuint n
)
382 const GLubyte
*s
= ((const GLubyte
*) src
);
384 for (i
= 0; i
< n
; i
++) {
385 dst
[i
][RCOMP
] = ((s
[i
] >> 5) & 0x7) * (1.0F
/ 7.0F
);
386 dst
[i
][GCOMP
] = ((s
[i
] >> 2) & 0x7) * (1.0F
/ 7.0F
);
387 dst
[i
][BCOMP
] = ((s
[i
] ) & 0x3) * (1.0F
/ 3.0F
);
388 dst
[i
][ACOMP
] = 1.0F
;
394 unpack_A8(const void *src
, GLfloat dst
[][4], GLuint n
)
396 const GLubyte
*s
= ((const GLubyte
*) src
);
398 for (i
= 0; i
< n
; i
++) {
401 dst
[i
][BCOMP
] = 0.0F
;
402 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT(s
[i
]);
407 unpack_A16(const void *src
, GLfloat dst
[][4], GLuint n
)
409 const GLushort
*s
= ((const GLushort
*) src
);
411 for (i
= 0; i
< n
; i
++) {
414 dst
[i
][BCOMP
] = 0.0F
;
415 dst
[i
][ACOMP
] = USHORT_TO_FLOAT(s
[i
]);
420 unpack_L8(const void *src
, GLfloat dst
[][4], GLuint n
)
422 const GLubyte
*s
= ((const GLubyte
*) src
);
424 for (i
= 0; i
< n
; i
++) {
427 dst
[i
][BCOMP
] = UBYTE_TO_FLOAT(s
[i
]);
428 dst
[i
][ACOMP
] = 1.0F
;
433 unpack_L16(const void *src
, GLfloat dst
[][4], GLuint n
)
435 const GLushort
*s
= ((const GLushort
*) src
);
437 for (i
= 0; i
< n
; i
++) {
440 dst
[i
][BCOMP
] = USHORT_TO_FLOAT(s
[i
]);
441 dst
[i
][ACOMP
] = 1.0F
;
446 unpack_I8(const void *src
, GLfloat dst
[][4], GLuint n
)
448 const GLubyte
*s
= ((const GLubyte
*) src
);
450 for (i
= 0; i
< n
; i
++) {
454 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT(s
[i
]);
459 unpack_I16(const void *src
, GLfloat dst
[][4], GLuint n
)
461 const GLushort
*s
= ((const GLushort
*) src
);
463 for (i
= 0; i
< n
; i
++) {
467 dst
[i
][ACOMP
] = USHORT_TO_FLOAT(s
[i
]);
472 unpack_YCBCR(const void *src
, GLfloat dst
[][4], GLuint n
)
475 for (i
= 0; i
< n
; i
++) {
476 const GLushort
*src0
= ((const GLushort
*) src
) + i
* 2; /* even */
477 const GLushort
*src1
= src0
+ 1; /* odd */
478 const GLubyte y0
= (*src0
>> 8) & 0xff; /* luminance */
479 const GLubyte cb
= *src0
& 0xff; /* chroma U */
480 const GLubyte y1
= (*src1
>> 8) & 0xff; /* luminance */
481 const GLubyte cr
= *src1
& 0xff; /* chroma V */
482 const GLubyte y
= (i
& 1) ? y1
: y0
; /* choose even/odd luminance */
483 GLfloat r
= 1.164F
* (y
- 16) + 1.596F
* (cr
- 128);
484 GLfloat g
= 1.164F
* (y
- 16) - 0.813F
* (cr
- 128) - 0.391F
* (cb
- 128);
485 GLfloat b
= 1.164F
* (y
- 16) + 2.018F
* (cb
- 128);
486 r
*= (1.0F
/ 255.0F
);
487 g
*= (1.0F
/ 255.0F
);
488 b
*= (1.0F
/ 255.0F
);
489 dst
[i
][RCOMP
] = CLAMP(r
, 0.0F
, 1.0F
);
490 dst
[i
][GCOMP
] = CLAMP(g
, 0.0F
, 1.0F
);
491 dst
[i
][BCOMP
] = CLAMP(b
, 0.0F
, 1.0F
);
492 dst
[i
][ACOMP
] = 1.0F
;
497 unpack_YCBCR_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
500 for (i
= 0; i
< n
; i
++) {
501 const GLushort
*src0
= ((const GLushort
*) src
) + i
* 2; /* even */
502 const GLushort
*src1
= src0
+ 1; /* odd */
503 const GLubyte y0
= *src0
& 0xff; /* luminance */
504 const GLubyte cr
= (*src0
>> 8) & 0xff; /* chroma V */
505 const GLubyte y1
= *src1
& 0xff; /* luminance */
506 const GLubyte cb
= (*src1
>> 8) & 0xff; /* chroma U */
507 const GLubyte y
= (i
& 1) ? y1
: y0
; /* choose even/odd luminance */
508 GLfloat r
= 1.164F
* (y
- 16) + 1.596F
* (cr
- 128);
509 GLfloat g
= 1.164F
* (y
- 16) - 0.813F
* (cr
- 128) - 0.391F
* (cb
- 128);
510 GLfloat b
= 1.164F
* (y
- 16) + 2.018F
* (cb
- 128);
511 r
*= (1.0F
/ 255.0F
);
512 g
*= (1.0F
/ 255.0F
);
513 b
*= (1.0F
/ 255.0F
);
514 dst
[i
][RCOMP
] = CLAMP(r
, 0.0F
, 1.0F
);
515 dst
[i
][GCOMP
] = CLAMP(g
, 0.0F
, 1.0F
);
516 dst
[i
][BCOMP
] = CLAMP(b
, 0.0F
, 1.0F
);
517 dst
[i
][ACOMP
] = 1.0F
;
522 unpack_R8(const void *src
, GLfloat dst
[][4], GLuint n
)
524 const GLubyte
*s
= ((const GLubyte
*) src
);
526 for (i
= 0; i
< n
; i
++) {
527 dst
[i
][0] = UBYTE_TO_FLOAT(s
[i
]);
535 unpack_GR88(const void *src
, GLfloat dst
[][4], GLuint n
)
537 const GLushort
*s
= ((const GLushort
*) src
);
539 for (i
= 0; i
< n
; i
++) {
540 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( s
[i
] & 0xff );
541 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 8 );
548 unpack_RG88(const void *src
, GLfloat dst
[][4], GLuint n
)
550 const GLushort
*s
= ((const GLushort
*) src
);
552 for (i
= 0; i
< n
; i
++) {
553 dst
[i
][RCOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 8 );
554 dst
[i
][GCOMP
] = UBYTE_TO_FLOAT( s
[i
] & 0xff );
561 unpack_R16(const void *src
, GLfloat dst
[][4], GLuint n
)
563 const GLushort
*s
= ((const GLushort
*) src
);
565 for (i
= 0; i
< n
; i
++) {
566 dst
[i
][RCOMP
] = USHORT_TO_FLOAT(s
[i
]);
574 unpack_GR1616(const void *src
, GLfloat dst
[][4], GLuint n
)
576 const GLuint
*s
= ((const GLuint
*) src
);
578 for (i
= 0; i
< n
; i
++) {
579 dst
[i
][RCOMP
] = USHORT_TO_FLOAT( s
[i
] & 0xffff );
580 dst
[i
][GCOMP
] = USHORT_TO_FLOAT( s
[i
] >> 16 );
587 unpack_RG1616(const void *src
, GLfloat dst
[][4], GLuint n
)
589 const GLuint
*s
= ((const GLuint
*) src
);
591 for (i
= 0; i
< n
; i
++) {
592 dst
[i
][RCOMP
] = USHORT_TO_FLOAT( s
[i
] >> 16 );
593 dst
[i
][GCOMP
] = USHORT_TO_FLOAT( s
[i
] & 0xffff );
600 unpack_ARGB2101010(const void *src
, GLfloat dst
[][4], GLuint n
)
602 const GLuint
*s
= ((const GLuint
*) src
);
604 for (i
= 0; i
< n
; i
++) {
605 dst
[i
][RCOMP
] = ((s
[i
] >> 20) & 0x3ff) * (1.0F
/ 1023.0F
);
606 dst
[i
][GCOMP
] = ((s
[i
] >> 10) & 0x3ff) * (1.0F
/ 1023.0F
);
607 dst
[i
][BCOMP
] = ((s
[i
] >> 0) & 0x3ff) * (1.0F
/ 1023.0F
);
608 dst
[i
][ACOMP
] = ((s
[i
] >> 30) & 0x03) * (1.0F
/ 3.0F
);
614 unpack_ARGB2101010_UINT(const void *src
, GLfloat dst
[][4], GLuint n
)
616 const GLuint
*s
= (const GLuint
*) src
;
618 for (i
= 0; i
< n
; i
++) {
619 dst
[i
][RCOMP
] = (GLfloat
)((s
[i
] >> 20) & 0x3ff);
620 dst
[i
][GCOMP
] = (GLfloat
)((s
[i
] >> 10) & 0x3ff);
621 dst
[i
][BCOMP
] = (GLfloat
)((s
[i
] >> 0) & 0x3ff);
622 dst
[i
][ACOMP
] = (GLfloat
)((s
[i
] >> 30) & 0x03);
628 unpack_ABGR2101010_UINT(const void *src
, GLfloat dst
[][4], GLuint n
)
630 const GLuint
*s
= ((const GLuint
*) src
);
632 for (i
= 0; i
< n
; i
++) {
633 dst
[i
][RCOMP
] = (GLfloat
)((s
[i
] >> 0) & 0x3ff);
634 dst
[i
][GCOMP
] = (GLfloat
)((s
[i
] >> 10) & 0x3ff);
635 dst
[i
][BCOMP
] = (GLfloat
)((s
[i
] >> 20) & 0x3ff);
636 dst
[i
][ACOMP
] = (GLfloat
)((s
[i
] >> 30) & 0x03);
642 unpack_Z24_S8(const void *src
, GLfloat dst
[][4], GLuint n
)
644 /* only return Z, not stencil data */
645 const GLuint
*s
= ((const GLuint
*) src
);
646 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
648 for (i
= 0; i
< n
; i
++) {
651 dst
[i
][2] = (GLfloat
) ((s
[i
] >> 8) * scale
);
653 ASSERT(dst
[i
][0] >= 0.0F
);
654 ASSERT(dst
[i
][0] <= 1.0F
);
659 unpack_S8_Z24(const void *src
, GLfloat dst
[][4], GLuint n
)
661 /* only return Z, not stencil data */
662 const GLuint
*s
= ((const GLuint
*) src
);
663 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
665 for (i
= 0; i
< n
; i
++) {
668 dst
[i
][2] = (float) ((s
[i
] & 0x00ffffff) * scale
);
670 ASSERT(dst
[i
][0] >= 0.0F
);
671 ASSERT(dst
[i
][0] <= 1.0F
);
676 unpack_Z16(const void *src
, GLfloat dst
[][4], GLuint n
)
678 const GLushort
*s
= ((const GLushort
*) src
);
680 for (i
= 0; i
< n
; i
++) {
683 dst
[i
][2] = s
[i
] * (1.0F
/ 65535.0F
);
689 unpack_X8_Z24(const void *src
, GLfloat dst
[][4], GLuint n
)
691 unpack_S8_Z24(src
, dst
, n
);
695 unpack_Z24_X8(const void *src
, GLfloat dst
[][4], GLuint n
)
697 unpack_Z24_S8(src
, dst
, n
);
701 unpack_Z32(const void *src
, GLfloat dst
[][4], GLuint n
)
703 const GLuint
*s
= ((const GLuint
*) src
);
705 for (i
= 0; i
< n
; i
++) {
708 dst
[i
][2] = s
[i
] * (1.0F
/ 0xffffffff);
714 unpack_Z32_FLOAT(const void *src
, GLfloat dst
[][4], GLuint n
)
716 const GLfloat
*s
= ((const GLfloat
*) src
);
718 for (i
= 0; i
< n
; i
++) {
721 dst
[i
][2] = s
[i
* 2];
727 unpack_Z32_FLOAT_X24S8(const void *src
, GLfloat dst
[][4], GLuint n
)
729 const GLfloat
*s
= ((const GLfloat
*) src
);
731 for (i
= 0; i
< n
; i
++) {
741 unpack_S8(const void *src
, GLfloat dst
[][4], GLuint n
)
743 /* should never be used */
745 for (i
= 0; i
< n
; i
++) {
755 unpack_SRGB8(const void *src
, GLfloat dst
[][4], GLuint n
)
757 const GLubyte
*s
= (const GLubyte
*) src
;
759 for (i
= 0; i
< n
; i
++) {
760 dst
[i
][RCOMP
] = _mesa_nonlinear_to_linear(s
[i
*3+2]);
761 dst
[i
][GCOMP
] = _mesa_nonlinear_to_linear(s
[i
*3+1]);
762 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear(s
[i
*3+0]);
763 dst
[i
][ACOMP
] = 1.0F
;
768 unpack_SRGBA8(const void *src
, GLfloat dst
[][4], GLuint n
)
770 const GLuint
*s
= ((const GLuint
*) src
);
772 for (i
= 0; i
< n
; i
++) {
773 dst
[i
][RCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 24) );
774 dst
[i
][GCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 16) & 0xff );
775 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 8) & 0xff );
776 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( s
[i
] & 0xff ); /* linear! */
781 unpack_SARGB8(const void *src
, GLfloat dst
[][4], GLuint n
)
783 const GLuint
*s
= ((const GLuint
*) src
);
785 for (i
= 0; i
< n
; i
++) {
786 dst
[i
][RCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 16) & 0xff );
787 dst
[i
][GCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 8) & 0xff );
788 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] ) & 0xff );
789 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 24 ); /* linear! */
794 unpack_SL8(const void *src
, GLfloat dst
[][4], GLuint n
)
796 const GLubyte
*s
= ((const GLubyte
*) src
);
798 for (i
= 0; i
< n
; i
++) {
801 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear(s
[i
]);
802 dst
[i
][ACOMP
] = 1.0F
;
807 unpack_SLA8(const void *src
, GLfloat dst
[][4], GLuint n
)
809 const GLushort
*s
= (const GLushort
*) src
;
811 for (i
= 0; i
< n
; i
++) {
814 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear(s
[i
] & 0xff);
815 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT(s
[i
] >> 8); /* linear! */
820 unpack_SRGB_DXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
825 unpack_SRGBA_DXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
830 unpack_SRGBA_DXT3(const void *src
, GLfloat dst
[][4], GLuint n
)
835 unpack_SRGBA_DXT5(const void *src
, GLfloat dst
[][4], GLuint n
)
840 unpack_RGB_FXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
845 unpack_RGBA_FXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
850 unpack_RGB_DXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
855 unpack_RGBA_DXT1(const void *src
, GLfloat dst
[][4], GLuint n
)
860 unpack_RGBA_DXT3(const void *src
, GLfloat dst
[][4], GLuint n
)
865 unpack_RGBA_DXT5(const void *src
, GLfloat dst
[][4], GLuint n
)
871 unpack_RGBA_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
873 const GLfloat
*s
= (const GLfloat
*) src
;
875 for (i
= 0; i
< n
; i
++) {
876 dst
[i
][RCOMP
] = s
[i
*4+0];
877 dst
[i
][GCOMP
] = s
[i
*4+1];
878 dst
[i
][BCOMP
] = s
[i
*4+2];
879 dst
[i
][ACOMP
] = s
[i
*4+3];
884 unpack_RGBA_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
886 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
888 for (i
= 0; i
< n
; i
++) {
889 dst
[i
][RCOMP
] = _mesa_half_to_float(s
[i
*4+0]);
890 dst
[i
][GCOMP
] = _mesa_half_to_float(s
[i
*4+1]);
891 dst
[i
][BCOMP
] = _mesa_half_to_float(s
[i
*4+2]);
892 dst
[i
][ACOMP
] = _mesa_half_to_float(s
[i
*4+3]);
897 unpack_RGB_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
899 const GLfloat
*s
= (const GLfloat
*) src
;
901 for (i
= 0; i
< n
; i
++) {
902 dst
[i
][RCOMP
] = s
[i
*3+0];
903 dst
[i
][GCOMP
] = s
[i
*3+1];
904 dst
[i
][BCOMP
] = s
[i
*3+2];
905 dst
[i
][ACOMP
] = 1.0F
;
910 unpack_RGB_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
912 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
914 for (i
= 0; i
< n
; i
++) {
915 dst
[i
][RCOMP
] = _mesa_half_to_float(s
[i
*3+0]);
916 dst
[i
][GCOMP
] = _mesa_half_to_float(s
[i
*3+1]);
917 dst
[i
][BCOMP
] = _mesa_half_to_float(s
[i
*3+2]);
918 dst
[i
][ACOMP
] = 1.0F
;
923 unpack_ALPHA_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
925 const GLfloat
*s
= (const GLfloat
*) src
;
927 for (i
= 0; i
< n
; i
++) {
930 dst
[i
][BCOMP
] = 0.0F
;
931 dst
[i
][ACOMP
] = s
[i
];
936 unpack_ALPHA_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
938 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
940 for (i
= 0; i
< n
; i
++) {
943 dst
[i
][BCOMP
] = 0.0F
;
944 dst
[i
][ACOMP
] = _mesa_half_to_float(s
[i
]);
949 unpack_LUMINANCE_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
951 const GLfloat
*s
= (const GLfloat
*) src
;
953 for (i
= 0; i
< n
; i
++) {
956 dst
[i
][BCOMP
] = s
[i
];
957 dst
[i
][ACOMP
] = 1.0F
;
962 unpack_LUMINANCE_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
964 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
966 for (i
= 0; i
< n
; i
++) {
969 dst
[i
][BCOMP
] = _mesa_half_to_float(s
[i
]);
970 dst
[i
][ACOMP
] = 1.0F
;
975 unpack_LUMINANCE_ALPHA_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
977 const GLfloat
*s
= (const GLfloat
*) src
;
979 for (i
= 0; i
< n
; i
++) {
982 dst
[i
][BCOMP
] = s
[i
*2+0];
983 dst
[i
][ACOMP
] = s
[i
*2+1];
988 unpack_LUMINANCE_ALPHA_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
990 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
992 for (i
= 0; i
< n
; i
++) {
995 dst
[i
][BCOMP
] = _mesa_half_to_float(s
[i
*2+0]);
996 dst
[i
][ACOMP
] = _mesa_half_to_float(s
[i
*2+1]);
1001 unpack_INTENSITY_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1003 const GLfloat
*s
= (const GLfloat
*) src
;
1005 for (i
= 0; i
< n
; i
++) {
1009 dst
[i
][ACOMP
] = s
[i
];
1014 unpack_INTENSITY_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1016 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
1018 for (i
= 0; i
< n
; i
++) {
1022 dst
[i
][ACOMP
] = _mesa_half_to_float(s
[i
]);
1027 unpack_R_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1029 const GLfloat
*s
= (const GLfloat
*) src
;
1031 for (i
= 0; i
< n
; i
++) {
1032 dst
[i
][RCOMP
] = s
[i
];
1033 dst
[i
][GCOMP
] = 0.0F
;
1034 dst
[i
][BCOMP
] = 0.0F
;
1035 dst
[i
][ACOMP
] = 1.0F
;
1040 unpack_R_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1042 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
1044 for (i
= 0; i
< n
; i
++) {
1045 dst
[i
][RCOMP
] = _mesa_half_to_float(s
[i
]);
1046 dst
[i
][GCOMP
] = 0.0F
;
1047 dst
[i
][BCOMP
] = 0.0F
;
1048 dst
[i
][ACOMP
] = 1.0F
;
1053 unpack_RG_FLOAT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1055 const GLfloat
*s
= (const GLfloat
*) src
;
1057 for (i
= 0; i
< n
; i
++) {
1058 dst
[i
][RCOMP
] = s
[i
*2+0];
1059 dst
[i
][GCOMP
] = s
[i
*2+1];
1060 dst
[i
][BCOMP
] = 0.0F
;
1061 dst
[i
][ACOMP
] = 1.0F
;
1066 unpack_RG_FLOAT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1068 const GLhalfARB
*s
= (const GLhalfARB
*) src
;
1070 for (i
= 0; i
< n
; i
++) {
1071 dst
[i
][RCOMP
] = _mesa_half_to_float(s
[i
*2+0]);
1072 dst
[i
][GCOMP
] = _mesa_half_to_float(s
[i
*2+1]);
1073 dst
[i
][BCOMP
] = 0.0F
;
1074 dst
[i
][ACOMP
] = 1.0F
;
1079 unpack_ALPHA_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1081 const GLubyte
*s
= (const GLubyte
*) src
;
1083 for (i
= 0; i
< n
; i
++) {
1086 dst
[i
][BCOMP
] = 0.0;
1087 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1092 unpack_ALPHA_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1094 const GLushort
*s
= (const GLushort
*) src
;
1096 for (i
= 0; i
< n
; i
++) {
1099 dst
[i
][BCOMP
] = 0.0;
1100 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1105 unpack_ALPHA_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1107 const GLuint
*s
= (const GLuint
*) src
;
1109 for (i
= 0; i
< n
; i
++) {
1112 dst
[i
][BCOMP
] = 0.0;
1113 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1118 unpack_ALPHA_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1120 const GLbyte
*s
= (const GLbyte
*) src
;
1122 for (i
= 0; i
< n
; i
++) {
1125 dst
[i
][BCOMP
] = 0.0;
1126 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1131 unpack_ALPHA_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1133 const GLshort
*s
= (const GLshort
*) src
;
1135 for (i
= 0; i
< n
; i
++) {
1138 dst
[i
][BCOMP
] = 0.0;
1139 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1144 unpack_ALPHA_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1146 const GLint
*s
= (const GLint
*) src
;
1148 for (i
= 0; i
< n
; i
++) {
1151 dst
[i
][BCOMP
] = 0.0;
1152 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1157 unpack_INTENSITY_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1159 const GLubyte
*s
= (const GLubyte
*) src
;
1161 for (i
= 0; i
< n
; i
++) {
1165 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1170 unpack_INTENSITY_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1172 const GLushort
*s
= (const GLushort
*) src
;
1174 for (i
= 0; i
< n
; i
++) {
1178 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1183 unpack_INTENSITY_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1185 const GLuint
*s
= (const GLuint
*) src
;
1187 for (i
= 0; i
< n
; i
++) {
1191 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1196 unpack_INTENSITY_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1198 const GLbyte
*s
= (const GLbyte
*) src
;
1200 for (i
= 0; i
< n
; i
++) {
1204 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1209 unpack_INTENSITY_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1211 const GLshort
*s
= (const GLshort
*) src
;
1213 for (i
= 0; i
< n
; i
++) {
1217 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1222 unpack_INTENSITY_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1224 const GLint
*s
= (const GLint
*) src
;
1226 for (i
= 0; i
< n
; i
++) {
1230 dst
[i
][ACOMP
] = (GLfloat
) s
[i
];
1235 unpack_LUMINANCE_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1237 const GLubyte
*s
= (const GLubyte
*) src
;
1239 for (i
= 0; i
< n
; i
++) {
1240 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1241 dst
[i
][ACOMP
] = 1.0;
1246 unpack_LUMINANCE_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1248 const GLushort
*s
= (const GLushort
*) src
;
1250 for (i
= 0; i
< n
; i
++) {
1251 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1252 dst
[i
][ACOMP
] = 1.0;
1257 unpack_LUMINANCE_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1259 const GLuint
*s
= (const GLuint
*) src
;
1261 for (i
= 0; i
< n
; i
++) {
1262 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1263 dst
[i
][ACOMP
] = 1.0;
1268 unpack_LUMINANCE_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1270 const GLbyte
*s
= (const GLbyte
*) src
;
1272 for (i
= 0; i
< n
; i
++) {
1273 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1274 dst
[i
][ACOMP
] = 1.0;
1279 unpack_LUMINANCE_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1281 const GLshort
*s
= (const GLshort
*) src
;
1283 for (i
= 0; i
< n
; i
++) {
1284 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1285 dst
[i
][ACOMP
] = 1.0;
1290 unpack_LUMINANCE_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1292 const GLint
*s
= (const GLint
*) src
;
1294 for (i
= 0; i
< n
; i
++) {
1295 dst
[i
][RCOMP
] = dst
[i
][GCOMP
] = dst
[i
][BCOMP
] = (GLfloat
) s
[i
];
1296 dst
[i
][ACOMP
] = 1.0;
1301 unpack_LUMINANCE_ALPHA_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1303 const GLubyte
*s
= (const GLubyte
*) src
;
1305 for (i
= 0; i
< n
; i
++) {
1308 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1309 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1314 unpack_LUMINANCE_ALPHA_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1316 const GLushort
*s
= (const GLushort
*) src
;
1318 for (i
= 0; i
< n
; i
++) {
1321 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1322 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1327 unpack_LUMINANCE_ALPHA_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1329 const GLuint
*s
= (const GLuint
*) src
;
1331 for (i
= 0; i
< n
; i
++) {
1334 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1335 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1340 unpack_LUMINANCE_ALPHA_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1342 const GLbyte
*s
= (const GLbyte
*) src
;
1344 for (i
= 0; i
< n
; i
++) {
1347 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1348 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1353 unpack_LUMINANCE_ALPHA_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1355 const GLshort
*s
= (const GLshort
*) src
;
1357 for (i
= 0; i
< n
; i
++) {
1360 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1361 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1366 unpack_LUMINANCE_ALPHA_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1368 const GLint
*s
= (const GLint
*) src
;
1370 for (i
= 0; i
< n
; i
++) {
1373 dst
[i
][BCOMP
] = (GLfloat
) s
[2*i
+0];
1374 dst
[i
][ACOMP
] = (GLfloat
) s
[2*i
+1];
1379 unpack_R_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1381 const GLbyte
*s
= (const GLbyte
*) src
;
1383 for (i
= 0; i
< n
; i
++) {
1384 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1385 dst
[i
][GCOMP
] = 0.0;
1386 dst
[i
][BCOMP
] = 0.0;
1387 dst
[i
][ACOMP
] = 1.0;
1392 unpack_RG_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1394 const GLbyte
*s
= (const GLbyte
*) src
;
1396 for (i
= 0; i
< n
; i
++) {
1397 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1398 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1399 dst
[i
][BCOMP
] = 0.0;
1400 dst
[i
][ACOMP
] = 1.0;
1405 unpack_RGB_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1407 const GLbyte
*s
= (const GLbyte
*) src
;
1409 for (i
= 0; i
< n
; i
++) {
1410 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1411 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1412 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1413 dst
[i
][ACOMP
] = 1.0;
1418 unpack_RGBA_INT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1420 const GLbyte
*s
= (const GLbyte
*) src
;
1422 for (i
= 0; i
< n
; i
++) {
1423 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1424 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1425 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1426 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1431 unpack_R_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1433 const GLshort
*s
= (const GLshort
*) src
;
1435 for (i
= 0; i
< n
; i
++) {
1436 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1437 dst
[i
][GCOMP
] = 0.0;
1438 dst
[i
][BCOMP
] = 0.0;
1439 dst
[i
][ACOMP
] = 1.0;
1444 unpack_RG_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1446 const GLshort
*s
= (const GLshort
*) src
;
1448 for (i
= 0; i
< n
; i
++) {
1449 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1450 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1451 dst
[i
][BCOMP
] = 0.0;
1452 dst
[i
][ACOMP
] = 1.0;
1457 unpack_RGB_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1459 const GLshort
*s
= (const GLshort
*) src
;
1461 for (i
= 0; i
< n
; i
++) {
1462 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1463 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1464 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1465 dst
[i
][ACOMP
] = 1.0;
1470 unpack_RGBA_INT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1472 const GLshort
*s
= (const GLshort
*) src
;
1474 for (i
= 0; i
< n
; i
++) {
1475 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1476 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1477 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1478 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1483 unpack_R_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1485 const GLint
*s
= (const GLint
*) src
;
1487 for (i
= 0; i
< n
; i
++) {
1488 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1489 dst
[i
][GCOMP
] = 0.0;
1490 dst
[i
][BCOMP
] = 0.0;
1491 dst
[i
][ACOMP
] = 1.0;
1496 unpack_RG_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1498 const GLint
*s
= (const GLint
*) src
;
1500 for (i
= 0; i
< n
; i
++) {
1501 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1502 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1503 dst
[i
][BCOMP
] = 0.0;
1504 dst
[i
][ACOMP
] = 1.0;
1509 unpack_RGB_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1511 const GLint
*s
= (const GLint
*) src
;
1513 for (i
= 0; i
< n
; i
++) {
1514 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1515 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1516 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1517 dst
[i
][ACOMP
] = 1.0;
1523 unpack_RGBA_INT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1525 const GLint
*s
= (const GLint
*) src
;
1527 for (i
= 0; i
< n
; i
++) {
1528 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1529 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1530 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1531 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1536 unpack_R_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1538 const GLubyte
*s
= (const GLubyte
*) src
;
1540 for (i
= 0; i
< n
; i
++) {
1541 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1542 dst
[i
][GCOMP
] = 0.0;
1543 dst
[i
][BCOMP
] = 0.0;
1544 dst
[i
][ACOMP
] = 1.0;
1549 unpack_RG_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1551 const GLubyte
*s
= (const GLubyte
*) src
;
1553 for (i
= 0; i
< n
; i
++) {
1554 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1555 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1556 dst
[i
][BCOMP
] = 0.0;
1557 dst
[i
][ACOMP
] = 1.0;
1562 unpack_RGB_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1564 const GLubyte
*s
= (const GLubyte
*) src
;
1566 for (i
= 0; i
< n
; i
++) {
1567 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1568 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1569 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1570 dst
[i
][ACOMP
] = 1.0;
1575 unpack_RGBA_UINT8(const void *src
, GLfloat dst
[][4], GLuint n
)
1577 const GLubyte
*s
= (const GLubyte
*) src
;
1579 for (i
= 0; i
< n
; i
++) {
1580 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1581 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1582 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1583 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1588 unpack_R_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1590 const GLushort
*s
= (const GLushort
*) src
;
1592 for (i
= 0; i
< n
; i
++) {
1593 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1594 dst
[i
][GCOMP
] = 0.0;
1595 dst
[i
][BCOMP
] = 0.0;
1596 dst
[i
][ACOMP
] = 1.0;
1601 unpack_RG_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1603 const GLushort
*s
= (const GLushort
*) src
;
1605 for (i
= 0; i
< n
; i
++) {
1606 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1607 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1608 dst
[i
][BCOMP
] = 0.0;
1609 dst
[i
][ACOMP
] = 1.0;
1614 unpack_RGB_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1616 const GLushort
*s
= (const GLushort
*) src
;
1618 for (i
= 0; i
< n
; i
++) {
1619 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1620 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1621 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1622 dst
[i
][ACOMP
] = 1.0;
1627 unpack_RGBA_UINT16(const void *src
, GLfloat dst
[][4], GLuint n
)
1629 const GLushort
*s
= (const GLushort
*) src
;
1631 for (i
= 0; i
< n
; i
++) {
1632 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1633 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1634 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1635 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1640 unpack_R_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1642 const GLuint
*s
= (const GLuint
*) src
;
1644 for (i
= 0; i
< n
; i
++) {
1645 dst
[i
][RCOMP
] = (GLfloat
) s
[i
];
1646 dst
[i
][GCOMP
] = 0.0;
1647 dst
[i
][BCOMP
] = 0.0;
1648 dst
[i
][ACOMP
] = 1.0;
1653 unpack_RG_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1655 const GLuint
*s
= (const GLuint
*) src
;
1657 for (i
= 0; i
< n
; i
++) {
1658 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*2+0];
1659 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*2+1];
1660 dst
[i
][BCOMP
] = 0.0;
1661 dst
[i
][ACOMP
] = 1.0;
1666 unpack_RGB_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1668 const GLuint
*s
= (const GLuint
*) src
;
1670 for (i
= 0; i
< n
; i
++) {
1671 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*3+0];
1672 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*3+1];
1673 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*3+2];
1674 dst
[i
][ACOMP
] = 1.0;
1679 unpack_RGBA_UINT32(const void *src
, GLfloat dst
[][4], GLuint n
)
1681 const GLuint
*s
= (const GLuint
*) src
;
1683 for (i
= 0; i
< n
; i
++) {
1684 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
1685 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
1686 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
1687 dst
[i
][ACOMP
] = (GLfloat
) s
[i
*4+3];
1692 unpack_DUDV8(const void *src
, GLfloat dst
[][4], GLuint n
)
1694 const GLbyte
*s
= (const GLbyte
*) src
;
1696 for (i
= 0; i
< n
; i
++) {
1697 dst
[i
][RCOMP
] = BYTE_TO_FLOAT(s
[i
*2+0]);
1698 dst
[i
][GCOMP
] = BYTE_TO_FLOAT(s
[i
*2+1]);
1705 unpack_SIGNED_R8(const void *src
, GLfloat dst
[][4], GLuint n
)
1707 const GLbyte
*s
= ((const GLbyte
*) src
);
1709 for (i
= 0; i
< n
; i
++) {
1710 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( s
[i
] );
1711 dst
[i
][GCOMP
] = 0.0F
;
1712 dst
[i
][BCOMP
] = 0.0F
;
1713 dst
[i
][ACOMP
] = 1.0F
;
1718 unpack_SIGNED_RG88_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
1720 const GLushort
*s
= ((const GLushort
*) src
);
1722 for (i
= 0; i
< n
; i
++) {
1723 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] & 0xff) );
1724 dst
[i
][GCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
1725 dst
[i
][BCOMP
] = 0.0F
;
1726 dst
[i
][ACOMP
] = 1.0F
;
1731 unpack_SIGNED_RGBX8888(const void *src
, GLfloat dst
[][4], GLuint n
)
1733 const GLuint
*s
= ((const GLuint
*) src
);
1735 for (i
= 0; i
< n
; i
++) {
1736 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 24) );
1737 dst
[i
][GCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 16) );
1738 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
1739 dst
[i
][ACOMP
] = 1.0f
;
1744 unpack_SIGNED_RGBA8888(const void *src
, GLfloat dst
[][4], GLuint n
)
1746 const GLuint
*s
= ((const GLuint
*) src
);
1748 for (i
= 0; i
< n
; i
++) {
1749 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 24) );
1750 dst
[i
][GCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 16) );
1751 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
1752 dst
[i
][ACOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] ) );
1757 unpack_SIGNED_RGBA8888_REV(const void *src
, GLfloat dst
[][4], GLuint n
)
1759 const GLuint
*s
= ((const GLuint
*) src
);
1761 for (i
= 0; i
< n
; i
++) {
1762 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] ) );
1763 dst
[i
][GCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
1764 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 16) );
1765 dst
[i
][ACOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 24) );
1770 unpack_SIGNED_R16(const void *src
, GLfloat dst
[][4], GLuint n
)
1772 const GLshort
*s
= ((const GLshort
*) src
);
1774 for (i
= 0; i
< n
; i
++) {
1775 dst
[i
][RCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
] );
1776 dst
[i
][GCOMP
] = 0.0F
;
1777 dst
[i
][BCOMP
] = 0.0F
;
1778 dst
[i
][ACOMP
] = 1.0F
;
1783 unpack_SIGNED_GR1616(const void *src
, GLfloat dst
[][4], GLuint n
)
1785 const GLuint
*s
= ((const GLuint
*) src
);
1787 for (i
= 0; i
< n
; i
++) {
1788 dst
[i
][RCOMP
] = SHORT_TO_FLOAT_TEX( (GLshort
) (s
[i
] & 0xffff) );
1789 dst
[i
][GCOMP
] = SHORT_TO_FLOAT_TEX( (GLshort
) (s
[i
] >> 16) );
1790 dst
[i
][BCOMP
] = 0.0F
;
1791 dst
[i
][ACOMP
] = 1.0F
;
1796 unpack_SIGNED_RGB_16(const void *src
, GLfloat dst
[][4], GLuint n
)
1798 const GLshort
*s
= (const GLshort
*) src
;
1800 for (i
= 0; i
< n
; i
++) {
1801 dst
[i
][RCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*3+0] );
1802 dst
[i
][GCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*3+1] );
1803 dst
[i
][BCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*3+2] );
1804 dst
[i
][ACOMP
] = 1.0F
;
1809 unpack_SIGNED_RGBA_16(const void *src
, GLfloat dst
[][4], GLuint n
)
1811 const GLshort
*s
= (const GLshort
*) src
;
1813 for (i
= 0; i
< n
; i
++) {
1814 dst
[i
][RCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+0] );
1815 dst
[i
][GCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+1] );
1816 dst
[i
][BCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+2] );
1817 dst
[i
][ACOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+3] );
1822 unpack_RGBA_16(const void *src
, GLfloat dst
[][4], GLuint n
)
1824 const GLushort
*s
= (const GLushort
*) src
;
1826 for (i
= 0; i
< n
; i
++) {
1827 dst
[i
][RCOMP
] = USHORT_TO_FLOAT( s
[i
*4+0] );
1828 dst
[i
][GCOMP
] = USHORT_TO_FLOAT( s
[i
*4+1] );
1829 dst
[i
][BCOMP
] = USHORT_TO_FLOAT( s
[i
*4+2] );
1830 dst
[i
][ACOMP
] = USHORT_TO_FLOAT( s
[i
*4+3] );
1835 unpack_RED_RGTC1(const void *src
, GLfloat dst
[][4], GLuint n
)
1841 unpack_SIGNED_RED_RGTC1(const void *src
, GLfloat dst
[][4], GLuint n
)
1847 unpack_RG_RGTC2(const void *src
, GLfloat dst
[][4], GLuint n
)
1853 unpack_SIGNED_RG_RGTC2(const void *src
, GLfloat dst
[][4], GLuint n
)
1859 unpack_L_LATC1(const void *src
, GLfloat dst
[][4], GLuint n
)
1865 unpack_SIGNED_L_LATC1(const void *src
, GLfloat dst
[][4], GLuint n
)
1871 unpack_LA_LATC2(const void *src
, GLfloat dst
[][4], GLuint n
)
1877 unpack_SIGNED_LA_LATC2(const void *src
, GLfloat dst
[][4], GLuint n
)
1883 unpack_ETC1_RGB8(const void *src
, GLfloat dst
[][4], GLuint n
)
1889 unpack_ETC2_RGB8(const void *src
, GLfloat dst
[][4], GLuint n
)
1895 unpack_ETC2_SRGB8(const void *src
, GLfloat dst
[][4], GLuint n
)
1901 unpack_ETC2_RGBA8_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1907 unpack_ETC2_SRGB8_ALPHA8_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1913 unpack_ETC2_R11_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1919 unpack_ETC2_RG11_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1925 unpack_ETC2_SIGNED_R11_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1931 unpack_ETC2_SIGNED_RG11_EAC(const void *src
, GLfloat dst
[][4], GLuint n
)
1937 unpack_ETC2_RGB8_PUNCHTHROUGH_ALPHA1(const void *src
, GLfloat dst
[][4],
1944 unpack_ETC2_SRGB8_PUNCHTHROUGH_ALPHA1(const void *src
, GLfloat dst
[][4],
1951 unpack_SIGNED_A8(const void *src
, GLfloat dst
[][4], GLuint n
)
1953 const GLbyte
*s
= ((const GLbyte
*) src
);
1955 for (i
= 0; i
< n
; i
++) {
1956 dst
[i
][RCOMP
] = 0.0F
;
1957 dst
[i
][GCOMP
] = 0.0F
;
1958 dst
[i
][BCOMP
] = 0.0F
;
1959 dst
[i
][ACOMP
] = BYTE_TO_FLOAT_TEX( s
[i
] );
1964 unpack_SIGNED_L8(const void *src
, GLfloat dst
[][4], GLuint n
)
1966 const GLbyte
*s
= ((const GLbyte
*) src
);
1968 for (i
= 0; i
< n
; i
++) {
1971 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( s
[i
] );
1972 dst
[i
][ACOMP
] = 1.0F
;
1977 unpack_SIGNED_AL88(const void *src
, GLfloat dst
[][4], GLuint n
)
1979 const GLshort
*s
= ((const GLshort
*) src
);
1981 for (i
= 0; i
< n
; i
++) {
1984 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] & 0xff) );
1985 dst
[i
][ACOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
1990 unpack_SIGNED_I8(const void *src
, GLfloat dst
[][4], GLuint n
)
1992 const GLbyte
*s
= ((const GLbyte
*) src
);
1994 for (i
= 0; i
< n
; i
++) {
1998 dst
[i
][ACOMP
] = BYTE_TO_FLOAT_TEX( s
[i
] );
2003 unpack_SIGNED_A16(const void *src
, GLfloat dst
[][4], GLuint n
)
2005 const GLshort
*s
= ((const GLshort
*) src
);
2007 for (i
= 0; i
< n
; i
++) {
2008 dst
[i
][RCOMP
] = 0.0F
;
2009 dst
[i
][GCOMP
] = 0.0F
;
2010 dst
[i
][BCOMP
] = 0.0F
;
2011 dst
[i
][ACOMP
] = SHORT_TO_FLOAT_TEX( s
[i
] );
2016 unpack_SIGNED_L16(const void *src
, GLfloat dst
[][4], GLuint n
)
2018 const GLshort
*s
= ((const GLshort
*) src
);
2020 for (i
= 0; i
< n
; i
++) {
2023 dst
[i
][BCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
] );
2024 dst
[i
][ACOMP
] = 1.0F
;
2029 unpack_SIGNED_AL1616(const void *src
, GLfloat dst
[][4], GLuint n
)
2031 const GLshort
*s
= (const GLshort
*) src
;
2033 for (i
= 0; i
< n
; i
++) {
2036 dst
[i
][BCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*2+0] );
2037 dst
[i
][ACOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*2+1] );
2042 unpack_SIGNED_I16(const void *src
, GLfloat dst
[][4], GLuint n
)
2044 const GLshort
*s
= ((const GLshort
*) src
);
2046 for (i
= 0; i
< n
; i
++) {
2050 dst
[i
][ACOMP
] = SHORT_TO_FLOAT_TEX( s
[i
] );
2055 unpack_RGB9_E5_FLOAT(const void *src
, GLfloat dst
[][4], GLuint n
)
2057 const GLuint
*s
= (const GLuint
*) src
;
2059 for (i
= 0; i
< n
; i
++) {
2060 rgb9e5_to_float3(s
[i
], dst
[i
]);
2061 dst
[i
][ACOMP
] = 1.0F
;
2066 unpack_R11_G11_B10_FLOAT(const void *src
, GLfloat dst
[][4], GLuint n
)
2068 const GLuint
*s
= (const GLuint
*) src
;
2070 for (i
= 0; i
< n
; i
++) {
2071 r11g11b10f_to_float3(s
[i
], dst
[i
]);
2072 dst
[i
][ACOMP
] = 1.0F
;
2077 unpack_XRGB4444_UNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2079 const GLushort
*s
= ((const GLushort
*) src
);
2081 for (i
= 0; i
< n
; i
++) {
2082 dst
[i
][RCOMP
] = ((s
[i
] >> 8) & 0xf) * (1.0F
/ 15.0F
);
2083 dst
[i
][GCOMP
] = ((s
[i
] >> 4) & 0xf) * (1.0F
/ 15.0F
);
2084 dst
[i
][BCOMP
] = ((s
[i
] ) & 0xf) * (1.0F
/ 15.0F
);
2085 dst
[i
][ACOMP
] = 1.0;
2090 unpack_XRGB1555_UNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2092 const GLushort
*s
= ((const GLushort
*) src
);
2094 for (i
= 0; i
< n
; i
++) {
2095 dst
[i
][RCOMP
] = ((s
[i
] >> 10) & 0x1f) * (1.0F
/ 31.0F
);
2096 dst
[i
][GCOMP
] = ((s
[i
] >> 5) & 0x1f) * (1.0F
/ 31.0F
);
2097 dst
[i
][BCOMP
] = ((s
[i
] >> 0) & 0x1f) * (1.0F
/ 31.0F
);
2098 dst
[i
][ACOMP
] = 1.0;
2103 unpack_XBGR8888_SNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2105 const GLuint
*s
= ((const GLuint
*) src
);
2107 for (i
= 0; i
< n
; i
++) {
2108 dst
[i
][RCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] ) );
2109 dst
[i
][GCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 8) );
2110 dst
[i
][BCOMP
] = BYTE_TO_FLOAT_TEX( (GLbyte
) (s
[i
] >> 16) );
2111 dst
[i
][ACOMP
] = 1.0;
2116 unpack_XBGR8888_SRGB(const void *src
, GLfloat dst
[][4], GLuint n
)
2118 const GLuint
*s
= ((const GLuint
*) src
);
2120 for (i
= 0; i
< n
; i
++) {
2121 dst
[i
][RCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] ) & 0xff );
2122 dst
[i
][GCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 8) & 0xff );
2123 dst
[i
][BCOMP
] = _mesa_nonlinear_to_linear( (s
[i
] >> 16) & 0xff );
2124 dst
[i
][ACOMP
] = UBYTE_TO_FLOAT( s
[i
] >> 24 ); /* linear! */
2129 unpack_XBGR8888_UINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2131 const GLbyte
*s
= (const GLbyte
*) src
;
2133 for (i
= 0; i
< n
; i
++) {
2134 dst
[i
][RCOMP
] = s
[i
*4+0];
2135 dst
[i
][GCOMP
] = s
[i
*4+1];
2136 dst
[i
][BCOMP
] = s
[i
*4+2];
2137 dst
[i
][ACOMP
] = 1.0;
2142 unpack_XBGR8888_SINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2144 const GLbyte
*s
= (const GLbyte
*) src
;
2146 for (i
= 0; i
< n
; i
++) {
2147 dst
[i
][RCOMP
] = s
[i
*4+0];
2148 dst
[i
][GCOMP
] = s
[i
*4+1];
2149 dst
[i
][BCOMP
] = s
[i
*4+2];
2150 dst
[i
][ACOMP
] = 1.0;
2155 unpack_XRGB2101010_UNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2157 const GLuint
*s
= ((const GLuint
*) src
);
2159 for (i
= 0; i
< n
; i
++) {
2160 dst
[i
][RCOMP
] = ((s
[i
] >> 20) & 0x3ff) * (1.0F
/ 1023.0F
);
2161 dst
[i
][GCOMP
] = ((s
[i
] >> 10) & 0x3ff) * (1.0F
/ 1023.0F
);
2162 dst
[i
][BCOMP
] = ((s
[i
] >> 0) & 0x3ff) * (1.0F
/ 1023.0F
);
2163 dst
[i
][ACOMP
] = 1.0;
2168 unpack_XBGR16161616_UNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2170 const GLushort
*s
= (const GLushort
*) src
;
2172 for (i
= 0; i
< n
; i
++) {
2173 dst
[i
][RCOMP
] = USHORT_TO_FLOAT( s
[i
*4+0] );
2174 dst
[i
][GCOMP
] = USHORT_TO_FLOAT( s
[i
*4+1] );
2175 dst
[i
][BCOMP
] = USHORT_TO_FLOAT( s
[i
*4+2] );
2176 dst
[i
][ACOMP
] = 1.0;
2181 unpack_XBGR16161616_SNORM(const void *src
, GLfloat dst
[][4], GLuint n
)
2183 const GLshort
*s
= (const GLshort
*) src
;
2185 for (i
= 0; i
< n
; i
++) {
2186 dst
[i
][RCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+0] );
2187 dst
[i
][GCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+1] );
2188 dst
[i
][BCOMP
] = SHORT_TO_FLOAT_TEX( s
[i
*4+2] );
2189 dst
[i
][ACOMP
] = 1.0;
2194 unpack_XBGR16161616_FLOAT(const void *src
, GLfloat dst
[][4], GLuint n
)
2196 const GLshort
*s
= (const GLshort
*) src
;
2198 for (i
= 0; i
< n
; i
++) {
2199 dst
[i
][RCOMP
] = _mesa_half_to_float(s
[i
*4+0]);
2200 dst
[i
][GCOMP
] = _mesa_half_to_float(s
[i
*4+1]);
2201 dst
[i
][BCOMP
] = _mesa_half_to_float(s
[i
*4+2]);
2202 dst
[i
][ACOMP
] = 1.0;
2207 unpack_XBGR16161616_UINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2209 const GLushort
*s
= (const GLushort
*) src
;
2211 for (i
= 0; i
< n
; i
++) {
2212 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
2213 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
2214 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
2215 dst
[i
][ACOMP
] = 1.0;
2220 unpack_XBGR16161616_SINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2222 const GLshort
*s
= (const GLshort
*) src
;
2224 for (i
= 0; i
< n
; i
++) {
2225 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
2226 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
2227 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
2228 dst
[i
][ACOMP
] = 1.0;
2233 unpack_XBGR32323232_FLOAT(const void *src
, GLfloat dst
[][4], GLuint n
)
2235 const GLfloat
*s
= (const GLfloat
*) src
;
2237 for (i
= 0; i
< n
; i
++) {
2238 dst
[i
][RCOMP
] = s
[i
*4+0];
2239 dst
[i
][GCOMP
] = s
[i
*4+1];
2240 dst
[i
][BCOMP
] = s
[i
*4+2];
2241 dst
[i
][ACOMP
] = 1.0;
2246 unpack_XBGR32323232_UINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2248 const GLuint
*s
= (const GLuint
*) src
;
2250 for (i
= 0; i
< n
; i
++) {
2251 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
2252 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
2253 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
2254 dst
[i
][ACOMP
] = 1.0;
2259 unpack_XBGR32323232_SINT(const void *src
, GLfloat dst
[][4], GLuint n
)
2261 const GLint
*s
= (const GLint
*) src
;
2263 for (i
= 0; i
< n
; i
++) {
2264 dst
[i
][RCOMP
] = (GLfloat
) s
[i
*4+0];
2265 dst
[i
][GCOMP
] = (GLfloat
) s
[i
*4+1];
2266 dst
[i
][BCOMP
] = (GLfloat
) s
[i
*4+2];
2267 dst
[i
][ACOMP
] = 1.0;
2273 * Return the unpacker function for the given format.
2275 static unpack_rgba_func
2276 get_unpack_rgba_function(gl_format format
)
2278 static unpack_rgba_func table
[MESA_FORMAT_COUNT
];
2279 static GLboolean initialized
= GL_FALSE
;
2282 table
[MESA_FORMAT_NONE
] = NULL
;
2284 table
[MESA_FORMAT_RGBA8888
] = unpack_RGBA8888
;
2285 table
[MESA_FORMAT_RGBA8888_REV
] = unpack_RGBA8888_REV
;
2286 table
[MESA_FORMAT_ARGB8888
] = unpack_ARGB8888
;
2287 table
[MESA_FORMAT_ARGB8888_REV
] = unpack_ARGB8888_REV
;
2288 table
[MESA_FORMAT_RGBX8888
] = unpack_RGBX8888
;
2289 table
[MESA_FORMAT_RGBX8888_REV
] = unpack_RGBX8888_REV
;
2290 table
[MESA_FORMAT_XRGB8888
] = unpack_XRGB8888
;
2291 table
[MESA_FORMAT_XRGB8888_REV
] = unpack_XRGB8888_REV
;
2292 table
[MESA_FORMAT_RGB888
] = unpack_RGB888
;
2293 table
[MESA_FORMAT_BGR888
] = unpack_BGR888
;
2294 table
[MESA_FORMAT_RGB565
] = unpack_RGB565
;
2295 table
[MESA_FORMAT_RGB565_REV
] = unpack_RGB565_REV
;
2296 table
[MESA_FORMAT_ARGB4444
] = unpack_ARGB4444
;
2297 table
[MESA_FORMAT_ARGB4444_REV
] = unpack_ARGB4444_REV
;
2298 table
[MESA_FORMAT_RGBA5551
] = unpack_RGBA5551
;
2299 table
[MESA_FORMAT_ARGB1555
] = unpack_ARGB1555
;
2300 table
[MESA_FORMAT_ARGB1555_REV
] = unpack_ARGB1555_REV
;
2301 table
[MESA_FORMAT_AL44
] = unpack_AL44
;
2302 table
[MESA_FORMAT_AL88
] = unpack_AL88
;
2303 table
[MESA_FORMAT_AL88_REV
] = unpack_AL88_REV
;
2304 table
[MESA_FORMAT_AL1616
] = unpack_AL1616
;
2305 table
[MESA_FORMAT_AL1616_REV
] = unpack_AL1616_REV
;
2306 table
[MESA_FORMAT_RGB332
] = unpack_RGB332
;
2307 table
[MESA_FORMAT_A8
] = unpack_A8
;
2308 table
[MESA_FORMAT_A16
] = unpack_A16
;
2309 table
[MESA_FORMAT_L8
] = unpack_L8
;
2310 table
[MESA_FORMAT_L16
] = unpack_L16
;
2311 table
[MESA_FORMAT_I8
] = unpack_I8
;
2312 table
[MESA_FORMAT_I16
] = unpack_I16
;
2313 table
[MESA_FORMAT_YCBCR
] = unpack_YCBCR
;
2314 table
[MESA_FORMAT_YCBCR_REV
] = unpack_YCBCR_REV
;
2315 table
[MESA_FORMAT_R8
] = unpack_R8
;
2316 table
[MESA_FORMAT_GR88
] = unpack_GR88
;
2317 table
[MESA_FORMAT_RG88
] = unpack_RG88
;
2318 table
[MESA_FORMAT_R16
] = unpack_R16
;
2319 table
[MESA_FORMAT_GR1616
] = unpack_GR1616
;
2320 table
[MESA_FORMAT_RG1616
] = unpack_RG1616
;
2321 table
[MESA_FORMAT_ARGB2101010
] = unpack_ARGB2101010
;
2322 table
[MESA_FORMAT_ARGB2101010_UINT
] = unpack_ARGB2101010_UINT
;
2323 table
[MESA_FORMAT_ABGR2101010_UINT
] = unpack_ABGR2101010_UINT
;
2324 table
[MESA_FORMAT_Z24_S8
] = unpack_Z24_S8
;
2325 table
[MESA_FORMAT_S8_Z24
] = unpack_S8_Z24
;
2326 table
[MESA_FORMAT_Z16
] = unpack_Z16
;
2327 table
[MESA_FORMAT_X8_Z24
] = unpack_X8_Z24
;
2328 table
[MESA_FORMAT_Z24_X8
] = unpack_Z24_X8
;
2329 table
[MESA_FORMAT_Z32
] = unpack_Z32
;
2330 table
[MESA_FORMAT_S8
] = unpack_S8
;
2331 table
[MESA_FORMAT_SRGB8
] = unpack_SRGB8
;
2332 table
[MESA_FORMAT_SRGBA8
] = unpack_SRGBA8
;
2333 table
[MESA_FORMAT_SARGB8
] = unpack_SARGB8
;
2334 table
[MESA_FORMAT_SL8
] = unpack_SL8
;
2335 table
[MESA_FORMAT_SLA8
] = unpack_SLA8
;
2336 table
[MESA_FORMAT_SRGB_DXT1
] = unpack_SRGB_DXT1
;
2337 table
[MESA_FORMAT_SRGBA_DXT1
] = unpack_SRGBA_DXT1
;
2338 table
[MESA_FORMAT_SRGBA_DXT3
] = unpack_SRGBA_DXT3
;
2339 table
[MESA_FORMAT_SRGBA_DXT5
] = unpack_SRGBA_DXT5
;
2341 table
[MESA_FORMAT_RGB_FXT1
] = unpack_RGB_FXT1
;
2342 table
[MESA_FORMAT_RGBA_FXT1
] = unpack_RGBA_FXT1
;
2343 table
[MESA_FORMAT_RGB_DXT1
] = unpack_RGB_DXT1
;
2344 table
[MESA_FORMAT_RGBA_DXT1
] = unpack_RGBA_DXT1
;
2345 table
[MESA_FORMAT_RGBA_DXT3
] = unpack_RGBA_DXT3
;
2346 table
[MESA_FORMAT_RGBA_DXT5
] = unpack_RGBA_DXT5
;
2348 table
[MESA_FORMAT_RGBA_FLOAT32
] = unpack_RGBA_FLOAT32
;
2349 table
[MESA_FORMAT_RGBA_FLOAT16
] = unpack_RGBA_FLOAT16
;
2350 table
[MESA_FORMAT_RGB_FLOAT32
] = unpack_RGB_FLOAT32
;
2351 table
[MESA_FORMAT_RGB_FLOAT16
] = unpack_RGB_FLOAT16
;
2352 table
[MESA_FORMAT_ALPHA_FLOAT32
] = unpack_ALPHA_FLOAT32
;
2353 table
[MESA_FORMAT_ALPHA_FLOAT16
] = unpack_ALPHA_FLOAT16
;
2354 table
[MESA_FORMAT_LUMINANCE_FLOAT32
] = unpack_LUMINANCE_FLOAT32
;
2355 table
[MESA_FORMAT_LUMINANCE_FLOAT16
] = unpack_LUMINANCE_FLOAT16
;
2356 table
[MESA_FORMAT_LUMINANCE_ALPHA_FLOAT32
] = unpack_LUMINANCE_ALPHA_FLOAT32
;
2357 table
[MESA_FORMAT_LUMINANCE_ALPHA_FLOAT16
] = unpack_LUMINANCE_ALPHA_FLOAT16
;
2358 table
[MESA_FORMAT_INTENSITY_FLOAT32
] = unpack_INTENSITY_FLOAT32
;
2359 table
[MESA_FORMAT_INTENSITY_FLOAT16
] = unpack_INTENSITY_FLOAT16
;
2360 table
[MESA_FORMAT_R_FLOAT32
] = unpack_R_FLOAT32
;
2361 table
[MESA_FORMAT_R_FLOAT16
] = unpack_R_FLOAT16
;
2362 table
[MESA_FORMAT_RG_FLOAT32
] = unpack_RG_FLOAT32
;
2363 table
[MESA_FORMAT_RG_FLOAT16
] = unpack_RG_FLOAT16
;
2365 table
[MESA_FORMAT_ALPHA_UINT8
] = unpack_ALPHA_UINT8
;
2366 table
[MESA_FORMAT_ALPHA_UINT16
] = unpack_ALPHA_UINT16
;
2367 table
[MESA_FORMAT_ALPHA_UINT32
] = unpack_ALPHA_UINT32
;
2368 table
[MESA_FORMAT_ALPHA_INT8
] = unpack_ALPHA_INT8
;
2369 table
[MESA_FORMAT_ALPHA_INT16
] = unpack_ALPHA_INT16
;
2370 table
[MESA_FORMAT_ALPHA_INT32
] = unpack_ALPHA_INT32
;
2372 table
[MESA_FORMAT_INTENSITY_UINT8
] = unpack_INTENSITY_UINT8
;
2373 table
[MESA_FORMAT_INTENSITY_UINT16
] = unpack_INTENSITY_UINT16
;
2374 table
[MESA_FORMAT_INTENSITY_UINT32
] = unpack_INTENSITY_UINT32
;
2375 table
[MESA_FORMAT_INTENSITY_INT8
] = unpack_INTENSITY_INT8
;
2376 table
[MESA_FORMAT_INTENSITY_INT16
] = unpack_INTENSITY_INT16
;
2377 table
[MESA_FORMAT_INTENSITY_INT32
] = unpack_INTENSITY_INT32
;
2379 table
[MESA_FORMAT_LUMINANCE_UINT8
] = unpack_LUMINANCE_UINT8
;
2380 table
[MESA_FORMAT_LUMINANCE_UINT16
] = unpack_LUMINANCE_UINT16
;
2381 table
[MESA_FORMAT_LUMINANCE_UINT32
] = unpack_LUMINANCE_UINT32
;
2382 table
[MESA_FORMAT_LUMINANCE_INT8
] = unpack_LUMINANCE_INT8
;
2383 table
[MESA_FORMAT_LUMINANCE_INT16
] = unpack_LUMINANCE_INT16
;
2384 table
[MESA_FORMAT_LUMINANCE_INT32
] = unpack_LUMINANCE_INT32
;
2386 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT8
] = unpack_LUMINANCE_ALPHA_UINT8
;
2387 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT16
] = unpack_LUMINANCE_ALPHA_UINT16
;
2388 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT32
] = unpack_LUMINANCE_ALPHA_UINT32
;
2389 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT8
] = unpack_LUMINANCE_ALPHA_INT8
;
2390 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT16
] = unpack_LUMINANCE_ALPHA_INT16
;
2391 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT32
] = unpack_LUMINANCE_ALPHA_INT32
;
2393 table
[MESA_FORMAT_R_INT8
] = unpack_R_INT8
;
2394 table
[MESA_FORMAT_RG_INT8
] = unpack_RG_INT8
;
2395 table
[MESA_FORMAT_RGB_INT8
] = unpack_RGB_INT8
;
2396 table
[MESA_FORMAT_RGBA_INT8
] = unpack_RGBA_INT8
;
2397 table
[MESA_FORMAT_R_INT16
] = unpack_R_INT16
;
2398 table
[MESA_FORMAT_RG_INT16
] = unpack_RG_INT16
;
2399 table
[MESA_FORMAT_RGB_INT16
] = unpack_RGB_INT16
;
2400 table
[MESA_FORMAT_RGBA_INT16
] = unpack_RGBA_INT16
;
2401 table
[MESA_FORMAT_R_INT32
] = unpack_R_INT32
;
2402 table
[MESA_FORMAT_RG_INT32
] = unpack_RG_INT32
;
2403 table
[MESA_FORMAT_RGB_INT32
] = unpack_RGB_INT32
;
2404 table
[MESA_FORMAT_RGBA_INT32
] = unpack_RGBA_INT32
;
2405 table
[MESA_FORMAT_R_UINT8
] = unpack_R_UINT8
;
2406 table
[MESA_FORMAT_RG_UINT8
] = unpack_RG_UINT8
;
2407 table
[MESA_FORMAT_RGB_UINT8
] = unpack_RGB_UINT8
;
2408 table
[MESA_FORMAT_RGBA_UINT8
] = unpack_RGBA_UINT8
;
2409 table
[MESA_FORMAT_R_UINT16
] = unpack_R_UINT16
;
2410 table
[MESA_FORMAT_RG_UINT16
] = unpack_RG_UINT16
;
2411 table
[MESA_FORMAT_RGB_UINT16
] = unpack_RGB_UINT16
;
2412 table
[MESA_FORMAT_RGBA_UINT16
] = unpack_RGBA_UINT16
;
2413 table
[MESA_FORMAT_R_UINT32
] = unpack_R_UINT32
;
2414 table
[MESA_FORMAT_RG_UINT32
] = unpack_RG_UINT32
;
2415 table
[MESA_FORMAT_RGB_UINT32
] = unpack_RGB_UINT32
;
2416 table
[MESA_FORMAT_RGBA_UINT32
] = unpack_RGBA_UINT32
;
2418 table
[MESA_FORMAT_DUDV8
] = unpack_DUDV8
;
2419 table
[MESA_FORMAT_SIGNED_R8
] = unpack_SIGNED_R8
;
2420 table
[MESA_FORMAT_SIGNED_RG88_REV
] = unpack_SIGNED_RG88_REV
;
2421 table
[MESA_FORMAT_SIGNED_RGBX8888
] = unpack_SIGNED_RGBX8888
;
2422 table
[MESA_FORMAT_SIGNED_RGBA8888
] = unpack_SIGNED_RGBA8888
;
2423 table
[MESA_FORMAT_SIGNED_RGBA8888_REV
] = unpack_SIGNED_RGBA8888_REV
;
2424 table
[MESA_FORMAT_SIGNED_R16
] = unpack_SIGNED_R16
;
2425 table
[MESA_FORMAT_SIGNED_GR1616
] = unpack_SIGNED_GR1616
;
2426 table
[MESA_FORMAT_SIGNED_RGB_16
] = unpack_SIGNED_RGB_16
;
2427 table
[MESA_FORMAT_SIGNED_RGBA_16
] = unpack_SIGNED_RGBA_16
;
2428 table
[MESA_FORMAT_RGBA_16
] = unpack_RGBA_16
;
2430 table
[MESA_FORMAT_RED_RGTC1
] = unpack_RED_RGTC1
;
2431 table
[MESA_FORMAT_SIGNED_RED_RGTC1
] = unpack_SIGNED_RED_RGTC1
;
2432 table
[MESA_FORMAT_RG_RGTC2
] = unpack_RG_RGTC2
;
2433 table
[MESA_FORMAT_SIGNED_RG_RGTC2
] = unpack_SIGNED_RG_RGTC2
;
2435 table
[MESA_FORMAT_L_LATC1
] = unpack_L_LATC1
;
2436 table
[MESA_FORMAT_SIGNED_L_LATC1
] = unpack_SIGNED_L_LATC1
;
2437 table
[MESA_FORMAT_LA_LATC2
] = unpack_LA_LATC2
;
2438 table
[MESA_FORMAT_SIGNED_LA_LATC2
] = unpack_SIGNED_LA_LATC2
;
2440 table
[MESA_FORMAT_ETC1_RGB8
] = unpack_ETC1_RGB8
;
2441 table
[MESA_FORMAT_ETC2_RGB8
] = unpack_ETC2_RGB8
;
2442 table
[MESA_FORMAT_ETC2_SRGB8
] = unpack_ETC2_SRGB8
;
2443 table
[MESA_FORMAT_ETC2_RGBA8_EAC
] = unpack_ETC2_RGBA8_EAC
;
2444 table
[MESA_FORMAT_ETC2_SRGB8_ALPHA8_EAC
] = unpack_ETC2_SRGB8_ALPHA8_EAC
;
2445 table
[MESA_FORMAT_ETC2_R11_EAC
] = unpack_ETC2_R11_EAC
;
2446 table
[MESA_FORMAT_ETC2_RG11_EAC
] = unpack_ETC2_RG11_EAC
;
2447 table
[MESA_FORMAT_ETC2_SIGNED_R11_EAC
] = unpack_ETC2_SIGNED_R11_EAC
;
2448 table
[MESA_FORMAT_ETC2_SIGNED_RG11_EAC
] = unpack_ETC2_SIGNED_RG11_EAC
;
2449 table
[MESA_FORMAT_ETC2_RGB8_PUNCHTHROUGH_ALPHA1
] =
2450 unpack_ETC2_RGB8_PUNCHTHROUGH_ALPHA1
;
2451 table
[MESA_FORMAT_ETC2_SRGB8_PUNCHTHROUGH_ALPHA1
] =
2452 unpack_ETC2_SRGB8_PUNCHTHROUGH_ALPHA1
;
2453 table
[MESA_FORMAT_SIGNED_A8
] = unpack_SIGNED_A8
;
2454 table
[MESA_FORMAT_SIGNED_L8
] = unpack_SIGNED_L8
;
2455 table
[MESA_FORMAT_SIGNED_AL88
] = unpack_SIGNED_AL88
;
2456 table
[MESA_FORMAT_SIGNED_I8
] = unpack_SIGNED_I8
;
2457 table
[MESA_FORMAT_SIGNED_A16
] = unpack_SIGNED_A16
;
2458 table
[MESA_FORMAT_SIGNED_L16
] = unpack_SIGNED_L16
;
2459 table
[MESA_FORMAT_SIGNED_AL1616
] = unpack_SIGNED_AL1616
;
2460 table
[MESA_FORMAT_SIGNED_I16
] = unpack_SIGNED_I16
;
2462 table
[MESA_FORMAT_RGB9_E5_FLOAT
] = unpack_RGB9_E5_FLOAT
;
2463 table
[MESA_FORMAT_R11_G11_B10_FLOAT
] = unpack_R11_G11_B10_FLOAT
;
2465 table
[MESA_FORMAT_Z32_FLOAT
] = unpack_Z32_FLOAT
;
2466 table
[MESA_FORMAT_Z32_FLOAT_X24S8
] = unpack_Z32_FLOAT_X24S8
;
2468 table
[MESA_FORMAT_XRGB4444_UNORM
] = unpack_XRGB4444_UNORM
;
2469 table
[MESA_FORMAT_XRGB1555_UNORM
] = unpack_XRGB1555_UNORM
;
2470 table
[MESA_FORMAT_XBGR8888_SNORM
] = unpack_XBGR8888_SNORM
;
2471 table
[MESA_FORMAT_XBGR8888_SRGB
] = unpack_XBGR8888_SRGB
;
2472 table
[MESA_FORMAT_XBGR8888_UINT
] = unpack_XBGR8888_UINT
;
2473 table
[MESA_FORMAT_XBGR8888_SINT
] = unpack_XBGR8888_SINT
;
2474 table
[MESA_FORMAT_XRGB2101010_UNORM
] = unpack_XRGB2101010_UNORM
;
2475 table
[MESA_FORMAT_XBGR16161616_UNORM
] = unpack_XBGR16161616_UNORM
;
2476 table
[MESA_FORMAT_XBGR16161616_SNORM
] = unpack_XBGR16161616_SNORM
;
2477 table
[MESA_FORMAT_XBGR16161616_FLOAT
] = unpack_XBGR16161616_FLOAT
;
2478 table
[MESA_FORMAT_XBGR16161616_UINT
] = unpack_XBGR16161616_UINT
;
2479 table
[MESA_FORMAT_XBGR16161616_SINT
] = unpack_XBGR16161616_SINT
;
2480 table
[MESA_FORMAT_XBGR32323232_FLOAT
] = unpack_XBGR32323232_FLOAT
;
2481 table
[MESA_FORMAT_XBGR32323232_UINT
] = unpack_XBGR32323232_UINT
;
2482 table
[MESA_FORMAT_XBGR32323232_SINT
] = unpack_XBGR32323232_SINT
;
2484 initialized
= GL_TRUE
;
2487 if (table
[format
] == NULL
) {
2488 _mesa_problem(NULL
, "unsupported unpack for format %s",
2489 _mesa_get_format_name(format
));
2492 return table
[format
];
2497 * Unpack rgba colors, returning as GLfloat values.
2500 _mesa_unpack_rgba_row(gl_format format
, GLuint n
,
2501 const void *src
, GLfloat dst
[][4])
2503 unpack_rgba_func unpack
= get_unpack_rgba_function(format
);
2504 unpack(src
, dst
, n
);
2508 /**********************************************************************/
2509 /* Unpack, returning GLubyte colors */
2510 /**********************************************************************/
2514 unpack_ubyte_RGBA8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2516 const GLuint
*s
= ((const GLuint
*) src
);
2518 for (i
= 0; i
< n
; i
++) {
2519 dst
[i
][RCOMP
] = (s
[i
] >> 24);
2520 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2521 dst
[i
][BCOMP
] = (s
[i
] >> 8) & 0xff;
2522 dst
[i
][ACOMP
] = (s
[i
] ) & 0xff;
2527 unpack_ubyte_RGBA8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2529 const GLuint
*s
= ((const GLuint
*) src
);
2531 for (i
= 0; i
< n
; i
++) {
2532 dst
[i
][RCOMP
] = (s
[i
] ) & 0xff;
2533 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2534 dst
[i
][BCOMP
] = (s
[i
] >> 16) & 0xff;
2535 dst
[i
][ACOMP
] = (s
[i
] >> 24);
2540 unpack_ubyte_ARGB8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2542 const GLuint
*s
= ((const GLuint
*) src
);
2544 for (i
= 0; i
< n
; i
++) {
2545 dst
[i
][RCOMP
] = (s
[i
] >> 16) & 0xff;
2546 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2547 dst
[i
][BCOMP
] = (s
[i
] ) & 0xff;
2548 dst
[i
][ACOMP
] = (s
[i
] >> 24);
2553 unpack_ubyte_ARGB8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2555 const GLuint
*s
= ((const GLuint
*) src
);
2557 for (i
= 0; i
< n
; i
++) {
2558 dst
[i
][RCOMP
] = (s
[i
] >> 8) & 0xff;
2559 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2560 dst
[i
][BCOMP
] = (s
[i
] >> 24);
2561 dst
[i
][ACOMP
] = (s
[i
] ) & 0xff;
2566 unpack_ubyte_RGBX8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2568 const GLuint
*s
= ((const GLuint
*) src
);
2570 for (i
= 0; i
< n
; i
++) {
2571 dst
[i
][RCOMP
] = (s
[i
] >> 24);
2572 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2573 dst
[i
][BCOMP
] = (s
[i
] >> 8) & 0xff;
2574 dst
[i
][ACOMP
] = 0xff;
2579 unpack_ubyte_RGBX8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2581 const GLuint
*s
= ((const GLuint
*) src
);
2583 for (i
= 0; i
< n
; i
++) {
2584 dst
[i
][RCOMP
] = (s
[i
] ) & 0xff;
2585 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2586 dst
[i
][BCOMP
] = (s
[i
] >> 16) & 0xff;
2587 dst
[i
][ACOMP
] = 0xff;
2592 unpack_ubyte_XRGB8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2594 const GLuint
*s
= ((const GLuint
*) src
);
2596 for (i
= 0; i
< n
; i
++) {
2597 dst
[i
][RCOMP
] = (s
[i
] >> 16) & 0xff;
2598 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2599 dst
[i
][BCOMP
] = (s
[i
] ) & 0xff;
2600 dst
[i
][ACOMP
] = 0xff;
2605 unpack_ubyte_XRGB8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2607 const GLuint
*s
= ((const GLuint
*) src
);
2609 for (i
= 0; i
< n
; i
++) {
2610 dst
[i
][RCOMP
] = (s
[i
] >> 8) & 0xff;
2611 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2612 dst
[i
][BCOMP
] = (s
[i
] >> 24);
2613 dst
[i
][ACOMP
] = 0xff;
2618 unpack_ubyte_RGB888(const void *src
, GLubyte dst
[][4], GLuint n
)
2620 const GLubyte
*s
= (const GLubyte
*) src
;
2622 for (i
= 0; i
< n
; i
++) {
2623 dst
[i
][RCOMP
] = s
[i
*3+2];
2624 dst
[i
][GCOMP
] = s
[i
*3+1];
2625 dst
[i
][BCOMP
] = s
[i
*3+0];
2626 dst
[i
][ACOMP
] = 0xff;
2631 unpack_ubyte_BGR888(const void *src
, GLubyte dst
[][4], GLuint n
)
2633 const GLubyte
*s
= (const GLubyte
*) src
;
2635 for (i
= 0; i
< n
; i
++) {
2636 dst
[i
][RCOMP
] = s
[i
*3+0];
2637 dst
[i
][GCOMP
] = s
[i
*3+1];
2638 dst
[i
][BCOMP
] = s
[i
*3+2];
2639 dst
[i
][ACOMP
] = 0xff;
2644 unpack_ubyte_RGB565(const void *src
, GLubyte dst
[][4], GLuint n
)
2646 const GLushort
*s
= ((const GLushort
*) src
);
2648 for (i
= 0; i
< n
; i
++) {
2649 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 11) & 0x1f);
2650 dst
[i
][GCOMP
] = EXPAND_6_8((s
[i
] >> 5 ) & 0x3f);
2651 dst
[i
][BCOMP
] = EXPAND_5_8( s
[i
] & 0x1f);
2652 dst
[i
][ACOMP
] = 0xff;
2657 unpack_ubyte_RGB565_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2659 const GLushort
*s
= ((const GLushort
*) src
);
2661 for (i
= 0; i
< n
; i
++) {
2662 GLuint t
= (s
[i
] >> 8) | (s
[i
] << 8); /* byte swap */
2663 dst
[i
][RCOMP
] = EXPAND_5_8((t
>> 11) & 0x1f);
2664 dst
[i
][GCOMP
] = EXPAND_6_8((t
>> 5 ) & 0x3f);
2665 dst
[i
][BCOMP
] = EXPAND_5_8( t
& 0x1f);
2666 dst
[i
][ACOMP
] = 0xff;
2671 unpack_ubyte_ARGB4444(const void *src
, GLubyte dst
[][4], GLuint n
)
2673 const GLushort
*s
= ((const GLushort
*) src
);
2675 for (i
= 0; i
< n
; i
++) {
2676 dst
[i
][RCOMP
] = EXPAND_4_8((s
[i
] >> 8) & 0xf);
2677 dst
[i
][GCOMP
] = EXPAND_4_8((s
[i
] >> 4) & 0xf);
2678 dst
[i
][BCOMP
] = EXPAND_4_8((s
[i
] ) & 0xf);
2679 dst
[i
][ACOMP
] = EXPAND_4_8((s
[i
] >> 12) & 0xf);
2684 unpack_ubyte_ARGB4444_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2686 const GLushort
*s
= ((const GLushort
*) src
);
2688 for (i
= 0; i
< n
; i
++) {
2689 dst
[i
][RCOMP
] = EXPAND_4_8((s
[i
] ) & 0xf);
2690 dst
[i
][GCOMP
] = EXPAND_4_8((s
[i
] >> 12) & 0xf);
2691 dst
[i
][BCOMP
] = EXPAND_4_8((s
[i
] >> 8) & 0xf);
2692 dst
[i
][ACOMP
] = EXPAND_4_8((s
[i
] >> 4) & 0xf);
2697 unpack_ubyte_RGBA5551(const void *src
, GLubyte dst
[][4], GLuint n
)
2699 const GLushort
*s
= ((const GLushort
*) src
);
2701 for (i
= 0; i
< n
; i
++) {
2702 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 11) & 0x1f);
2703 dst
[i
][GCOMP
] = EXPAND_5_8((s
[i
] >> 6) & 0x1f);
2704 dst
[i
][BCOMP
] = EXPAND_5_8((s
[i
] >> 1) & 0x1f);
2705 dst
[i
][ACOMP
] = EXPAND_1_8((s
[i
] ) & 0x01);
2710 unpack_ubyte_ARGB1555(const void *src
, GLubyte dst
[][4], GLuint n
)
2712 const GLushort
*s
= ((const GLushort
*) src
);
2714 for (i
= 0; i
< n
; i
++) {
2715 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 10) & 0x1f);
2716 dst
[i
][GCOMP
] = EXPAND_5_8((s
[i
] >> 5) & 0x1f);
2717 dst
[i
][BCOMP
] = EXPAND_5_8((s
[i
] >> 0) & 0x1f);
2718 dst
[i
][ACOMP
] = EXPAND_1_8((s
[i
] >> 15) & 0x01);
2723 unpack_ubyte_ARGB1555_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2725 const GLushort
*s
= ((const GLushort
*) src
);
2727 for (i
= 0; i
< n
; i
++) {
2728 GLushort tmp
= (s
[i
] << 8) | (s
[i
] >> 8); /* byteswap */
2729 dst
[i
][RCOMP
] = EXPAND_5_8((tmp
>> 10) & 0x1f);
2730 dst
[i
][GCOMP
] = EXPAND_5_8((tmp
>> 5) & 0x1f);
2731 dst
[i
][BCOMP
] = EXPAND_5_8((tmp
>> 0) & 0x1f);
2732 dst
[i
][ACOMP
] = EXPAND_1_8((tmp
>> 15) & 0x01);
2737 unpack_ubyte_AL44(const void *src
, GLubyte dst
[][4], GLuint n
)
2739 const GLubyte
*s
= ((const GLubyte
*) src
);
2741 for (i
= 0; i
< n
; i
++) {
2744 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] & 0xf);
2745 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] >> 4);
2750 unpack_ubyte_AL88(const void *src
, GLubyte dst
[][4], GLuint n
)
2752 const GLushort
*s
= ((const GLushort
*) src
);
2754 for (i
= 0; i
< n
; i
++) {
2757 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] & 0xff);
2758 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] >> 8);
2763 unpack_ubyte_AL88_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2765 const GLushort
*s
= ((const GLushort
*) src
);
2767 for (i
= 0; i
< n
; i
++) {
2770 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] >> 8);
2771 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] & 0xff);
2776 unpack_ubyte_RGB332(const void *src
, GLubyte dst
[][4], GLuint n
)
2778 const GLubyte
*s
= ((const GLubyte
*) src
);
2780 for (i
= 0; i
< n
; i
++) {
2781 dst
[i
][RCOMP
] = EXPAND_3_8((s
[i
] >> 5) & 0x7);
2782 dst
[i
][GCOMP
] = EXPAND_3_8((s
[i
] >> 2) & 0x7);
2783 dst
[i
][BCOMP
] = EXPAND_2_8((s
[i
] ) & 0x3);
2784 dst
[i
][ACOMP
] = 0xff;
2789 unpack_ubyte_A8(const void *src
, GLubyte dst
[][4], GLuint n
)
2791 const GLubyte
*s
= ((const GLubyte
*) src
);
2793 for (i
= 0; i
< n
; i
++) {
2797 dst
[i
][ACOMP
] = s
[i
];
2802 unpack_ubyte_L8(const void *src
, GLubyte dst
[][4], GLuint n
)
2804 const GLubyte
*s
= ((const GLubyte
*) src
);
2806 for (i
= 0; i
< n
; i
++) {
2809 dst
[i
][BCOMP
] = s
[i
];
2810 dst
[i
][ACOMP
] = 0xff;
2816 unpack_ubyte_I8(const void *src
, GLubyte dst
[][4], GLuint n
)
2818 const GLubyte
*s
= ((const GLubyte
*) src
);
2820 for (i
= 0; i
< n
; i
++) {
2824 dst
[i
][ACOMP
] = s
[i
];
2829 unpack_ubyte_R8(const void *src
, GLubyte dst
[][4], GLuint n
)
2831 const GLubyte
*s
= ((const GLubyte
*) src
);
2833 for (i
= 0; i
< n
; i
++) {
2842 unpack_ubyte_GR88(const void *src
, GLubyte dst
[][4], GLuint n
)
2844 const GLushort
*s
= ((const GLushort
*) src
);
2846 for (i
= 0; i
< n
; i
++) {
2847 dst
[i
][RCOMP
] = s
[i
] & 0xff;
2848 dst
[i
][GCOMP
] = s
[i
] >> 8;
2850 dst
[i
][ACOMP
] = 0xff;
2855 unpack_ubyte_RG88(const void *src
, GLubyte dst
[][4], GLuint n
)
2857 const GLushort
*s
= ((const GLushort
*) src
);
2859 for (i
= 0; i
< n
; i
++) {
2860 dst
[i
][RCOMP
] = s
[i
] >> 8;
2861 dst
[i
][GCOMP
] = s
[i
] & 0xff;
2863 dst
[i
][ACOMP
] = 0xff;
2869 * Unpack rgba colors, returning as GLubyte values. This should usually
2870 * only be used for unpacking formats that use 8 bits or less per channel.
2873 _mesa_unpack_ubyte_rgba_row(gl_format format
, GLuint n
,
2874 const void *src
, GLubyte dst
[][4])
2877 case MESA_FORMAT_RGBA8888
:
2878 unpack_ubyte_RGBA8888(src
, dst
, n
);
2880 case MESA_FORMAT_RGBA8888_REV
:
2881 unpack_ubyte_RGBA8888_REV(src
, dst
, n
);
2883 case MESA_FORMAT_ARGB8888
:
2884 unpack_ubyte_ARGB8888(src
, dst
, n
);
2886 case MESA_FORMAT_ARGB8888_REV
:
2887 unpack_ubyte_ARGB8888_REV(src
, dst
, n
);
2889 case MESA_FORMAT_RGBX8888
:
2890 unpack_ubyte_RGBX8888(src
, dst
, n
);
2892 case MESA_FORMAT_RGBX8888_REV
:
2893 unpack_ubyte_RGBX8888_REV(src
, dst
, n
);
2895 case MESA_FORMAT_XRGB8888
:
2896 unpack_ubyte_XRGB8888(src
, dst
, n
);
2898 case MESA_FORMAT_XRGB8888_REV
:
2899 unpack_ubyte_XRGB8888_REV(src
, dst
, n
);
2901 case MESA_FORMAT_RGB888
:
2902 unpack_ubyte_RGB888(src
, dst
, n
);
2904 case MESA_FORMAT_BGR888
:
2905 unpack_ubyte_BGR888(src
, dst
, n
);
2907 case MESA_FORMAT_RGB565
:
2908 unpack_ubyte_RGB565(src
, dst
, n
);
2910 case MESA_FORMAT_RGB565_REV
:
2911 unpack_ubyte_RGB565_REV(src
, dst
, n
);
2913 case MESA_FORMAT_ARGB4444
:
2914 unpack_ubyte_ARGB4444(src
, dst
, n
);
2916 case MESA_FORMAT_ARGB4444_REV
:
2917 unpack_ubyte_ARGB4444_REV(src
, dst
, n
);
2919 case MESA_FORMAT_RGBA5551
:
2920 unpack_ubyte_RGBA5551(src
, dst
, n
);
2922 case MESA_FORMAT_ARGB1555
:
2923 unpack_ubyte_ARGB1555(src
, dst
, n
);
2925 case MESA_FORMAT_ARGB1555_REV
:
2926 unpack_ubyte_ARGB1555_REV(src
, dst
, n
);
2928 case MESA_FORMAT_AL44
:
2929 unpack_ubyte_AL44(src
, dst
, n
);
2931 case MESA_FORMAT_AL88
:
2932 unpack_ubyte_AL88(src
, dst
, n
);
2934 case MESA_FORMAT_AL88_REV
:
2935 unpack_ubyte_AL88_REV(src
, dst
, n
);
2937 case MESA_FORMAT_RGB332
:
2938 unpack_ubyte_RGB332(src
, dst
, n
);
2940 case MESA_FORMAT_A8
:
2941 unpack_ubyte_A8(src
, dst
, n
);
2943 case MESA_FORMAT_L8
:
2944 unpack_ubyte_L8(src
, dst
, n
);
2946 case MESA_FORMAT_I8
:
2947 unpack_ubyte_I8(src
, dst
, n
);
2949 case MESA_FORMAT_R8
:
2950 unpack_ubyte_R8(src
, dst
, n
);
2952 case MESA_FORMAT_GR88
:
2953 unpack_ubyte_GR88(src
, dst
, n
);
2955 case MESA_FORMAT_RG88
:
2956 unpack_ubyte_RG88(src
, dst
, n
);
2959 /* get float values, convert to ubyte */
2961 GLfloat
*tmp
= malloc(n
* 4 * sizeof(GLfloat
));
2964 _mesa_unpack_rgba_row(format
, n
, src
, (GLfloat (*)[4]) tmp
);
2965 for (i
= 0; i
< n
; i
++) {
2966 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][0], tmp
[i
*4+0]);
2967 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][1], tmp
[i
*4+1]);
2968 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][2], tmp
[i
*4+2]);
2969 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][3], tmp
[i
*4+3]);
2979 /**********************************************************************/
2980 /* Unpack, returning GLuint colors */
2981 /**********************************************************************/
2984 unpack_int_rgba_RGBA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
2986 memcpy(dst
, src
, n
* 4 * sizeof(GLuint
));
2990 unpack_int_rgba_RGBA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
2994 for (i
= 0; i
< n
; i
++) {
2995 dst
[i
][0] = src
[i
* 4 + 0];
2996 dst
[i
][1] = src
[i
* 4 + 1];
2997 dst
[i
][2] = src
[i
* 4 + 2];
2998 dst
[i
][3] = src
[i
* 4 + 3];
3003 unpack_int_rgba_RGBA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3007 for (i
= 0; i
< n
; i
++) {
3008 dst
[i
][0] = src
[i
* 4 + 0];
3009 dst
[i
][1] = src
[i
* 4 + 1];
3010 dst
[i
][2] = src
[i
* 4 + 2];
3011 dst
[i
][3] = src
[i
* 4 + 3];
3016 unpack_int_rgba_RGBA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3020 for (i
= 0; i
< n
; i
++) {
3021 dst
[i
][0] = src
[i
* 4 + 0];
3022 dst
[i
][1] = src
[i
* 4 + 1];
3023 dst
[i
][2] = src
[i
* 4 + 2];
3024 dst
[i
][3] = src
[i
* 4 + 3];
3029 unpack_int_rgba_RGBA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3033 for (i
= 0; i
< n
; i
++) {
3034 dst
[i
][0] = src
[i
* 4 + 0];
3035 dst
[i
][1] = src
[i
* 4 + 1];
3036 dst
[i
][2] = src
[i
* 4 + 2];
3037 dst
[i
][3] = src
[i
* 4 + 3];
3042 unpack_int_rgba_ARGB8888(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3046 for (i
= 0; i
< n
; i
++) {
3047 dst
[i
][RCOMP
] = (GLubyte
) src
[i
* 4 + 2];
3048 dst
[i
][GCOMP
] = (GLubyte
) src
[i
* 4 + 1];
3049 dst
[i
][BCOMP
] = (GLubyte
) src
[i
* 4 + 0];
3050 dst
[i
][ACOMP
] = (GLubyte
) src
[i
* 4 + 3];
3055 unpack_int_rgba_XRGB8888(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3059 for (i
= 0; i
< n
; i
++) {
3060 dst
[i
][RCOMP
] = (GLubyte
) src
[i
* 4 + 2];
3061 dst
[i
][GCOMP
] = (GLubyte
) src
[i
* 4 + 1];
3062 dst
[i
][BCOMP
] = (GLubyte
) src
[i
* 4 + 0];
3063 dst
[i
][ACOMP
] = (GLubyte
) 0xff;
3068 unpack_int_rgba_RGB_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3072 for (i
= 0; i
< n
; i
++) {
3073 dst
[i
][0] = src
[i
* 3 + 0];
3074 dst
[i
][1] = src
[i
* 3 + 1];
3075 dst
[i
][2] = src
[i
* 3 + 2];
3081 unpack_int_rgba_RGB_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3085 for (i
= 0; i
< n
; i
++) {
3086 dst
[i
][0] = src
[i
* 3 + 0];
3087 dst
[i
][1] = src
[i
* 3 + 1];
3088 dst
[i
][2] = src
[i
* 3 + 2];
3094 unpack_int_rgba_RGB_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3098 for (i
= 0; i
< n
; i
++) {
3099 dst
[i
][0] = src
[i
* 3 + 0];
3100 dst
[i
][1] = src
[i
* 3 + 1];
3101 dst
[i
][2] = src
[i
* 3 + 2];
3107 unpack_int_rgba_RGB_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3111 for (i
= 0; i
< n
; i
++) {
3112 dst
[i
][0] = src
[i
* 3 + 0];
3113 dst
[i
][1] = src
[i
* 3 + 1];
3114 dst
[i
][2] = src
[i
* 3 + 2];
3120 unpack_int_rgba_RGB_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3124 for (i
= 0; i
< n
; i
++) {
3125 dst
[i
][0] = src
[i
* 3 + 0];
3126 dst
[i
][1] = src
[i
* 3 + 1];
3127 dst
[i
][2] = src
[i
* 3 + 2];
3133 unpack_int_rgba_RG_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3137 for (i
= 0; i
< n
; i
++) {
3138 dst
[i
][0] = src
[i
* 2 + 0];
3139 dst
[i
][1] = src
[i
* 2 + 1];
3146 unpack_int_rgba_RG_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3150 for (i
= 0; i
< n
; i
++) {
3151 dst
[i
][0] = src
[i
* 2 + 0];
3152 dst
[i
][1] = src
[i
* 2 + 1];
3159 unpack_int_rgba_RG_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3163 for (i
= 0; i
< n
; i
++) {
3164 dst
[i
][0] = src
[i
* 2 + 0];
3165 dst
[i
][1] = src
[i
* 2 + 1];
3172 unpack_int_rgba_RG_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3176 for (i
= 0; i
< n
; i
++) {
3177 dst
[i
][0] = src
[i
* 2 + 0];
3178 dst
[i
][1] = src
[i
* 2 + 1];
3185 unpack_int_rgba_RG_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3189 for (i
= 0; i
< n
; i
++) {
3190 dst
[i
][0] = src
[i
* 2 + 0];
3191 dst
[i
][1] = src
[i
* 2 + 1];
3198 unpack_int_rgba_R_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3202 for (i
= 0; i
< n
; i
++) {
3211 unpack_int_rgba_R_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3215 for (i
= 0; i
< n
; i
++) {
3224 unpack_int_rgba_R_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3228 for (i
= 0; i
< n
; i
++) {
3237 unpack_int_rgba_R_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3241 for (i
= 0; i
< n
; i
++) {
3250 unpack_int_rgba_R_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3254 for (i
= 0; i
< n
; i
++) {
3263 unpack_int_rgba_ALPHA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3267 for (i
= 0; i
< n
; i
++) {
3268 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3274 unpack_int_rgba_ALPHA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3278 for (i
= 0; i
< n
; i
++) {
3279 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3285 unpack_int_rgba_ALPHA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3289 for (i
= 0; i
< n
; i
++) {
3290 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3296 unpack_int_rgba_ALPHA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3300 for (i
= 0; i
< n
; i
++) {
3301 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3307 unpack_int_rgba_ALPHA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3311 for (i
= 0; i
< n
; i
++) {
3312 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3318 unpack_int_rgba_LUMINANCE_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3322 for (i
= 0; i
< n
; i
++) {
3323 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3329 unpack_int_rgba_LUMINANCE_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3333 for (i
= 0; i
< n
; i
++) {
3334 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3340 unpack_int_rgba_LUMINANCE_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3344 for (i
= 0; i
< n
; i
++) {
3345 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3351 unpack_int_rgba_LUMINANCE_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3355 for (i
= 0; i
< n
; i
++) {
3356 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3362 unpack_int_rgba_LUMINANCE_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3366 for (i
= 0; i
< n
; i
++) {
3367 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3374 unpack_int_rgba_LUMINANCE_ALPHA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3378 for (i
= 0; i
< n
; i
++) {
3379 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3380 dst
[i
][3] = src
[i
* 2 + 1];
3385 unpack_int_rgba_LUMINANCE_ALPHA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3389 for (i
= 0; i
< n
; i
++) {
3390 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3391 dst
[i
][3] = src
[i
* 2 + 1];
3396 unpack_int_rgba_LUMINANCE_ALPHA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3400 for (i
= 0; i
< n
; i
++) {
3401 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3402 dst
[i
][3] = src
[i
* 2 + 1];
3407 unpack_int_rgba_LUMINANCE_ALPHA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3411 for (i
= 0; i
< n
; i
++) {
3412 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3413 dst
[i
][3] = src
[i
* 2 + 1];
3418 unpack_int_rgba_LUMINANCE_ALPHA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3422 for (i
= 0; i
< n
; i
++) {
3423 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3424 dst
[i
][3] = src
[i
* 2 + 1];
3429 unpack_int_rgba_INTENSITY_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3433 for (i
= 0; i
< n
; i
++) {
3434 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3439 unpack_int_rgba_INTENSITY_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3443 for (i
= 0; i
< n
; i
++) {
3444 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3449 unpack_int_rgba_INTENSITY_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3453 for (i
= 0; i
< n
; i
++) {
3454 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3459 unpack_int_rgba_INTENSITY_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3463 for (i
= 0; i
< n
; i
++) {
3464 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3469 unpack_int_rgba_INTENSITY_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3473 for (i
= 0; i
< n
; i
++) {
3474 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3479 unpack_int_rgba_ARGB2101010_UINT(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3483 for (i
= 0; i
< n
; i
++) {
3484 GLuint tmp
= src
[i
];
3485 dst
[i
][0] = (tmp
>> 20) & 0x3ff;
3486 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3487 dst
[i
][2] = (tmp
>> 0) & 0x3ff;
3488 dst
[i
][3] = (tmp
>> 30) & 0x3;
3493 unpack_int_rgba_ABGR2101010_UINT(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3497 for (i
= 0; i
< n
; i
++) {
3498 GLuint tmp
= src
[i
];
3499 dst
[i
][0] = (tmp
>> 0) & 0x3ff;
3500 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3501 dst
[i
][2] = (tmp
>> 20) & 0x3ff;
3502 dst
[i
][3] = (tmp
>> 30) & 0x3;
3507 unpack_int_rgba_ARGB2101010(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3511 for (i
= 0; i
< n
; i
++) {
3512 GLuint tmp
= src
[i
];
3513 dst
[i
][0] = (tmp
>> 20) & 0x3ff;
3514 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3515 dst
[i
][2] = (tmp
>> 0) & 0x3ff;
3516 dst
[i
][3] = (tmp
>> 30) & 0x3;
3521 unpack_int_rgba_XBGR8888_UINT(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3525 for (i
= 0; i
< n
; i
++) {
3526 dst
[i
][0] = src
[i
* 4 + 0];
3527 dst
[i
][1] = src
[i
* 4 + 1];
3528 dst
[i
][2] = src
[i
* 4 + 2];
3534 unpack_int_rgba_XBGR8888_SINT(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3538 for (i
= 0; i
< n
; i
++) {
3539 dst
[i
][0] = src
[i
* 4 + 0];
3540 dst
[i
][1] = src
[i
* 4 + 1];
3541 dst
[i
][2] = src
[i
* 4 + 2];
3547 unpack_int_rgba_XBGR16161616_UINT(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3551 for (i
= 0; i
< n
; i
++) {
3552 dst
[i
][0] = src
[i
* 4 + 0];
3553 dst
[i
][1] = src
[i
* 4 + 1];
3554 dst
[i
][2] = src
[i
* 4 + 2];
3560 unpack_int_rgba_XBGR16161616_SINT(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3564 for (i
= 0; i
< n
; i
++) {
3565 dst
[i
][0] = src
[i
* 4 + 0];
3566 dst
[i
][1] = src
[i
* 4 + 1];
3567 dst
[i
][2] = src
[i
* 4 + 2];
3573 unpack_int_rgba_XBGR32323232_UINT(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3577 for (i
= 0; i
< n
; i
++) {
3578 dst
[i
][0] = src
[i
* 4 + 0];
3579 dst
[i
][1] = src
[i
* 4 + 1];
3580 dst
[i
][2] = src
[i
* 4 + 2];
3586 _mesa_unpack_uint_rgba_row(gl_format format
, GLuint n
,
3587 const void *src
, GLuint dst
[][4])
3590 /* Since there won't be any sign extension happening, there's no need to
3591 * make separate paths for 32-bit-to-32-bit integer unpack.
3593 case MESA_FORMAT_RGBA_UINT32
:
3594 case MESA_FORMAT_RGBA_INT32
:
3595 unpack_int_rgba_RGBA_UINT32(src
, dst
, n
);
3598 case MESA_FORMAT_RGBA_UINT16
:
3599 unpack_int_rgba_RGBA_UINT16(src
, dst
, n
);
3601 case MESA_FORMAT_RGBA_INT16
:
3602 unpack_int_rgba_RGBA_INT16(src
, dst
, n
);
3605 case MESA_FORMAT_RGBA_UINT8
:
3606 unpack_int_rgba_RGBA_UINT8(src
, dst
, n
);
3608 case MESA_FORMAT_RGBA_INT8
:
3609 unpack_int_rgba_RGBA_INT8(src
, dst
, n
);
3612 case MESA_FORMAT_ARGB8888
:
3613 unpack_int_rgba_ARGB8888(src
, dst
, n
);
3616 case MESA_FORMAT_XRGB8888
:
3617 unpack_int_rgba_XRGB8888(src
, dst
, n
);
3620 case MESA_FORMAT_RGB_UINT32
:
3621 case MESA_FORMAT_RGB_INT32
:
3622 unpack_int_rgba_RGB_UINT32(src
, dst
, n
);
3625 case MESA_FORMAT_RGB_UINT16
:
3626 unpack_int_rgba_RGB_UINT16(src
, dst
, n
);
3628 case MESA_FORMAT_RGB_INT16
:
3629 unpack_int_rgba_RGB_INT16(src
, dst
, n
);
3632 case MESA_FORMAT_RGB_UINT8
:
3633 unpack_int_rgba_RGB_UINT8(src
, dst
, n
);
3635 case MESA_FORMAT_RGB_INT8
:
3636 unpack_int_rgba_RGB_INT8(src
, dst
, n
);
3639 case MESA_FORMAT_RG_UINT32
:
3640 case MESA_FORMAT_RG_INT32
:
3641 unpack_int_rgba_RG_UINT32(src
, dst
, n
);
3644 case MESA_FORMAT_RG_UINT16
:
3645 unpack_int_rgba_RG_UINT16(src
, dst
, n
);
3647 case MESA_FORMAT_RG_INT16
:
3648 unpack_int_rgba_RG_INT16(src
, dst
, n
);
3651 case MESA_FORMAT_RG_UINT8
:
3652 unpack_int_rgba_RG_UINT8(src
, dst
, n
);
3654 case MESA_FORMAT_RG_INT8
:
3655 unpack_int_rgba_RG_INT8(src
, dst
, n
);
3658 case MESA_FORMAT_R_UINT32
:
3659 case MESA_FORMAT_R_INT32
:
3660 unpack_int_rgba_R_UINT32(src
, dst
, n
);
3663 case MESA_FORMAT_R_UINT16
:
3664 unpack_int_rgba_R_UINT16(src
, dst
, n
);
3666 case MESA_FORMAT_R_INT16
:
3667 unpack_int_rgba_R_INT16(src
, dst
, n
);
3670 case MESA_FORMAT_R_UINT8
:
3671 unpack_int_rgba_R_UINT8(src
, dst
, n
);
3673 case MESA_FORMAT_R_INT8
:
3674 unpack_int_rgba_R_INT8(src
, dst
, n
);
3677 case MESA_FORMAT_ALPHA_UINT32
:
3678 case MESA_FORMAT_ALPHA_INT32
:
3679 unpack_int_rgba_ALPHA_UINT32(src
, dst
, n
);
3682 case MESA_FORMAT_ALPHA_UINT16
:
3683 unpack_int_rgba_ALPHA_UINT16(src
, dst
, n
);
3685 case MESA_FORMAT_ALPHA_INT16
:
3686 unpack_int_rgba_ALPHA_INT16(src
, dst
, n
);
3689 case MESA_FORMAT_ALPHA_UINT8
:
3690 unpack_int_rgba_ALPHA_UINT8(src
, dst
, n
);
3692 case MESA_FORMAT_ALPHA_INT8
:
3693 unpack_int_rgba_ALPHA_INT8(src
, dst
, n
);
3696 case MESA_FORMAT_LUMINANCE_UINT32
:
3697 case MESA_FORMAT_LUMINANCE_INT32
:
3698 unpack_int_rgba_LUMINANCE_UINT32(src
, dst
, n
);
3700 case MESA_FORMAT_LUMINANCE_UINT16
:
3701 unpack_int_rgba_LUMINANCE_UINT16(src
, dst
, n
);
3703 case MESA_FORMAT_LUMINANCE_INT16
:
3704 unpack_int_rgba_LUMINANCE_INT16(src
, dst
, n
);
3707 case MESA_FORMAT_LUMINANCE_UINT8
:
3708 unpack_int_rgba_LUMINANCE_UINT8(src
, dst
, n
);
3710 case MESA_FORMAT_LUMINANCE_INT8
:
3711 unpack_int_rgba_LUMINANCE_INT8(src
, dst
, n
);
3714 case MESA_FORMAT_LUMINANCE_ALPHA_UINT32
:
3715 case MESA_FORMAT_LUMINANCE_ALPHA_INT32
:
3716 unpack_int_rgba_LUMINANCE_ALPHA_UINT32(src
, dst
, n
);
3719 case MESA_FORMAT_LUMINANCE_ALPHA_UINT16
:
3720 unpack_int_rgba_LUMINANCE_ALPHA_UINT16(src
, dst
, n
);
3722 case MESA_FORMAT_LUMINANCE_ALPHA_INT16
:
3723 unpack_int_rgba_LUMINANCE_ALPHA_INT16(src
, dst
, n
);
3726 case MESA_FORMAT_LUMINANCE_ALPHA_UINT8
:
3727 unpack_int_rgba_LUMINANCE_ALPHA_UINT8(src
, dst
, n
);
3729 case MESA_FORMAT_LUMINANCE_ALPHA_INT8
:
3730 unpack_int_rgba_LUMINANCE_ALPHA_INT8(src
, dst
, n
);
3733 case MESA_FORMAT_INTENSITY_UINT32
:
3734 case MESA_FORMAT_INTENSITY_INT32
:
3735 unpack_int_rgba_INTENSITY_UINT32(src
, dst
, n
);
3738 case MESA_FORMAT_INTENSITY_UINT16
:
3739 unpack_int_rgba_INTENSITY_UINT16(src
, dst
, n
);
3741 case MESA_FORMAT_INTENSITY_INT16
:
3742 unpack_int_rgba_INTENSITY_INT16(src
, dst
, n
);
3745 case MESA_FORMAT_INTENSITY_UINT8
:
3746 unpack_int_rgba_INTENSITY_UINT8(src
, dst
, n
);
3748 case MESA_FORMAT_INTENSITY_INT8
:
3749 unpack_int_rgba_INTENSITY_INT8(src
, dst
, n
);
3752 case MESA_FORMAT_ARGB2101010_UINT
:
3753 unpack_int_rgba_ARGB2101010_UINT(src
, dst
, n
);
3756 case MESA_FORMAT_ABGR2101010_UINT
:
3757 unpack_int_rgba_ABGR2101010_UINT(src
, dst
, n
);
3760 case MESA_FORMAT_ARGB2101010
:
3761 unpack_int_rgba_ARGB2101010(src
, dst
, n
);
3764 case MESA_FORMAT_XBGR8888_UINT
:
3765 unpack_int_rgba_XBGR8888_UINT(src
, dst
, n
);
3768 case MESA_FORMAT_XBGR8888_SINT
:
3769 unpack_int_rgba_XBGR8888_SINT(src
, dst
, n
);
3772 case MESA_FORMAT_XBGR16161616_UINT
:
3773 unpack_int_rgba_XBGR16161616_UINT(src
, dst
, n
);
3776 case MESA_FORMAT_XBGR16161616_SINT
:
3777 unpack_int_rgba_XBGR16161616_SINT(src
, dst
, n
);
3780 case MESA_FORMAT_XBGR32323232_UINT
:
3781 case MESA_FORMAT_XBGR32323232_SINT
:
3782 unpack_int_rgba_XBGR32323232_UINT(src
, dst
, n
);
3786 _mesa_problem(NULL
, "%s: bad format %s", __FUNCTION__
,
3787 _mesa_get_format_name(format
));
3793 * Unpack a 2D rect of pixels returning float RGBA colors.
3794 * \param format the source image format
3795 * \param src start address of the source image
3796 * \param srcRowStride source image row stride in bytes
3797 * \param dst start address of the dest image
3798 * \param dstRowStride dest image row stride in bytes
3799 * \param x source image start X pos
3800 * \param y source image start Y pos
3801 * \param width width of rect region to convert
3802 * \param height height of rect region to convert
3805 _mesa_unpack_rgba_block(gl_format format
,
3806 const void *src
, GLint srcRowStride
,
3807 GLfloat dst
[][4], GLint dstRowStride
,
3808 GLuint x
, GLuint y
, GLuint width
, GLuint height
)
3810 unpack_rgba_func unpack
= get_unpack_rgba_function(format
);
3811 const GLuint srcPixStride
= _mesa_get_format_bytes(format
);
3812 const GLuint dstPixStride
= 4 * sizeof(GLfloat
);
3813 const GLubyte
*srcRow
;
3817 /* XXX needs to be fixed for compressed formats */
3819 srcRow
= ((const GLubyte
*) src
) + srcRowStride
* y
+ srcPixStride
* x
;
3820 dstRow
= ((GLubyte
*) dst
) + dstRowStride
* y
+ dstPixStride
* x
;
3822 for (i
= 0; i
< height
; i
++) {
3823 unpack(srcRow
, (GLfloat (*)[4]) dstRow
, width
);
3825 dstRow
+= dstRowStride
;
3826 srcRow
+= srcRowStride
;
3833 typedef void (*unpack_float_z_func
)(GLuint n
, const void *src
, GLfloat
*dst
);
3836 unpack_float_z_Z24_X8(GLuint n
, const void *src
, GLfloat
*dst
)
3838 /* only return Z, not stencil data */
3839 const GLuint
*s
= ((const GLuint
*) src
);
3840 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
3842 for (i
= 0; i
< n
; i
++) {
3843 dst
[i
] = (GLfloat
) ((s
[i
] >> 8) * scale
);
3844 ASSERT(dst
[i
] >= 0.0F
);
3845 ASSERT(dst
[i
] <= 1.0F
);
3850 unpack_float_z_X8_Z24(GLuint n
, const void *src
, GLfloat
*dst
)
3852 /* only return Z, not stencil data */
3853 const GLuint
*s
= ((const GLuint
*) src
);
3854 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
3856 for (i
= 0; i
< n
; i
++) {
3857 dst
[i
] = (GLfloat
) ((s
[i
] & 0x00ffffff) * scale
);
3858 ASSERT(dst
[i
] >= 0.0F
);
3859 ASSERT(dst
[i
] <= 1.0F
);
3864 unpack_float_z_Z16(GLuint n
, const void *src
, GLfloat
*dst
)
3866 const GLushort
*s
= ((const GLushort
*) src
);
3868 for (i
= 0; i
< n
; i
++) {
3869 dst
[i
] = s
[i
] * (1.0F
/ 65535.0F
);
3874 unpack_float_z_Z32(GLuint n
, const void *src
, GLfloat
*dst
)
3876 const GLuint
*s
= ((const GLuint
*) src
);
3878 for (i
= 0; i
< n
; i
++) {
3879 dst
[i
] = s
[i
] * (1.0F
/ 0xffffffff);
3884 unpack_float_z_Z32F(GLuint n
, const void *src
, GLfloat
*dst
)
3886 memcpy(dst
, src
, n
* sizeof(float));
3890 unpack_float_z_Z32X24S8(GLuint n
, const void *src
, GLfloat
*dst
)
3892 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
3894 for (i
= 0; i
< n
; i
++) {
3903 * The returned values will always be in the range [0.0, 1.0].
3906 _mesa_unpack_float_z_row(gl_format format
, GLuint n
,
3907 const void *src
, GLfloat
*dst
)
3909 unpack_float_z_func unpack
;
3912 case MESA_FORMAT_Z24_S8
:
3913 case MESA_FORMAT_Z24_X8
:
3914 unpack
= unpack_float_z_Z24_X8
;
3916 case MESA_FORMAT_S8_Z24
:
3917 case MESA_FORMAT_X8_Z24
:
3918 unpack
= unpack_float_z_X8_Z24
;
3920 case MESA_FORMAT_Z16
:
3921 unpack
= unpack_float_z_Z16
;
3923 case MESA_FORMAT_Z32
:
3924 unpack
= unpack_float_z_Z32
;
3926 case MESA_FORMAT_Z32_FLOAT
:
3927 unpack
= unpack_float_z_Z32F
;
3929 case MESA_FORMAT_Z32_FLOAT_X24S8
:
3930 unpack
= unpack_float_z_Z32X24S8
;
3933 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_float_z_row",
3934 _mesa_get_format_name(format
));
3938 unpack(n
, src
, dst
);
3943 typedef void (*unpack_uint_z_func
)(const void *src
, GLuint
*dst
, GLuint n
);
3946 unpack_uint_z_Z24_X8(const void *src
, GLuint
*dst
, GLuint n
)
3948 /* only return Z, not stencil data */
3949 const GLuint
*s
= ((const GLuint
*) src
);
3951 for (i
= 0; i
< n
; i
++) {
3952 dst
[i
] = (s
[i
] & 0xffffff00) | (s
[i
] >> 24);
3957 unpack_uint_z_X8_Z24(const void *src
, GLuint
*dst
, GLuint n
)
3959 /* only return Z, not stencil data */
3960 const GLuint
*s
= ((const GLuint
*) src
);
3962 for (i
= 0; i
< n
; i
++) {
3963 dst
[i
] = (s
[i
] << 8) | ((s
[i
] >> 16) & 0xff);
3968 unpack_uint_z_Z16(const void *src
, GLuint
*dst
, GLuint n
)
3970 const GLushort
*s
= ((const GLushort
*)src
);
3972 for (i
= 0; i
< n
; i
++) {
3973 dst
[i
] = (s
[i
] << 16) | s
[i
];
3978 unpack_uint_z_Z32(const void *src
, GLuint
*dst
, GLuint n
)
3980 memcpy(dst
, src
, n
* sizeof(GLuint
));
3984 unpack_uint_z_Z32_FLOAT(const void *src
, GLuint
*dst
, GLuint n
)
3986 const float *s
= (const float *)src
;
3988 for (i
= 0; i
< n
; i
++) {
3989 dst
[i
] = FLOAT_TO_UINT(CLAMP(s
[i
], 0.0F
, 1.0F
));
3994 unpack_uint_z_Z32_FLOAT_X24S8(const void *src
, GLuint
*dst
, GLuint n
)
3996 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
3999 for (i
= 0; i
< n
; i
++) {
4000 dst
[i
] = FLOAT_TO_UINT(CLAMP(s
[i
].z
, 0.0F
, 1.0F
));
4007 * The returned values will always be in the range [0, 0xffffffff].
4010 _mesa_unpack_uint_z_row(gl_format format
, GLuint n
,
4011 const void *src
, GLuint
*dst
)
4013 unpack_uint_z_func unpack
;
4014 const GLubyte
*srcPtr
= (GLubyte
*) src
;
4017 case MESA_FORMAT_Z24_S8
:
4018 case MESA_FORMAT_Z24_X8
:
4019 unpack
= unpack_uint_z_Z24_X8
;
4021 case MESA_FORMAT_S8_Z24
:
4022 case MESA_FORMAT_X8_Z24
:
4023 unpack
= unpack_uint_z_X8_Z24
;
4025 case MESA_FORMAT_Z16
:
4026 unpack
= unpack_uint_z_Z16
;
4028 case MESA_FORMAT_Z32
:
4029 unpack
= unpack_uint_z_Z32
;
4031 case MESA_FORMAT_Z32_FLOAT
:
4032 unpack
= unpack_uint_z_Z32_FLOAT
;
4034 case MESA_FORMAT_Z32_FLOAT_X24S8
:
4035 unpack
= unpack_uint_z_Z32_FLOAT_X24S8
;
4038 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_uint_z_row",
4039 _mesa_get_format_name(format
));
4043 unpack(srcPtr
, dst
, n
);
4048 unpack_ubyte_s_S8(const void *src
, GLubyte
*dst
, GLuint n
)
4050 memcpy(dst
, src
, n
);
4054 unpack_ubyte_s_Z24_S8(const void *src
, GLubyte
*dst
, GLuint n
)
4057 const GLuint
*src32
= src
;
4059 for (i
= 0; i
< n
; i
++)
4060 dst
[i
] = src32
[i
] & 0xff;
4064 unpack_ubyte_s_S8_Z24(const void *src
, GLubyte
*dst
, GLuint n
)
4067 const GLuint
*src32
= src
;
4069 for (i
= 0; i
< n
; i
++)
4070 dst
[i
] = src32
[i
] >> 24;
4074 unpack_ubyte_s_Z32_FLOAT_X24S8(const void *src
, GLubyte
*dst
, GLuint n
)
4077 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
4079 for (i
= 0; i
< n
; i
++)
4080 dst
[i
] = s
[i
].x24s8
& 0xff;
4084 _mesa_unpack_ubyte_stencil_row(gl_format format
, GLuint n
,
4085 const void *src
, GLubyte
*dst
)
4088 case MESA_FORMAT_S8
:
4089 unpack_ubyte_s_S8(src
, dst
, n
);
4091 case MESA_FORMAT_Z24_S8
:
4092 unpack_ubyte_s_Z24_S8(src
, dst
, n
);
4094 case MESA_FORMAT_S8_Z24
:
4095 unpack_ubyte_s_S8_Z24(src
, dst
, n
);
4097 case MESA_FORMAT_Z32_FLOAT_X24S8
:
4098 unpack_ubyte_s_Z32_FLOAT_X24S8(src
, dst
, n
);
4101 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_ubyte_s_row",
4102 _mesa_get_format_name(format
));
4108 unpack_uint_24_8_depth_stencil_S8_Z24(const GLuint
*src
, GLuint
*dst
, GLuint n
)
4112 for (i
= 0; i
< n
; i
++) {
4113 GLuint val
= src
[i
];
4114 dst
[i
] = val
>> 24 | val
<< 8;
4119 unpack_uint_24_8_depth_stencil_Z24_S8(const GLuint
*src
, GLuint
*dst
, GLuint n
)
4121 memcpy(dst
, src
, n
* 4);
4125 _mesa_unpack_uint_24_8_depth_stencil_row(gl_format format
, GLuint n
,
4126 const void *src
, GLuint
*dst
)
4129 case MESA_FORMAT_Z24_S8
:
4130 unpack_uint_24_8_depth_stencil_Z24_S8(src
, dst
, n
);
4132 case MESA_FORMAT_S8_Z24
:
4133 unpack_uint_24_8_depth_stencil_S8_Z24(src
, dst
, n
);
4137 "bad format %s in _mesa_unpack_uint_24_8_depth_stencil_row",
4138 _mesa_get_format_name(format
));