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;
2272 unpack_ABGR2101010(const void *src
, GLfloat dst
[][4], GLuint n
)
2274 const GLuint
*s
= ((const GLuint
*) src
);
2276 for (i
= 0; i
< n
; i
++) {
2277 dst
[i
][RCOMP
] = ((s
[i
] >> 0) & 0x3ff) * (1.0F
/ 1023.0F
);
2278 dst
[i
][GCOMP
] = ((s
[i
] >> 10) & 0x3ff) * (1.0F
/ 1023.0F
);
2279 dst
[i
][BCOMP
] = ((s
[i
] >> 20) & 0x3ff) * (1.0F
/ 1023.0F
);
2280 dst
[i
][ACOMP
] = ((s
[i
] >> 30) & 0x03) * (1.0F
/ 3.0F
);
2285 * Return the unpacker function for the given format.
2287 static unpack_rgba_func
2288 get_unpack_rgba_function(gl_format format
)
2290 static unpack_rgba_func table
[MESA_FORMAT_COUNT
];
2291 static GLboolean initialized
= GL_FALSE
;
2294 table
[MESA_FORMAT_NONE
] = NULL
;
2296 table
[MESA_FORMAT_RGBA8888
] = unpack_RGBA8888
;
2297 table
[MESA_FORMAT_RGBA8888_REV
] = unpack_RGBA8888_REV
;
2298 table
[MESA_FORMAT_ARGB8888
] = unpack_ARGB8888
;
2299 table
[MESA_FORMAT_ARGB8888_REV
] = unpack_ARGB8888_REV
;
2300 table
[MESA_FORMAT_RGBX8888
] = unpack_RGBX8888
;
2301 table
[MESA_FORMAT_RGBX8888_REV
] = unpack_RGBX8888_REV
;
2302 table
[MESA_FORMAT_XRGB8888
] = unpack_XRGB8888
;
2303 table
[MESA_FORMAT_XRGB8888_REV
] = unpack_XRGB8888_REV
;
2304 table
[MESA_FORMAT_RGB888
] = unpack_RGB888
;
2305 table
[MESA_FORMAT_BGR888
] = unpack_BGR888
;
2306 table
[MESA_FORMAT_RGB565
] = unpack_RGB565
;
2307 table
[MESA_FORMAT_RGB565_REV
] = unpack_RGB565_REV
;
2308 table
[MESA_FORMAT_ARGB4444
] = unpack_ARGB4444
;
2309 table
[MESA_FORMAT_ARGB4444_REV
] = unpack_ARGB4444_REV
;
2310 table
[MESA_FORMAT_RGBA5551
] = unpack_RGBA5551
;
2311 table
[MESA_FORMAT_ARGB1555
] = unpack_ARGB1555
;
2312 table
[MESA_FORMAT_ARGB1555_REV
] = unpack_ARGB1555_REV
;
2313 table
[MESA_FORMAT_AL44
] = unpack_AL44
;
2314 table
[MESA_FORMAT_AL88
] = unpack_AL88
;
2315 table
[MESA_FORMAT_AL88_REV
] = unpack_AL88_REV
;
2316 table
[MESA_FORMAT_AL1616
] = unpack_AL1616
;
2317 table
[MESA_FORMAT_AL1616_REV
] = unpack_AL1616_REV
;
2318 table
[MESA_FORMAT_RGB332
] = unpack_RGB332
;
2319 table
[MESA_FORMAT_A8
] = unpack_A8
;
2320 table
[MESA_FORMAT_A16
] = unpack_A16
;
2321 table
[MESA_FORMAT_L8
] = unpack_L8
;
2322 table
[MESA_FORMAT_L16
] = unpack_L16
;
2323 table
[MESA_FORMAT_I8
] = unpack_I8
;
2324 table
[MESA_FORMAT_I16
] = unpack_I16
;
2325 table
[MESA_FORMAT_YCBCR
] = unpack_YCBCR
;
2326 table
[MESA_FORMAT_YCBCR_REV
] = unpack_YCBCR_REV
;
2327 table
[MESA_FORMAT_R8
] = unpack_R8
;
2328 table
[MESA_FORMAT_GR88
] = unpack_GR88
;
2329 table
[MESA_FORMAT_RG88
] = unpack_RG88
;
2330 table
[MESA_FORMAT_R16
] = unpack_R16
;
2331 table
[MESA_FORMAT_GR1616
] = unpack_GR1616
;
2332 table
[MESA_FORMAT_RG1616
] = unpack_RG1616
;
2333 table
[MESA_FORMAT_ARGB2101010
] = unpack_ARGB2101010
;
2334 table
[MESA_FORMAT_ARGB2101010_UINT
] = unpack_ARGB2101010_UINT
;
2335 table
[MESA_FORMAT_ABGR2101010_UINT
] = unpack_ABGR2101010_UINT
;
2336 table
[MESA_FORMAT_Z24_S8
] = unpack_Z24_S8
;
2337 table
[MESA_FORMAT_S8_Z24
] = unpack_S8_Z24
;
2338 table
[MESA_FORMAT_Z16
] = unpack_Z16
;
2339 table
[MESA_FORMAT_X8_Z24
] = unpack_X8_Z24
;
2340 table
[MESA_FORMAT_Z24_X8
] = unpack_Z24_X8
;
2341 table
[MESA_FORMAT_Z32
] = unpack_Z32
;
2342 table
[MESA_FORMAT_S8
] = unpack_S8
;
2343 table
[MESA_FORMAT_SRGB8
] = unpack_SRGB8
;
2344 table
[MESA_FORMAT_SRGBA8
] = unpack_SRGBA8
;
2345 table
[MESA_FORMAT_SARGB8
] = unpack_SARGB8
;
2346 table
[MESA_FORMAT_SL8
] = unpack_SL8
;
2347 table
[MESA_FORMAT_SLA8
] = unpack_SLA8
;
2348 table
[MESA_FORMAT_SRGB_DXT1
] = unpack_SRGB_DXT1
;
2349 table
[MESA_FORMAT_SRGBA_DXT1
] = unpack_SRGBA_DXT1
;
2350 table
[MESA_FORMAT_SRGBA_DXT3
] = unpack_SRGBA_DXT3
;
2351 table
[MESA_FORMAT_SRGBA_DXT5
] = unpack_SRGBA_DXT5
;
2353 table
[MESA_FORMAT_RGB_FXT1
] = unpack_RGB_FXT1
;
2354 table
[MESA_FORMAT_RGBA_FXT1
] = unpack_RGBA_FXT1
;
2355 table
[MESA_FORMAT_RGB_DXT1
] = unpack_RGB_DXT1
;
2356 table
[MESA_FORMAT_RGBA_DXT1
] = unpack_RGBA_DXT1
;
2357 table
[MESA_FORMAT_RGBA_DXT3
] = unpack_RGBA_DXT3
;
2358 table
[MESA_FORMAT_RGBA_DXT5
] = unpack_RGBA_DXT5
;
2360 table
[MESA_FORMAT_RGBA_FLOAT32
] = unpack_RGBA_FLOAT32
;
2361 table
[MESA_FORMAT_RGBA_FLOAT16
] = unpack_RGBA_FLOAT16
;
2362 table
[MESA_FORMAT_RGB_FLOAT32
] = unpack_RGB_FLOAT32
;
2363 table
[MESA_FORMAT_RGB_FLOAT16
] = unpack_RGB_FLOAT16
;
2364 table
[MESA_FORMAT_ALPHA_FLOAT32
] = unpack_ALPHA_FLOAT32
;
2365 table
[MESA_FORMAT_ALPHA_FLOAT16
] = unpack_ALPHA_FLOAT16
;
2366 table
[MESA_FORMAT_LUMINANCE_FLOAT32
] = unpack_LUMINANCE_FLOAT32
;
2367 table
[MESA_FORMAT_LUMINANCE_FLOAT16
] = unpack_LUMINANCE_FLOAT16
;
2368 table
[MESA_FORMAT_LUMINANCE_ALPHA_FLOAT32
] = unpack_LUMINANCE_ALPHA_FLOAT32
;
2369 table
[MESA_FORMAT_LUMINANCE_ALPHA_FLOAT16
] = unpack_LUMINANCE_ALPHA_FLOAT16
;
2370 table
[MESA_FORMAT_INTENSITY_FLOAT32
] = unpack_INTENSITY_FLOAT32
;
2371 table
[MESA_FORMAT_INTENSITY_FLOAT16
] = unpack_INTENSITY_FLOAT16
;
2372 table
[MESA_FORMAT_R_FLOAT32
] = unpack_R_FLOAT32
;
2373 table
[MESA_FORMAT_R_FLOAT16
] = unpack_R_FLOAT16
;
2374 table
[MESA_FORMAT_RG_FLOAT32
] = unpack_RG_FLOAT32
;
2375 table
[MESA_FORMAT_RG_FLOAT16
] = unpack_RG_FLOAT16
;
2377 table
[MESA_FORMAT_ALPHA_UINT8
] = unpack_ALPHA_UINT8
;
2378 table
[MESA_FORMAT_ALPHA_UINT16
] = unpack_ALPHA_UINT16
;
2379 table
[MESA_FORMAT_ALPHA_UINT32
] = unpack_ALPHA_UINT32
;
2380 table
[MESA_FORMAT_ALPHA_INT8
] = unpack_ALPHA_INT8
;
2381 table
[MESA_FORMAT_ALPHA_INT16
] = unpack_ALPHA_INT16
;
2382 table
[MESA_FORMAT_ALPHA_INT32
] = unpack_ALPHA_INT32
;
2384 table
[MESA_FORMAT_INTENSITY_UINT8
] = unpack_INTENSITY_UINT8
;
2385 table
[MESA_FORMAT_INTENSITY_UINT16
] = unpack_INTENSITY_UINT16
;
2386 table
[MESA_FORMAT_INTENSITY_UINT32
] = unpack_INTENSITY_UINT32
;
2387 table
[MESA_FORMAT_INTENSITY_INT8
] = unpack_INTENSITY_INT8
;
2388 table
[MESA_FORMAT_INTENSITY_INT16
] = unpack_INTENSITY_INT16
;
2389 table
[MESA_FORMAT_INTENSITY_INT32
] = unpack_INTENSITY_INT32
;
2391 table
[MESA_FORMAT_LUMINANCE_UINT8
] = unpack_LUMINANCE_UINT8
;
2392 table
[MESA_FORMAT_LUMINANCE_UINT16
] = unpack_LUMINANCE_UINT16
;
2393 table
[MESA_FORMAT_LUMINANCE_UINT32
] = unpack_LUMINANCE_UINT32
;
2394 table
[MESA_FORMAT_LUMINANCE_INT8
] = unpack_LUMINANCE_INT8
;
2395 table
[MESA_FORMAT_LUMINANCE_INT16
] = unpack_LUMINANCE_INT16
;
2396 table
[MESA_FORMAT_LUMINANCE_INT32
] = unpack_LUMINANCE_INT32
;
2398 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT8
] = unpack_LUMINANCE_ALPHA_UINT8
;
2399 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT16
] = unpack_LUMINANCE_ALPHA_UINT16
;
2400 table
[MESA_FORMAT_LUMINANCE_ALPHA_UINT32
] = unpack_LUMINANCE_ALPHA_UINT32
;
2401 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT8
] = unpack_LUMINANCE_ALPHA_INT8
;
2402 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT16
] = unpack_LUMINANCE_ALPHA_INT16
;
2403 table
[MESA_FORMAT_LUMINANCE_ALPHA_INT32
] = unpack_LUMINANCE_ALPHA_INT32
;
2405 table
[MESA_FORMAT_R_INT8
] = unpack_R_INT8
;
2406 table
[MESA_FORMAT_RG_INT8
] = unpack_RG_INT8
;
2407 table
[MESA_FORMAT_RGB_INT8
] = unpack_RGB_INT8
;
2408 table
[MESA_FORMAT_RGBA_INT8
] = unpack_RGBA_INT8
;
2409 table
[MESA_FORMAT_R_INT16
] = unpack_R_INT16
;
2410 table
[MESA_FORMAT_RG_INT16
] = unpack_RG_INT16
;
2411 table
[MESA_FORMAT_RGB_INT16
] = unpack_RGB_INT16
;
2412 table
[MESA_FORMAT_RGBA_INT16
] = unpack_RGBA_INT16
;
2413 table
[MESA_FORMAT_R_INT32
] = unpack_R_INT32
;
2414 table
[MESA_FORMAT_RG_INT32
] = unpack_RG_INT32
;
2415 table
[MESA_FORMAT_RGB_INT32
] = unpack_RGB_INT32
;
2416 table
[MESA_FORMAT_RGBA_INT32
] = unpack_RGBA_INT32
;
2417 table
[MESA_FORMAT_R_UINT8
] = unpack_R_UINT8
;
2418 table
[MESA_FORMAT_RG_UINT8
] = unpack_RG_UINT8
;
2419 table
[MESA_FORMAT_RGB_UINT8
] = unpack_RGB_UINT8
;
2420 table
[MESA_FORMAT_RGBA_UINT8
] = unpack_RGBA_UINT8
;
2421 table
[MESA_FORMAT_R_UINT16
] = unpack_R_UINT16
;
2422 table
[MESA_FORMAT_RG_UINT16
] = unpack_RG_UINT16
;
2423 table
[MESA_FORMAT_RGB_UINT16
] = unpack_RGB_UINT16
;
2424 table
[MESA_FORMAT_RGBA_UINT16
] = unpack_RGBA_UINT16
;
2425 table
[MESA_FORMAT_R_UINT32
] = unpack_R_UINT32
;
2426 table
[MESA_FORMAT_RG_UINT32
] = unpack_RG_UINT32
;
2427 table
[MESA_FORMAT_RGB_UINT32
] = unpack_RGB_UINT32
;
2428 table
[MESA_FORMAT_RGBA_UINT32
] = unpack_RGBA_UINT32
;
2430 table
[MESA_FORMAT_DUDV8
] = unpack_DUDV8
;
2431 table
[MESA_FORMAT_SIGNED_R8
] = unpack_SIGNED_R8
;
2432 table
[MESA_FORMAT_SIGNED_RG88_REV
] = unpack_SIGNED_RG88_REV
;
2433 table
[MESA_FORMAT_SIGNED_RGBX8888
] = unpack_SIGNED_RGBX8888
;
2434 table
[MESA_FORMAT_SIGNED_RGBA8888
] = unpack_SIGNED_RGBA8888
;
2435 table
[MESA_FORMAT_SIGNED_RGBA8888_REV
] = unpack_SIGNED_RGBA8888_REV
;
2436 table
[MESA_FORMAT_SIGNED_R16
] = unpack_SIGNED_R16
;
2437 table
[MESA_FORMAT_SIGNED_GR1616
] = unpack_SIGNED_GR1616
;
2438 table
[MESA_FORMAT_SIGNED_RGB_16
] = unpack_SIGNED_RGB_16
;
2439 table
[MESA_FORMAT_SIGNED_RGBA_16
] = unpack_SIGNED_RGBA_16
;
2440 table
[MESA_FORMAT_RGBA_16
] = unpack_RGBA_16
;
2442 table
[MESA_FORMAT_RED_RGTC1
] = unpack_RED_RGTC1
;
2443 table
[MESA_FORMAT_SIGNED_RED_RGTC1
] = unpack_SIGNED_RED_RGTC1
;
2444 table
[MESA_FORMAT_RG_RGTC2
] = unpack_RG_RGTC2
;
2445 table
[MESA_FORMAT_SIGNED_RG_RGTC2
] = unpack_SIGNED_RG_RGTC2
;
2447 table
[MESA_FORMAT_L_LATC1
] = unpack_L_LATC1
;
2448 table
[MESA_FORMAT_SIGNED_L_LATC1
] = unpack_SIGNED_L_LATC1
;
2449 table
[MESA_FORMAT_LA_LATC2
] = unpack_LA_LATC2
;
2450 table
[MESA_FORMAT_SIGNED_LA_LATC2
] = unpack_SIGNED_LA_LATC2
;
2452 table
[MESA_FORMAT_ETC1_RGB8
] = unpack_ETC1_RGB8
;
2453 table
[MESA_FORMAT_ETC2_RGB8
] = unpack_ETC2_RGB8
;
2454 table
[MESA_FORMAT_ETC2_SRGB8
] = unpack_ETC2_SRGB8
;
2455 table
[MESA_FORMAT_ETC2_RGBA8_EAC
] = unpack_ETC2_RGBA8_EAC
;
2456 table
[MESA_FORMAT_ETC2_SRGB8_ALPHA8_EAC
] = unpack_ETC2_SRGB8_ALPHA8_EAC
;
2457 table
[MESA_FORMAT_ETC2_R11_EAC
] = unpack_ETC2_R11_EAC
;
2458 table
[MESA_FORMAT_ETC2_RG11_EAC
] = unpack_ETC2_RG11_EAC
;
2459 table
[MESA_FORMAT_ETC2_SIGNED_R11_EAC
] = unpack_ETC2_SIGNED_R11_EAC
;
2460 table
[MESA_FORMAT_ETC2_SIGNED_RG11_EAC
] = unpack_ETC2_SIGNED_RG11_EAC
;
2461 table
[MESA_FORMAT_ETC2_RGB8_PUNCHTHROUGH_ALPHA1
] =
2462 unpack_ETC2_RGB8_PUNCHTHROUGH_ALPHA1
;
2463 table
[MESA_FORMAT_ETC2_SRGB8_PUNCHTHROUGH_ALPHA1
] =
2464 unpack_ETC2_SRGB8_PUNCHTHROUGH_ALPHA1
;
2465 table
[MESA_FORMAT_SIGNED_A8
] = unpack_SIGNED_A8
;
2466 table
[MESA_FORMAT_SIGNED_L8
] = unpack_SIGNED_L8
;
2467 table
[MESA_FORMAT_SIGNED_AL88
] = unpack_SIGNED_AL88
;
2468 table
[MESA_FORMAT_SIGNED_I8
] = unpack_SIGNED_I8
;
2469 table
[MESA_FORMAT_SIGNED_A16
] = unpack_SIGNED_A16
;
2470 table
[MESA_FORMAT_SIGNED_L16
] = unpack_SIGNED_L16
;
2471 table
[MESA_FORMAT_SIGNED_AL1616
] = unpack_SIGNED_AL1616
;
2472 table
[MESA_FORMAT_SIGNED_I16
] = unpack_SIGNED_I16
;
2474 table
[MESA_FORMAT_RGB9_E5_FLOAT
] = unpack_RGB9_E5_FLOAT
;
2475 table
[MESA_FORMAT_R11_G11_B10_FLOAT
] = unpack_R11_G11_B10_FLOAT
;
2477 table
[MESA_FORMAT_Z32_FLOAT
] = unpack_Z32_FLOAT
;
2478 table
[MESA_FORMAT_Z32_FLOAT_X24S8
] = unpack_Z32_FLOAT_X24S8
;
2480 table
[MESA_FORMAT_XRGB4444_UNORM
] = unpack_XRGB4444_UNORM
;
2481 table
[MESA_FORMAT_XRGB1555_UNORM
] = unpack_XRGB1555_UNORM
;
2482 table
[MESA_FORMAT_XBGR8888_SNORM
] = unpack_XBGR8888_SNORM
;
2483 table
[MESA_FORMAT_XBGR8888_SRGB
] = unpack_XBGR8888_SRGB
;
2484 table
[MESA_FORMAT_XBGR8888_UINT
] = unpack_XBGR8888_UINT
;
2485 table
[MESA_FORMAT_XBGR8888_SINT
] = unpack_XBGR8888_SINT
;
2486 table
[MESA_FORMAT_XRGB2101010_UNORM
] = unpack_XRGB2101010_UNORM
;
2487 table
[MESA_FORMAT_XBGR16161616_UNORM
] = unpack_XBGR16161616_UNORM
;
2488 table
[MESA_FORMAT_XBGR16161616_SNORM
] = unpack_XBGR16161616_SNORM
;
2489 table
[MESA_FORMAT_XBGR16161616_FLOAT
] = unpack_XBGR16161616_FLOAT
;
2490 table
[MESA_FORMAT_XBGR16161616_UINT
] = unpack_XBGR16161616_UINT
;
2491 table
[MESA_FORMAT_XBGR16161616_SINT
] = unpack_XBGR16161616_SINT
;
2492 table
[MESA_FORMAT_XBGR32323232_FLOAT
] = unpack_XBGR32323232_FLOAT
;
2493 table
[MESA_FORMAT_XBGR32323232_UINT
] = unpack_XBGR32323232_UINT
;
2494 table
[MESA_FORMAT_XBGR32323232_SINT
] = unpack_XBGR32323232_SINT
;
2496 table
[MESA_FORMAT_ABGR2101010
] = unpack_ABGR2101010
;
2498 initialized
= GL_TRUE
;
2501 if (table
[format
] == NULL
) {
2502 _mesa_problem(NULL
, "unsupported unpack for format %s",
2503 _mesa_get_format_name(format
));
2506 return table
[format
];
2511 * Unpack rgba colors, returning as GLfloat values.
2514 _mesa_unpack_rgba_row(gl_format format
, GLuint n
,
2515 const void *src
, GLfloat dst
[][4])
2517 unpack_rgba_func unpack
= get_unpack_rgba_function(format
);
2518 unpack(src
, dst
, n
);
2522 /**********************************************************************/
2523 /* Unpack, returning GLubyte colors */
2524 /**********************************************************************/
2528 unpack_ubyte_RGBA8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2530 const GLuint
*s
= ((const GLuint
*) src
);
2532 for (i
= 0; i
< n
; i
++) {
2533 dst
[i
][RCOMP
] = (s
[i
] >> 24);
2534 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2535 dst
[i
][BCOMP
] = (s
[i
] >> 8) & 0xff;
2536 dst
[i
][ACOMP
] = (s
[i
] ) & 0xff;
2541 unpack_ubyte_RGBA8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2543 const GLuint
*s
= ((const GLuint
*) src
);
2545 for (i
= 0; i
< n
; i
++) {
2546 dst
[i
][RCOMP
] = (s
[i
] ) & 0xff;
2547 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2548 dst
[i
][BCOMP
] = (s
[i
] >> 16) & 0xff;
2549 dst
[i
][ACOMP
] = (s
[i
] >> 24);
2554 unpack_ubyte_ARGB8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2556 const GLuint
*s
= ((const GLuint
*) src
);
2558 for (i
= 0; i
< n
; i
++) {
2559 dst
[i
][RCOMP
] = (s
[i
] >> 16) & 0xff;
2560 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2561 dst
[i
][BCOMP
] = (s
[i
] ) & 0xff;
2562 dst
[i
][ACOMP
] = (s
[i
] >> 24);
2567 unpack_ubyte_ARGB8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2569 const GLuint
*s
= ((const GLuint
*) src
);
2571 for (i
= 0; i
< n
; i
++) {
2572 dst
[i
][RCOMP
] = (s
[i
] >> 8) & 0xff;
2573 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2574 dst
[i
][BCOMP
] = (s
[i
] >> 24);
2575 dst
[i
][ACOMP
] = (s
[i
] ) & 0xff;
2580 unpack_ubyte_RGBX8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2582 const GLuint
*s
= ((const GLuint
*) src
);
2584 for (i
= 0; i
< n
; i
++) {
2585 dst
[i
][RCOMP
] = (s
[i
] >> 24);
2586 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2587 dst
[i
][BCOMP
] = (s
[i
] >> 8) & 0xff;
2588 dst
[i
][ACOMP
] = 0xff;
2593 unpack_ubyte_RGBX8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2595 const GLuint
*s
= ((const GLuint
*) src
);
2597 for (i
= 0; i
< n
; i
++) {
2598 dst
[i
][RCOMP
] = (s
[i
] ) & 0xff;
2599 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2600 dst
[i
][BCOMP
] = (s
[i
] >> 16) & 0xff;
2601 dst
[i
][ACOMP
] = 0xff;
2606 unpack_ubyte_XRGB8888(const void *src
, GLubyte dst
[][4], GLuint n
)
2608 const GLuint
*s
= ((const GLuint
*) src
);
2610 for (i
= 0; i
< n
; i
++) {
2611 dst
[i
][RCOMP
] = (s
[i
] >> 16) & 0xff;
2612 dst
[i
][GCOMP
] = (s
[i
] >> 8) & 0xff;
2613 dst
[i
][BCOMP
] = (s
[i
] ) & 0xff;
2614 dst
[i
][ACOMP
] = 0xff;
2619 unpack_ubyte_XRGB8888_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2621 const GLuint
*s
= ((const GLuint
*) src
);
2623 for (i
= 0; i
< n
; i
++) {
2624 dst
[i
][RCOMP
] = (s
[i
] >> 8) & 0xff;
2625 dst
[i
][GCOMP
] = (s
[i
] >> 16) & 0xff;
2626 dst
[i
][BCOMP
] = (s
[i
] >> 24);
2627 dst
[i
][ACOMP
] = 0xff;
2632 unpack_ubyte_RGB888(const void *src
, GLubyte dst
[][4], GLuint n
)
2634 const GLubyte
*s
= (const GLubyte
*) src
;
2636 for (i
= 0; i
< n
; i
++) {
2637 dst
[i
][RCOMP
] = s
[i
*3+2];
2638 dst
[i
][GCOMP
] = s
[i
*3+1];
2639 dst
[i
][BCOMP
] = s
[i
*3+0];
2640 dst
[i
][ACOMP
] = 0xff;
2645 unpack_ubyte_BGR888(const void *src
, GLubyte dst
[][4], GLuint n
)
2647 const GLubyte
*s
= (const GLubyte
*) src
;
2649 for (i
= 0; i
< n
; i
++) {
2650 dst
[i
][RCOMP
] = s
[i
*3+0];
2651 dst
[i
][GCOMP
] = s
[i
*3+1];
2652 dst
[i
][BCOMP
] = s
[i
*3+2];
2653 dst
[i
][ACOMP
] = 0xff;
2658 unpack_ubyte_RGB565(const void *src
, GLubyte dst
[][4], GLuint n
)
2660 const GLushort
*s
= ((const GLushort
*) src
);
2662 for (i
= 0; i
< n
; i
++) {
2663 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 11) & 0x1f);
2664 dst
[i
][GCOMP
] = EXPAND_6_8((s
[i
] >> 5 ) & 0x3f);
2665 dst
[i
][BCOMP
] = EXPAND_5_8( s
[i
] & 0x1f);
2666 dst
[i
][ACOMP
] = 0xff;
2671 unpack_ubyte_RGB565_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2673 const GLushort
*s
= ((const GLushort
*) src
);
2675 for (i
= 0; i
< n
; i
++) {
2676 GLuint t
= (s
[i
] >> 8) | (s
[i
] << 8); /* byte swap */
2677 dst
[i
][RCOMP
] = EXPAND_5_8((t
>> 11) & 0x1f);
2678 dst
[i
][GCOMP
] = EXPAND_6_8((t
>> 5 ) & 0x3f);
2679 dst
[i
][BCOMP
] = EXPAND_5_8( t
& 0x1f);
2680 dst
[i
][ACOMP
] = 0xff;
2685 unpack_ubyte_ARGB4444(const void *src
, GLubyte dst
[][4], GLuint n
)
2687 const GLushort
*s
= ((const GLushort
*) src
);
2689 for (i
= 0; i
< n
; i
++) {
2690 dst
[i
][RCOMP
] = EXPAND_4_8((s
[i
] >> 8) & 0xf);
2691 dst
[i
][GCOMP
] = EXPAND_4_8((s
[i
] >> 4) & 0xf);
2692 dst
[i
][BCOMP
] = EXPAND_4_8((s
[i
] ) & 0xf);
2693 dst
[i
][ACOMP
] = EXPAND_4_8((s
[i
] >> 12) & 0xf);
2698 unpack_ubyte_ARGB4444_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2700 const GLushort
*s
= ((const GLushort
*) src
);
2702 for (i
= 0; i
< n
; i
++) {
2703 dst
[i
][RCOMP
] = EXPAND_4_8((s
[i
] ) & 0xf);
2704 dst
[i
][GCOMP
] = EXPAND_4_8((s
[i
] >> 12) & 0xf);
2705 dst
[i
][BCOMP
] = EXPAND_4_8((s
[i
] >> 8) & 0xf);
2706 dst
[i
][ACOMP
] = EXPAND_4_8((s
[i
] >> 4) & 0xf);
2711 unpack_ubyte_RGBA5551(const void *src
, GLubyte dst
[][4], GLuint n
)
2713 const GLushort
*s
= ((const GLushort
*) src
);
2715 for (i
= 0; i
< n
; i
++) {
2716 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 11) & 0x1f);
2717 dst
[i
][GCOMP
] = EXPAND_5_8((s
[i
] >> 6) & 0x1f);
2718 dst
[i
][BCOMP
] = EXPAND_5_8((s
[i
] >> 1) & 0x1f);
2719 dst
[i
][ACOMP
] = EXPAND_1_8((s
[i
] ) & 0x01);
2724 unpack_ubyte_ARGB1555(const void *src
, GLubyte dst
[][4], GLuint n
)
2726 const GLushort
*s
= ((const GLushort
*) src
);
2728 for (i
= 0; i
< n
; i
++) {
2729 dst
[i
][RCOMP
] = EXPAND_5_8((s
[i
] >> 10) & 0x1f);
2730 dst
[i
][GCOMP
] = EXPAND_5_8((s
[i
] >> 5) & 0x1f);
2731 dst
[i
][BCOMP
] = EXPAND_5_8((s
[i
] >> 0) & 0x1f);
2732 dst
[i
][ACOMP
] = EXPAND_1_8((s
[i
] >> 15) & 0x01);
2737 unpack_ubyte_ARGB1555_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2739 const GLushort
*s
= ((const GLushort
*) src
);
2741 for (i
= 0; i
< n
; i
++) {
2742 GLushort tmp
= (s
[i
] << 8) | (s
[i
] >> 8); /* byteswap */
2743 dst
[i
][RCOMP
] = EXPAND_5_8((tmp
>> 10) & 0x1f);
2744 dst
[i
][GCOMP
] = EXPAND_5_8((tmp
>> 5) & 0x1f);
2745 dst
[i
][BCOMP
] = EXPAND_5_8((tmp
>> 0) & 0x1f);
2746 dst
[i
][ACOMP
] = EXPAND_1_8((tmp
>> 15) & 0x01);
2751 unpack_ubyte_AL44(const void *src
, GLubyte dst
[][4], GLuint n
)
2753 const GLubyte
*s
= ((const GLubyte
*) src
);
2755 for (i
= 0; i
< n
; i
++) {
2758 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] & 0xf);
2759 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] >> 4);
2764 unpack_ubyte_AL88(const void *src
, GLubyte dst
[][4], GLuint n
)
2766 const GLushort
*s
= ((const GLushort
*) src
);
2768 for (i
= 0; i
< n
; i
++) {
2771 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] & 0xff);
2772 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] >> 8);
2777 unpack_ubyte_AL88_REV(const void *src
, GLubyte dst
[][4], GLuint n
)
2779 const GLushort
*s
= ((const GLushort
*) src
);
2781 for (i
= 0; i
< n
; i
++) {
2784 dst
[i
][BCOMP
] = EXPAND_4_8(s
[i
] >> 8);
2785 dst
[i
][ACOMP
] = EXPAND_4_8(s
[i
] & 0xff);
2790 unpack_ubyte_RGB332(const void *src
, GLubyte dst
[][4], GLuint n
)
2792 const GLubyte
*s
= ((const GLubyte
*) src
);
2794 for (i
= 0; i
< n
; i
++) {
2795 dst
[i
][RCOMP
] = EXPAND_3_8((s
[i
] >> 5) & 0x7);
2796 dst
[i
][GCOMP
] = EXPAND_3_8((s
[i
] >> 2) & 0x7);
2797 dst
[i
][BCOMP
] = EXPAND_2_8((s
[i
] ) & 0x3);
2798 dst
[i
][ACOMP
] = 0xff;
2803 unpack_ubyte_A8(const void *src
, GLubyte dst
[][4], GLuint n
)
2805 const GLubyte
*s
= ((const GLubyte
*) src
);
2807 for (i
= 0; i
< n
; i
++) {
2811 dst
[i
][ACOMP
] = s
[i
];
2816 unpack_ubyte_L8(const void *src
, GLubyte dst
[][4], GLuint n
)
2818 const GLubyte
*s
= ((const GLubyte
*) src
);
2820 for (i
= 0; i
< n
; i
++) {
2823 dst
[i
][BCOMP
] = s
[i
];
2824 dst
[i
][ACOMP
] = 0xff;
2830 unpack_ubyte_I8(const void *src
, GLubyte dst
[][4], GLuint n
)
2832 const GLubyte
*s
= ((const GLubyte
*) src
);
2834 for (i
= 0; i
< n
; i
++) {
2838 dst
[i
][ACOMP
] = s
[i
];
2843 unpack_ubyte_R8(const void *src
, GLubyte dst
[][4], GLuint n
)
2845 const GLubyte
*s
= ((const GLubyte
*) src
);
2847 for (i
= 0; i
< n
; i
++) {
2856 unpack_ubyte_GR88(const void *src
, GLubyte dst
[][4], GLuint n
)
2858 const GLushort
*s
= ((const GLushort
*) src
);
2860 for (i
= 0; i
< n
; i
++) {
2861 dst
[i
][RCOMP
] = s
[i
] & 0xff;
2862 dst
[i
][GCOMP
] = s
[i
] >> 8;
2864 dst
[i
][ACOMP
] = 0xff;
2869 unpack_ubyte_RG88(const void *src
, GLubyte dst
[][4], GLuint n
)
2871 const GLushort
*s
= ((const GLushort
*) src
);
2873 for (i
= 0; i
< n
; i
++) {
2874 dst
[i
][RCOMP
] = s
[i
] >> 8;
2875 dst
[i
][GCOMP
] = s
[i
] & 0xff;
2877 dst
[i
][ACOMP
] = 0xff;
2883 * Unpack rgba colors, returning as GLubyte values. This should usually
2884 * only be used for unpacking formats that use 8 bits or less per channel.
2887 _mesa_unpack_ubyte_rgba_row(gl_format format
, GLuint n
,
2888 const void *src
, GLubyte dst
[][4])
2891 case MESA_FORMAT_RGBA8888
:
2892 unpack_ubyte_RGBA8888(src
, dst
, n
);
2894 case MESA_FORMAT_RGBA8888_REV
:
2895 unpack_ubyte_RGBA8888_REV(src
, dst
, n
);
2897 case MESA_FORMAT_ARGB8888
:
2898 unpack_ubyte_ARGB8888(src
, dst
, n
);
2900 case MESA_FORMAT_ARGB8888_REV
:
2901 unpack_ubyte_ARGB8888_REV(src
, dst
, n
);
2903 case MESA_FORMAT_RGBX8888
:
2904 unpack_ubyte_RGBX8888(src
, dst
, n
);
2906 case MESA_FORMAT_RGBX8888_REV
:
2907 unpack_ubyte_RGBX8888_REV(src
, dst
, n
);
2909 case MESA_FORMAT_XRGB8888
:
2910 unpack_ubyte_XRGB8888(src
, dst
, n
);
2912 case MESA_FORMAT_XRGB8888_REV
:
2913 unpack_ubyte_XRGB8888_REV(src
, dst
, n
);
2915 case MESA_FORMAT_RGB888
:
2916 unpack_ubyte_RGB888(src
, dst
, n
);
2918 case MESA_FORMAT_BGR888
:
2919 unpack_ubyte_BGR888(src
, dst
, n
);
2921 case MESA_FORMAT_RGB565
:
2922 unpack_ubyte_RGB565(src
, dst
, n
);
2924 case MESA_FORMAT_RGB565_REV
:
2925 unpack_ubyte_RGB565_REV(src
, dst
, n
);
2927 case MESA_FORMAT_ARGB4444
:
2928 unpack_ubyte_ARGB4444(src
, dst
, n
);
2930 case MESA_FORMAT_ARGB4444_REV
:
2931 unpack_ubyte_ARGB4444_REV(src
, dst
, n
);
2933 case MESA_FORMAT_RGBA5551
:
2934 unpack_ubyte_RGBA5551(src
, dst
, n
);
2936 case MESA_FORMAT_ARGB1555
:
2937 unpack_ubyte_ARGB1555(src
, dst
, n
);
2939 case MESA_FORMAT_ARGB1555_REV
:
2940 unpack_ubyte_ARGB1555_REV(src
, dst
, n
);
2942 case MESA_FORMAT_AL44
:
2943 unpack_ubyte_AL44(src
, dst
, n
);
2945 case MESA_FORMAT_AL88
:
2946 unpack_ubyte_AL88(src
, dst
, n
);
2948 case MESA_FORMAT_AL88_REV
:
2949 unpack_ubyte_AL88_REV(src
, dst
, n
);
2951 case MESA_FORMAT_RGB332
:
2952 unpack_ubyte_RGB332(src
, dst
, n
);
2954 case MESA_FORMAT_A8
:
2955 unpack_ubyte_A8(src
, dst
, n
);
2957 case MESA_FORMAT_L8
:
2958 unpack_ubyte_L8(src
, dst
, n
);
2960 case MESA_FORMAT_I8
:
2961 unpack_ubyte_I8(src
, dst
, n
);
2963 case MESA_FORMAT_R8
:
2964 unpack_ubyte_R8(src
, dst
, n
);
2966 case MESA_FORMAT_GR88
:
2967 unpack_ubyte_GR88(src
, dst
, n
);
2969 case MESA_FORMAT_RG88
:
2970 unpack_ubyte_RG88(src
, dst
, n
);
2973 /* get float values, convert to ubyte */
2975 GLfloat
*tmp
= malloc(n
* 4 * sizeof(GLfloat
));
2978 _mesa_unpack_rgba_row(format
, n
, src
, (GLfloat (*)[4]) tmp
);
2979 for (i
= 0; i
< n
; i
++) {
2980 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][0], tmp
[i
*4+0]);
2981 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][1], tmp
[i
*4+1]);
2982 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][2], tmp
[i
*4+2]);
2983 UNCLAMPED_FLOAT_TO_UBYTE(dst
[i
][3], tmp
[i
*4+3]);
2993 /**********************************************************************/
2994 /* Unpack, returning GLuint colors */
2995 /**********************************************************************/
2998 unpack_int_rgba_RGBA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3000 memcpy(dst
, src
, n
* 4 * sizeof(GLuint
));
3004 unpack_int_rgba_RGBA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3008 for (i
= 0; i
< n
; i
++) {
3009 dst
[i
][0] = src
[i
* 4 + 0];
3010 dst
[i
][1] = src
[i
* 4 + 1];
3011 dst
[i
][2] = src
[i
* 4 + 2];
3012 dst
[i
][3] = src
[i
* 4 + 3];
3017 unpack_int_rgba_RGBA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3021 for (i
= 0; i
< n
; i
++) {
3022 dst
[i
][0] = src
[i
* 4 + 0];
3023 dst
[i
][1] = src
[i
* 4 + 1];
3024 dst
[i
][2] = src
[i
* 4 + 2];
3025 dst
[i
][3] = src
[i
* 4 + 3];
3030 unpack_int_rgba_RGBA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3034 for (i
= 0; i
< n
; i
++) {
3035 dst
[i
][0] = src
[i
* 4 + 0];
3036 dst
[i
][1] = src
[i
* 4 + 1];
3037 dst
[i
][2] = src
[i
* 4 + 2];
3038 dst
[i
][3] = src
[i
* 4 + 3];
3043 unpack_int_rgba_RGBA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3047 for (i
= 0; i
< n
; i
++) {
3048 dst
[i
][0] = src
[i
* 4 + 0];
3049 dst
[i
][1] = src
[i
* 4 + 1];
3050 dst
[i
][2] = src
[i
* 4 + 2];
3051 dst
[i
][3] = src
[i
* 4 + 3];
3056 unpack_int_rgba_ARGB8888(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3060 for (i
= 0; i
< n
; i
++) {
3061 dst
[i
][RCOMP
] = (GLubyte
) src
[i
* 4 + 2];
3062 dst
[i
][GCOMP
] = (GLubyte
) src
[i
* 4 + 1];
3063 dst
[i
][BCOMP
] = (GLubyte
) src
[i
* 4 + 0];
3064 dst
[i
][ACOMP
] = (GLubyte
) src
[i
* 4 + 3];
3069 unpack_int_rgba_XRGB8888(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3073 for (i
= 0; i
< n
; i
++) {
3074 dst
[i
][RCOMP
] = (GLubyte
) src
[i
* 4 + 2];
3075 dst
[i
][GCOMP
] = (GLubyte
) src
[i
* 4 + 1];
3076 dst
[i
][BCOMP
] = (GLubyte
) src
[i
* 4 + 0];
3077 dst
[i
][ACOMP
] = (GLubyte
) 0xff;
3082 unpack_int_rgba_RGB_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3086 for (i
= 0; i
< n
; i
++) {
3087 dst
[i
][0] = src
[i
* 3 + 0];
3088 dst
[i
][1] = src
[i
* 3 + 1];
3089 dst
[i
][2] = src
[i
* 3 + 2];
3095 unpack_int_rgba_RGB_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3099 for (i
= 0; i
< n
; i
++) {
3100 dst
[i
][0] = src
[i
* 3 + 0];
3101 dst
[i
][1] = src
[i
* 3 + 1];
3102 dst
[i
][2] = src
[i
* 3 + 2];
3108 unpack_int_rgba_RGB_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3112 for (i
= 0; i
< n
; i
++) {
3113 dst
[i
][0] = src
[i
* 3 + 0];
3114 dst
[i
][1] = src
[i
* 3 + 1];
3115 dst
[i
][2] = src
[i
* 3 + 2];
3121 unpack_int_rgba_RGB_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3125 for (i
= 0; i
< n
; i
++) {
3126 dst
[i
][0] = src
[i
* 3 + 0];
3127 dst
[i
][1] = src
[i
* 3 + 1];
3128 dst
[i
][2] = src
[i
* 3 + 2];
3134 unpack_int_rgba_RGB_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3138 for (i
= 0; i
< n
; i
++) {
3139 dst
[i
][0] = src
[i
* 3 + 0];
3140 dst
[i
][1] = src
[i
* 3 + 1];
3141 dst
[i
][2] = src
[i
* 3 + 2];
3147 unpack_int_rgba_RG_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3151 for (i
= 0; i
< n
; i
++) {
3152 dst
[i
][0] = src
[i
* 2 + 0];
3153 dst
[i
][1] = src
[i
* 2 + 1];
3160 unpack_int_rgba_RG_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3164 for (i
= 0; i
< n
; i
++) {
3165 dst
[i
][0] = src
[i
* 2 + 0];
3166 dst
[i
][1] = src
[i
* 2 + 1];
3173 unpack_int_rgba_RG_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3177 for (i
= 0; i
< n
; i
++) {
3178 dst
[i
][0] = src
[i
* 2 + 0];
3179 dst
[i
][1] = src
[i
* 2 + 1];
3186 unpack_int_rgba_RG_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3190 for (i
= 0; i
< n
; i
++) {
3191 dst
[i
][0] = src
[i
* 2 + 0];
3192 dst
[i
][1] = src
[i
* 2 + 1];
3199 unpack_int_rgba_RG_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3203 for (i
= 0; i
< n
; i
++) {
3204 dst
[i
][0] = src
[i
* 2 + 0];
3205 dst
[i
][1] = src
[i
* 2 + 1];
3212 unpack_int_rgba_R_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3216 for (i
= 0; i
< n
; i
++) {
3225 unpack_int_rgba_R_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3229 for (i
= 0; i
< n
; i
++) {
3238 unpack_int_rgba_R_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3242 for (i
= 0; i
< n
; i
++) {
3251 unpack_int_rgba_R_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3255 for (i
= 0; i
< n
; i
++) {
3264 unpack_int_rgba_R_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3268 for (i
= 0; i
< n
; i
++) {
3277 unpack_int_rgba_ALPHA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3281 for (i
= 0; i
< n
; i
++) {
3282 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3288 unpack_int_rgba_ALPHA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3292 for (i
= 0; i
< n
; i
++) {
3293 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3299 unpack_int_rgba_ALPHA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3303 for (i
= 0; i
< n
; i
++) {
3304 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3310 unpack_int_rgba_ALPHA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3314 for (i
= 0; i
< n
; i
++) {
3315 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3321 unpack_int_rgba_ALPHA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3325 for (i
= 0; i
< n
; i
++) {
3326 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = 0;
3332 unpack_int_rgba_LUMINANCE_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3336 for (i
= 0; i
< n
; i
++) {
3337 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3343 unpack_int_rgba_LUMINANCE_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3347 for (i
= 0; i
< n
; i
++) {
3348 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3354 unpack_int_rgba_LUMINANCE_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3358 for (i
= 0; i
< n
; i
++) {
3359 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3365 unpack_int_rgba_LUMINANCE_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3369 for (i
= 0; i
< n
; i
++) {
3370 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3376 unpack_int_rgba_LUMINANCE_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3380 for (i
= 0; i
< n
; i
++) {
3381 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
];
3388 unpack_int_rgba_LUMINANCE_ALPHA_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3392 for (i
= 0; i
< n
; i
++) {
3393 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3394 dst
[i
][3] = src
[i
* 2 + 1];
3399 unpack_int_rgba_LUMINANCE_ALPHA_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3403 for (i
= 0; i
< n
; i
++) {
3404 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3405 dst
[i
][3] = src
[i
* 2 + 1];
3410 unpack_int_rgba_LUMINANCE_ALPHA_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3414 for (i
= 0; i
< n
; i
++) {
3415 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3416 dst
[i
][3] = src
[i
* 2 + 1];
3421 unpack_int_rgba_LUMINANCE_ALPHA_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3425 for (i
= 0; i
< n
; i
++) {
3426 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3427 dst
[i
][3] = src
[i
* 2 + 1];
3432 unpack_int_rgba_LUMINANCE_ALPHA_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3436 for (i
= 0; i
< n
; i
++) {
3437 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = src
[i
* 2 + 0];
3438 dst
[i
][3] = src
[i
* 2 + 1];
3443 unpack_int_rgba_INTENSITY_UINT32(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3447 for (i
= 0; i
< n
; i
++) {
3448 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3453 unpack_int_rgba_INTENSITY_UINT16(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3457 for (i
= 0; i
< n
; i
++) {
3458 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3463 unpack_int_rgba_INTENSITY_INT16(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3467 for (i
= 0; i
< n
; i
++) {
3468 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3473 unpack_int_rgba_INTENSITY_UINT8(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3477 for (i
= 0; i
< n
; i
++) {
3478 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3483 unpack_int_rgba_INTENSITY_INT8(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3487 for (i
= 0; i
< n
; i
++) {
3488 dst
[i
][0] = dst
[i
][1] = dst
[i
][2] = dst
[i
][3] = src
[i
];
3493 unpack_int_rgba_ARGB2101010_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
>> 20) & 0x3ff;
3500 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3501 dst
[i
][2] = (tmp
>> 0) & 0x3ff;
3502 dst
[i
][3] = (tmp
>> 30) & 0x3;
3507 unpack_int_rgba_ABGR2101010_UINT(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
>> 0) & 0x3ff;
3514 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3515 dst
[i
][2] = (tmp
>> 20) & 0x3ff;
3516 dst
[i
][3] = (tmp
>> 30) & 0x3;
3521 unpack_int_rgba_ARGB2101010(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3525 for (i
= 0; i
< n
; i
++) {
3526 GLuint tmp
= src
[i
];
3527 dst
[i
][0] = (tmp
>> 20) & 0x3ff;
3528 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3529 dst
[i
][2] = (tmp
>> 0) & 0x3ff;
3530 dst
[i
][3] = (tmp
>> 30) & 0x3;
3535 unpack_int_rgba_XBGR8888_UINT(const GLubyte
*src
, GLuint dst
[][4], GLuint n
)
3539 for (i
= 0; i
< n
; i
++) {
3540 dst
[i
][0] = src
[i
* 4 + 0];
3541 dst
[i
][1] = src
[i
* 4 + 1];
3542 dst
[i
][2] = src
[i
* 4 + 2];
3548 unpack_int_rgba_XBGR8888_SINT(const GLbyte
*src
, GLuint dst
[][4], GLuint n
)
3552 for (i
= 0; i
< n
; i
++) {
3553 dst
[i
][0] = src
[i
* 4 + 0];
3554 dst
[i
][1] = src
[i
* 4 + 1];
3555 dst
[i
][2] = src
[i
* 4 + 2];
3561 unpack_int_rgba_XBGR16161616_UINT(const GLushort
*src
, GLuint dst
[][4], GLuint n
)
3565 for (i
= 0; i
< n
; i
++) {
3566 dst
[i
][0] = src
[i
* 4 + 0];
3567 dst
[i
][1] = src
[i
* 4 + 1];
3568 dst
[i
][2] = src
[i
* 4 + 2];
3574 unpack_int_rgba_XBGR16161616_SINT(const GLshort
*src
, GLuint dst
[][4], GLuint n
)
3578 for (i
= 0; i
< n
; i
++) {
3579 dst
[i
][0] = src
[i
* 4 + 0];
3580 dst
[i
][1] = src
[i
* 4 + 1];
3581 dst
[i
][2] = src
[i
* 4 + 2];
3587 unpack_int_rgba_XBGR32323232_UINT(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3591 for (i
= 0; i
< n
; i
++) {
3592 dst
[i
][0] = src
[i
* 4 + 0];
3593 dst
[i
][1] = src
[i
* 4 + 1];
3594 dst
[i
][2] = src
[i
* 4 + 2];
3600 unpack_int_rgba_ABGR2101010(const GLuint
*src
, GLuint dst
[][4], GLuint n
)
3604 for (i
= 0; i
< n
; i
++) {
3605 GLuint tmp
= src
[i
];
3606 dst
[i
][0] = (tmp
>> 0) & 0x3ff;
3607 dst
[i
][1] = (tmp
>> 10) & 0x3ff;
3608 dst
[i
][2] = (tmp
>> 20) & 0x3ff;
3609 dst
[i
][3] = (tmp
>> 30) & 0x3;
3614 _mesa_unpack_uint_rgba_row(gl_format format
, GLuint n
,
3615 const void *src
, GLuint dst
[][4])
3618 /* Since there won't be any sign extension happening, there's no need to
3619 * make separate paths for 32-bit-to-32-bit integer unpack.
3621 case MESA_FORMAT_RGBA_UINT32
:
3622 case MESA_FORMAT_RGBA_INT32
:
3623 unpack_int_rgba_RGBA_UINT32(src
, dst
, n
);
3626 case MESA_FORMAT_RGBA_UINT16
:
3627 unpack_int_rgba_RGBA_UINT16(src
, dst
, n
);
3629 case MESA_FORMAT_RGBA_INT16
:
3630 unpack_int_rgba_RGBA_INT16(src
, dst
, n
);
3633 case MESA_FORMAT_RGBA_UINT8
:
3634 unpack_int_rgba_RGBA_UINT8(src
, dst
, n
);
3636 case MESA_FORMAT_RGBA_INT8
:
3637 unpack_int_rgba_RGBA_INT8(src
, dst
, n
);
3640 case MESA_FORMAT_ARGB8888
:
3641 unpack_int_rgba_ARGB8888(src
, dst
, n
);
3644 case MESA_FORMAT_XRGB8888
:
3645 unpack_int_rgba_XRGB8888(src
, dst
, n
);
3648 case MESA_FORMAT_RGB_UINT32
:
3649 case MESA_FORMAT_RGB_INT32
:
3650 unpack_int_rgba_RGB_UINT32(src
, dst
, n
);
3653 case MESA_FORMAT_RGB_UINT16
:
3654 unpack_int_rgba_RGB_UINT16(src
, dst
, n
);
3656 case MESA_FORMAT_RGB_INT16
:
3657 unpack_int_rgba_RGB_INT16(src
, dst
, n
);
3660 case MESA_FORMAT_RGB_UINT8
:
3661 unpack_int_rgba_RGB_UINT8(src
, dst
, n
);
3663 case MESA_FORMAT_RGB_INT8
:
3664 unpack_int_rgba_RGB_INT8(src
, dst
, n
);
3667 case MESA_FORMAT_RG_UINT32
:
3668 case MESA_FORMAT_RG_INT32
:
3669 unpack_int_rgba_RG_UINT32(src
, dst
, n
);
3672 case MESA_FORMAT_RG_UINT16
:
3673 unpack_int_rgba_RG_UINT16(src
, dst
, n
);
3675 case MESA_FORMAT_RG_INT16
:
3676 unpack_int_rgba_RG_INT16(src
, dst
, n
);
3679 case MESA_FORMAT_RG_UINT8
:
3680 unpack_int_rgba_RG_UINT8(src
, dst
, n
);
3682 case MESA_FORMAT_RG_INT8
:
3683 unpack_int_rgba_RG_INT8(src
, dst
, n
);
3686 case MESA_FORMAT_R_UINT32
:
3687 case MESA_FORMAT_R_INT32
:
3688 unpack_int_rgba_R_UINT32(src
, dst
, n
);
3691 case MESA_FORMAT_R_UINT16
:
3692 unpack_int_rgba_R_UINT16(src
, dst
, n
);
3694 case MESA_FORMAT_R_INT16
:
3695 unpack_int_rgba_R_INT16(src
, dst
, n
);
3698 case MESA_FORMAT_R_UINT8
:
3699 unpack_int_rgba_R_UINT8(src
, dst
, n
);
3701 case MESA_FORMAT_R_INT8
:
3702 unpack_int_rgba_R_INT8(src
, dst
, n
);
3705 case MESA_FORMAT_ALPHA_UINT32
:
3706 case MESA_FORMAT_ALPHA_INT32
:
3707 unpack_int_rgba_ALPHA_UINT32(src
, dst
, n
);
3710 case MESA_FORMAT_ALPHA_UINT16
:
3711 unpack_int_rgba_ALPHA_UINT16(src
, dst
, n
);
3713 case MESA_FORMAT_ALPHA_INT16
:
3714 unpack_int_rgba_ALPHA_INT16(src
, dst
, n
);
3717 case MESA_FORMAT_ALPHA_UINT8
:
3718 unpack_int_rgba_ALPHA_UINT8(src
, dst
, n
);
3720 case MESA_FORMAT_ALPHA_INT8
:
3721 unpack_int_rgba_ALPHA_INT8(src
, dst
, n
);
3724 case MESA_FORMAT_LUMINANCE_UINT32
:
3725 case MESA_FORMAT_LUMINANCE_INT32
:
3726 unpack_int_rgba_LUMINANCE_UINT32(src
, dst
, n
);
3728 case MESA_FORMAT_LUMINANCE_UINT16
:
3729 unpack_int_rgba_LUMINANCE_UINT16(src
, dst
, n
);
3731 case MESA_FORMAT_LUMINANCE_INT16
:
3732 unpack_int_rgba_LUMINANCE_INT16(src
, dst
, n
);
3735 case MESA_FORMAT_LUMINANCE_UINT8
:
3736 unpack_int_rgba_LUMINANCE_UINT8(src
, dst
, n
);
3738 case MESA_FORMAT_LUMINANCE_INT8
:
3739 unpack_int_rgba_LUMINANCE_INT8(src
, dst
, n
);
3742 case MESA_FORMAT_LUMINANCE_ALPHA_UINT32
:
3743 case MESA_FORMAT_LUMINANCE_ALPHA_INT32
:
3744 unpack_int_rgba_LUMINANCE_ALPHA_UINT32(src
, dst
, n
);
3747 case MESA_FORMAT_LUMINANCE_ALPHA_UINT16
:
3748 unpack_int_rgba_LUMINANCE_ALPHA_UINT16(src
, dst
, n
);
3750 case MESA_FORMAT_LUMINANCE_ALPHA_INT16
:
3751 unpack_int_rgba_LUMINANCE_ALPHA_INT16(src
, dst
, n
);
3754 case MESA_FORMAT_LUMINANCE_ALPHA_UINT8
:
3755 unpack_int_rgba_LUMINANCE_ALPHA_UINT8(src
, dst
, n
);
3757 case MESA_FORMAT_LUMINANCE_ALPHA_INT8
:
3758 unpack_int_rgba_LUMINANCE_ALPHA_INT8(src
, dst
, n
);
3761 case MESA_FORMAT_INTENSITY_UINT32
:
3762 case MESA_FORMAT_INTENSITY_INT32
:
3763 unpack_int_rgba_INTENSITY_UINT32(src
, dst
, n
);
3766 case MESA_FORMAT_INTENSITY_UINT16
:
3767 unpack_int_rgba_INTENSITY_UINT16(src
, dst
, n
);
3769 case MESA_FORMAT_INTENSITY_INT16
:
3770 unpack_int_rgba_INTENSITY_INT16(src
, dst
, n
);
3773 case MESA_FORMAT_INTENSITY_UINT8
:
3774 unpack_int_rgba_INTENSITY_UINT8(src
, dst
, n
);
3776 case MESA_FORMAT_INTENSITY_INT8
:
3777 unpack_int_rgba_INTENSITY_INT8(src
, dst
, n
);
3780 case MESA_FORMAT_ARGB2101010_UINT
:
3781 unpack_int_rgba_ARGB2101010_UINT(src
, dst
, n
);
3784 case MESA_FORMAT_ABGR2101010_UINT
:
3785 unpack_int_rgba_ABGR2101010_UINT(src
, dst
, n
);
3788 case MESA_FORMAT_ARGB2101010
:
3789 unpack_int_rgba_ARGB2101010(src
, dst
, n
);
3792 case MESA_FORMAT_XBGR8888_UINT
:
3793 unpack_int_rgba_XBGR8888_UINT(src
, dst
, n
);
3796 case MESA_FORMAT_XBGR8888_SINT
:
3797 unpack_int_rgba_XBGR8888_SINT(src
, dst
, n
);
3800 case MESA_FORMAT_XBGR16161616_UINT
:
3801 unpack_int_rgba_XBGR16161616_UINT(src
, dst
, n
);
3804 case MESA_FORMAT_XBGR16161616_SINT
:
3805 unpack_int_rgba_XBGR16161616_SINT(src
, dst
, n
);
3808 case MESA_FORMAT_XBGR32323232_UINT
:
3809 case MESA_FORMAT_XBGR32323232_SINT
:
3810 unpack_int_rgba_XBGR32323232_UINT(src
, dst
, n
);
3813 case MESA_FORMAT_ABGR2101010
:
3814 unpack_int_rgba_ABGR2101010(src
, dst
, n
);
3818 _mesa_problem(NULL
, "%s: bad format %s", __FUNCTION__
,
3819 _mesa_get_format_name(format
));
3825 * Unpack a 2D rect of pixels returning float RGBA colors.
3826 * \param format the source image format
3827 * \param src start address of the source image
3828 * \param srcRowStride source image row stride in bytes
3829 * \param dst start address of the dest image
3830 * \param dstRowStride dest image row stride in bytes
3831 * \param x source image start X pos
3832 * \param y source image start Y pos
3833 * \param width width of rect region to convert
3834 * \param height height of rect region to convert
3837 _mesa_unpack_rgba_block(gl_format format
,
3838 const void *src
, GLint srcRowStride
,
3839 GLfloat dst
[][4], GLint dstRowStride
,
3840 GLuint x
, GLuint y
, GLuint width
, GLuint height
)
3842 unpack_rgba_func unpack
= get_unpack_rgba_function(format
);
3843 const GLuint srcPixStride
= _mesa_get_format_bytes(format
);
3844 const GLuint dstPixStride
= 4 * sizeof(GLfloat
);
3845 const GLubyte
*srcRow
;
3849 /* XXX needs to be fixed for compressed formats */
3851 srcRow
= ((const GLubyte
*) src
) + srcRowStride
* y
+ srcPixStride
* x
;
3852 dstRow
= ((GLubyte
*) dst
) + dstRowStride
* y
+ dstPixStride
* x
;
3854 for (i
= 0; i
< height
; i
++) {
3855 unpack(srcRow
, (GLfloat (*)[4]) dstRow
, width
);
3857 dstRow
+= dstRowStride
;
3858 srcRow
+= srcRowStride
;
3865 typedef void (*unpack_float_z_func
)(GLuint n
, const void *src
, GLfloat
*dst
);
3868 unpack_float_z_Z24_X8(GLuint n
, const void *src
, GLfloat
*dst
)
3870 /* only return Z, not stencil data */
3871 const GLuint
*s
= ((const GLuint
*) src
);
3872 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
3874 for (i
= 0; i
< n
; i
++) {
3875 dst
[i
] = (GLfloat
) ((s
[i
] >> 8) * scale
);
3876 ASSERT(dst
[i
] >= 0.0F
);
3877 ASSERT(dst
[i
] <= 1.0F
);
3882 unpack_float_z_X8_Z24(GLuint n
, const void *src
, GLfloat
*dst
)
3884 /* only return Z, not stencil data */
3885 const GLuint
*s
= ((const GLuint
*) src
);
3886 const GLdouble scale
= 1.0 / (GLdouble
) 0xffffff;
3888 for (i
= 0; i
< n
; i
++) {
3889 dst
[i
] = (GLfloat
) ((s
[i
] & 0x00ffffff) * scale
);
3890 ASSERT(dst
[i
] >= 0.0F
);
3891 ASSERT(dst
[i
] <= 1.0F
);
3896 unpack_float_z_Z16(GLuint n
, const void *src
, GLfloat
*dst
)
3898 const GLushort
*s
= ((const GLushort
*) src
);
3900 for (i
= 0; i
< n
; i
++) {
3901 dst
[i
] = s
[i
] * (1.0F
/ 65535.0F
);
3906 unpack_float_z_Z32(GLuint n
, const void *src
, GLfloat
*dst
)
3908 const GLuint
*s
= ((const GLuint
*) src
);
3910 for (i
= 0; i
< n
; i
++) {
3911 dst
[i
] = s
[i
] * (1.0F
/ 0xffffffff);
3916 unpack_float_z_Z32F(GLuint n
, const void *src
, GLfloat
*dst
)
3918 memcpy(dst
, src
, n
* sizeof(float));
3922 unpack_float_z_Z32X24S8(GLuint n
, const void *src
, GLfloat
*dst
)
3924 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
3926 for (i
= 0; i
< n
; i
++) {
3935 * The returned values will always be in the range [0.0, 1.0].
3938 _mesa_unpack_float_z_row(gl_format format
, GLuint n
,
3939 const void *src
, GLfloat
*dst
)
3941 unpack_float_z_func unpack
;
3944 case MESA_FORMAT_Z24_S8
:
3945 case MESA_FORMAT_Z24_X8
:
3946 unpack
= unpack_float_z_Z24_X8
;
3948 case MESA_FORMAT_S8_Z24
:
3949 case MESA_FORMAT_X8_Z24
:
3950 unpack
= unpack_float_z_X8_Z24
;
3952 case MESA_FORMAT_Z16
:
3953 unpack
= unpack_float_z_Z16
;
3955 case MESA_FORMAT_Z32
:
3956 unpack
= unpack_float_z_Z32
;
3958 case MESA_FORMAT_Z32_FLOAT
:
3959 unpack
= unpack_float_z_Z32F
;
3961 case MESA_FORMAT_Z32_FLOAT_X24S8
:
3962 unpack
= unpack_float_z_Z32X24S8
;
3965 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_float_z_row",
3966 _mesa_get_format_name(format
));
3970 unpack(n
, src
, dst
);
3975 typedef void (*unpack_uint_z_func
)(const void *src
, GLuint
*dst
, GLuint n
);
3978 unpack_uint_z_Z24_X8(const void *src
, GLuint
*dst
, GLuint n
)
3980 /* only return Z, not stencil data */
3981 const GLuint
*s
= ((const GLuint
*) src
);
3983 for (i
= 0; i
< n
; i
++) {
3984 dst
[i
] = (s
[i
] & 0xffffff00) | (s
[i
] >> 24);
3989 unpack_uint_z_X8_Z24(const void *src
, GLuint
*dst
, GLuint n
)
3991 /* only return Z, not stencil data */
3992 const GLuint
*s
= ((const GLuint
*) src
);
3994 for (i
= 0; i
< n
; i
++) {
3995 dst
[i
] = (s
[i
] << 8) | ((s
[i
] >> 16) & 0xff);
4000 unpack_uint_z_Z16(const void *src
, GLuint
*dst
, GLuint n
)
4002 const GLushort
*s
= ((const GLushort
*)src
);
4004 for (i
= 0; i
< n
; i
++) {
4005 dst
[i
] = (s
[i
] << 16) | s
[i
];
4010 unpack_uint_z_Z32(const void *src
, GLuint
*dst
, GLuint n
)
4012 memcpy(dst
, src
, n
* sizeof(GLuint
));
4016 unpack_uint_z_Z32_FLOAT(const void *src
, GLuint
*dst
, GLuint n
)
4018 const float *s
= (const float *)src
;
4020 for (i
= 0; i
< n
; i
++) {
4021 dst
[i
] = FLOAT_TO_UINT(CLAMP(s
[i
], 0.0F
, 1.0F
));
4026 unpack_uint_z_Z32_FLOAT_X24S8(const void *src
, GLuint
*dst
, GLuint n
)
4028 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
4031 for (i
= 0; i
< n
; i
++) {
4032 dst
[i
] = FLOAT_TO_UINT(CLAMP(s
[i
].z
, 0.0F
, 1.0F
));
4039 * The returned values will always be in the range [0, 0xffffffff].
4042 _mesa_unpack_uint_z_row(gl_format format
, GLuint n
,
4043 const void *src
, GLuint
*dst
)
4045 unpack_uint_z_func unpack
;
4046 const GLubyte
*srcPtr
= (GLubyte
*) src
;
4049 case MESA_FORMAT_Z24_S8
:
4050 case MESA_FORMAT_Z24_X8
:
4051 unpack
= unpack_uint_z_Z24_X8
;
4053 case MESA_FORMAT_S8_Z24
:
4054 case MESA_FORMAT_X8_Z24
:
4055 unpack
= unpack_uint_z_X8_Z24
;
4057 case MESA_FORMAT_Z16
:
4058 unpack
= unpack_uint_z_Z16
;
4060 case MESA_FORMAT_Z32
:
4061 unpack
= unpack_uint_z_Z32
;
4063 case MESA_FORMAT_Z32_FLOAT
:
4064 unpack
= unpack_uint_z_Z32_FLOAT
;
4066 case MESA_FORMAT_Z32_FLOAT_X24S8
:
4067 unpack
= unpack_uint_z_Z32_FLOAT_X24S8
;
4070 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_uint_z_row",
4071 _mesa_get_format_name(format
));
4075 unpack(srcPtr
, dst
, n
);
4080 unpack_ubyte_s_S8(const void *src
, GLubyte
*dst
, GLuint n
)
4082 memcpy(dst
, src
, n
);
4086 unpack_ubyte_s_Z24_S8(const void *src
, GLubyte
*dst
, GLuint n
)
4089 const GLuint
*src32
= src
;
4091 for (i
= 0; i
< n
; i
++)
4092 dst
[i
] = src32
[i
] & 0xff;
4096 unpack_ubyte_s_S8_Z24(const void *src
, GLubyte
*dst
, GLuint n
)
4099 const GLuint
*src32
= src
;
4101 for (i
= 0; i
< n
; i
++)
4102 dst
[i
] = src32
[i
] >> 24;
4106 unpack_ubyte_s_Z32_FLOAT_X24S8(const void *src
, GLubyte
*dst
, GLuint n
)
4109 const struct z32f_x24s8
*s
= (const struct z32f_x24s8
*) src
;
4111 for (i
= 0; i
< n
; i
++)
4112 dst
[i
] = s
[i
].x24s8
& 0xff;
4116 _mesa_unpack_ubyte_stencil_row(gl_format format
, GLuint n
,
4117 const void *src
, GLubyte
*dst
)
4120 case MESA_FORMAT_S8
:
4121 unpack_ubyte_s_S8(src
, dst
, n
);
4123 case MESA_FORMAT_Z24_S8
:
4124 unpack_ubyte_s_Z24_S8(src
, dst
, n
);
4126 case MESA_FORMAT_S8_Z24
:
4127 unpack_ubyte_s_S8_Z24(src
, dst
, n
);
4129 case MESA_FORMAT_Z32_FLOAT_X24S8
:
4130 unpack_ubyte_s_Z32_FLOAT_X24S8(src
, dst
, n
);
4133 _mesa_problem(NULL
, "bad format %s in _mesa_unpack_ubyte_s_row",
4134 _mesa_get_format_name(format
));
4140 unpack_uint_24_8_depth_stencil_S8_Z24(const GLuint
*src
, GLuint
*dst
, GLuint n
)
4144 for (i
= 0; i
< n
; i
++) {
4145 GLuint val
= src
[i
];
4146 dst
[i
] = val
>> 24 | val
<< 8;
4151 unpack_uint_24_8_depth_stencil_Z24_S8(const GLuint
*src
, GLuint
*dst
, GLuint n
)
4153 memcpy(dst
, src
, n
* 4);
4157 _mesa_unpack_uint_24_8_depth_stencil_row(gl_format format
, GLuint n
,
4158 const void *src
, GLuint
*dst
)
4161 case MESA_FORMAT_Z24_S8
:
4162 unpack_uint_24_8_depth_stencil_Z24_S8(src
, dst
, n
);
4164 case MESA_FORMAT_S8_Z24
:
4165 unpack_uint_24_8_depth_stencil_S8_Z24(src
, dst
, n
);
4169 "bad format %s in _mesa_unpack_uint_24_8_depth_stencil_row",
4170 _mesa_get_format_name(format
));