ReactOS 0.4.15-dev-7918-g2a2556c
txc_fetch_dxtn.c File Reference
#include <stdio.h>
#include "txc_dxtn.h"
Include dependency graph for txc_fetch_dxtn.c:

Go to the source code of this file.

Macros

#define EXP5TO8R(packedcol)    ((((packedcol) >> 8) & 0xf8) | (((packedcol) >> 13) & 0x7))
 
#define EXP6TO8G(packedcol)    ((((packedcol) >> 3) & 0xfc) | (((packedcol) >> 9) & 0x3))
 
#define EXP5TO8B(packedcol)    ((((packedcol) << 3) & 0xf8) | (((packedcol) >> 2) & 0x7))
 
#define EXP4TO8(col)    ((col) | ((col) << 4))
 

Functions

static void dxt135_decode_imageblock (const GLubyte *img_block_src, GLint i, GLint j, GLuint dxt_type, GLvoid *texel)
 
void fetch_2d_texel_rgb_dxt1 (GLint srcRowStride, const GLubyte *pixdata, GLint i, GLint j, GLvoid *texel)
 
void fetch_2d_texel_rgba_dxt1 (GLint srcRowStride, const GLubyte *pixdata, GLint i, GLint j, GLvoid *texel)
 
void fetch_2d_texel_rgba_dxt3 (GLint srcRowStride, const GLubyte *pixdata, GLint i, GLint j, GLvoid *texel)
 
void fetch_2d_texel_rgba_dxt5 (GLint srcRowStride, const GLubyte *pixdata, GLint i, GLint j, GLvoid *texel)
 

Macro Definition Documentation

◆ EXP4TO8

#define EXP4TO8 (   col)     ((col) | ((col) << 4))

Definition at line 37 of file txc_fetch_dxtn.c.

◆ EXP5TO8B

#define EXP5TO8B (   packedcol)     ((((packedcol) << 3) & 0xf8) | (((packedcol) >> 2) & 0x7))

Definition at line 34 of file txc_fetch_dxtn.c.

◆ EXP5TO8R

#define EXP5TO8R (   packedcol)     ((((packedcol) >> 8) & 0xf8) | (((packedcol) >> 13) & 0x7))

Definition at line 28 of file txc_fetch_dxtn.c.

◆ EXP6TO8G

#define EXP6TO8G (   packedcol)     ((((packedcol) >> 3) & 0xfc) | (((packedcol) >> 9) & 0x3))

Definition at line 31 of file txc_fetch_dxtn.c.

Function Documentation

◆ dxt135_decode_imageblock()

static void dxt135_decode_imageblock ( const GLubyte img_block_src,
GLint  i,
GLint  j,
GLuint  dxt_type,
GLvoid texel 
)
static

Definition at line 42 of file txc_fetch_dxtn.c.

43 {
44 GLchan *rgba = (GLchan *) texel;
45 const GLushort color0 = img_block_src[0] | (img_block_src[1] << 8);
46 const GLushort color1 = img_block_src[2] | (img_block_src[3] << 8);
47 const GLuint bits = img_block_src[4] | (img_block_src[5] << 8) |
48 (img_block_src[6] << 16) | (img_block_src[7] << 24);
49 /* What about big/little endian? */
50 GLubyte bit_pos = 2 * (j * 4 + i) ;
51 GLubyte code = (GLubyte) ((bits >> bit_pos) & 3);
52
53 rgba[ACOMP] = CHAN_MAX;
54 switch (code) {
55 case 0:
56 rgba[RCOMP] = UBYTE_TO_CHAN( EXP5TO8R(color0) );
57 rgba[GCOMP] = UBYTE_TO_CHAN( EXP6TO8G(color0) );
58 rgba[BCOMP] = UBYTE_TO_CHAN( EXP5TO8B(color0) );
59 break;
60 case 1:
61 rgba[RCOMP] = UBYTE_TO_CHAN( EXP5TO8R(color1) );
62 rgba[GCOMP] = UBYTE_TO_CHAN( EXP6TO8G(color1) );
63 rgba[BCOMP] = UBYTE_TO_CHAN( EXP5TO8B(color1) );
64 break;
65 case 2:
66 if ((dxt_type > 1) || (color0 > color1)) {
67 rgba[RCOMP] = UBYTE_TO_CHAN( ((EXP5TO8R(color0) * 2 + EXP5TO8R(color1)) / 3) );
68 rgba[GCOMP] = UBYTE_TO_CHAN( ((EXP6TO8G(color0) * 2 + EXP6TO8G(color1)) / 3) );
69 rgba[BCOMP] = UBYTE_TO_CHAN( ((EXP5TO8B(color0) * 2 + EXP5TO8B(color1)) / 3) );
70 }
71 else {
72 rgba[RCOMP] = UBYTE_TO_CHAN( ((EXP5TO8R(color0) + EXP5TO8R(color1)) / 2) );
73 rgba[GCOMP] = UBYTE_TO_CHAN( ((EXP6TO8G(color0) + EXP6TO8G(color1)) / 2) );
74 rgba[BCOMP] = UBYTE_TO_CHAN( ((EXP5TO8B(color0) + EXP5TO8B(color1)) / 2) );
75 }
76 break;
77 case 3:
78 if ((dxt_type > 1) || (color0 > color1)) {
79 rgba[RCOMP] = UBYTE_TO_CHAN( ((EXP5TO8R(color0) + EXP5TO8R(color1) * 2) / 3) );
80 rgba[GCOMP] = UBYTE_TO_CHAN( ((EXP6TO8G(color0) + EXP6TO8G(color1) * 2) / 3) );
81 rgba[BCOMP] = UBYTE_TO_CHAN( ((EXP5TO8B(color0) + EXP5TO8B(color1) * 2) / 3) );
82 }
83 else {
84 rgba[RCOMP] = 0;
85 rgba[GCOMP] = 0;
86 rgba[BCOMP] = 0;
87 if (dxt_type == 1) rgba[ACOMP] = UBYTE_TO_CHAN(0);
88 }
89 break;
90 default:
91 /* CANNOT happen (I hope) */
92 break;
93 }
94}
#define ACOMP
Definition: txc_dxtn.h:36
#define BCOMP
Definition: txc_dxtn.h:35
#define RCOMP
Definition: txc_dxtn.h:33
#define CHAN_MAX
Definition: txc_dxtn.h:32
GLubyte GLchan
Definition: txc_dxtn.h:30
#define UBYTE_TO_CHAN(b)
Definition: txc_dxtn.h:31
#define GCOMP
Definition: txc_dxtn.h:34
#define EXP5TO8R(packedcol)
#define EXP6TO8G(packedcol)
#define EXP5TO8B(packedcol)
unsigned char GLubyte
Definition: gl.h:157
unsigned int GLuint
Definition: gl.h:159
unsigned short GLushort
Definition: gl.h:158
GLenum GLint GLenum GLsizei GLsizei GLsizei GLint GLsizei const GLvoid * bits
Definition: glext.h:10929
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint GLint GLint j
Definition: glfuncs.h:250
Definition: inflate.c:139

Referenced by fetch_2d_texel_rgb_dxt1(), fetch_2d_texel_rgba_dxt1(), fetch_2d_texel_rgba_dxt3(), and fetch_2d_texel_rgba_dxt5().

◆ fetch_2d_texel_rgb_dxt1()

void fetch_2d_texel_rgb_dxt1 ( GLint  srcRowStride,
const GLubyte pixdata,
GLint  i,
GLint  j,
GLvoid texel 
)

Definition at line 97 of file txc_fetch_dxtn.c.

99{
100 /* Extract the (i,j) pixel from pixdata and return it
101 * in texel[RCOMP], texel[GCOMP], texel[BCOMP], texel[ACOMP].
102 */
103
104 const GLubyte *blksrc = (pixdata + ((srcRowStride + 3) / 4 * (j / 4) + (i / 4)) * 8);
105 dxt135_decode_imageblock(blksrc, (i&3), (j&3), 0, texel);
106}
static void dxt135_decode_imageblock(const GLubyte *img_block_src, GLint i, GLint j, GLuint dxt_type, GLvoid *texel)
static const unsigned char pixdata[]
Definition: surface.c:101

◆ fetch_2d_texel_rgba_dxt1()

void fetch_2d_texel_rgba_dxt1 ( GLint  srcRowStride,
const GLubyte pixdata,
GLint  i,
GLint  j,
GLvoid texel 
)

Definition at line 109 of file txc_fetch_dxtn.c.

111{
112 /* Extract the (i,j) pixel from pixdata and return it
113 * in texel[RCOMP], texel[GCOMP], texel[BCOMP], texel[ACOMP].
114 */
115
116 const GLubyte *blksrc = (pixdata + ((srcRowStride + 3) / 4 * (j / 4) + (i / 4)) * 8);
117 dxt135_decode_imageblock(blksrc, (i&3), (j&3), 1, texel);
118}

◆ fetch_2d_texel_rgba_dxt3()

void fetch_2d_texel_rgba_dxt3 ( GLint  srcRowStride,
const GLubyte pixdata,
GLint  i,
GLint  j,
GLvoid texel 
)

Definition at line 120 of file txc_fetch_dxtn.c.

121 {
122
123 /* Extract the (i,j) pixel from pixdata and return it
124 * in texel[RCOMP], texel[GCOMP], texel[BCOMP], texel[ACOMP].
125 */
126
127 GLchan *rgba = (GLchan *) texel;
128 const GLubyte *blksrc = (pixdata + ((srcRowStride + 3) / 4 * (j / 4) + (i / 4)) * 16);
129#if 0
130 /* Simple 32bit version. */
131/* that's pretty brain-dead for a single pixel, isn't it? */
132 const GLubyte bit_pos = 4 * ((j&3) * 4 + (i&3));
133 const GLuint alpha_low = blksrc[0] | (blksrc[1] << 8) | (blksrc[2] << 16) | (blksrc[3] << 24);
134 const GLuint alpha_high = blksrc[4] | (blksrc[5] << 8) | (blksrc[6] << 16) | (blksrc[7] << 24);
135
136 dxt135_decode_imageblock(blksrc + 8, (i&3), (j&3), 2, texel);
137 if (bit_pos < 32)
138 rgba[ACOMP] = UBYTE_TO_CHAN( (GLubyte)(EXP4TO8((alpha_low >> bit_pos) & 15)) );
139 else
140 rgba[ACOMP] = UBYTE_TO_CHAN( (GLubyte)(EXP4TO8((alpha_high >> (bit_pos - 32)) & 15)) );
141#endif
142#if 1
143/* TODO test this! */
144 const GLubyte anibble = (blksrc[((j&3) * 4 + (i&3)) / 2] >> (4 * (i&1))) & 0xf;
145 dxt135_decode_imageblock(blksrc + 8, (i&3), (j&3), 2, texel);
146 rgba[ACOMP] = UBYTE_TO_CHAN( (GLubyte)(EXP4TO8(anibble)) );
147#endif
148
149}
#define EXP4TO8(col)

◆ fetch_2d_texel_rgba_dxt5()

void fetch_2d_texel_rgba_dxt5 ( GLint  srcRowStride,
const GLubyte pixdata,
GLint  i,
GLint  j,
GLvoid texel 
)

Definition at line 151 of file txc_fetch_dxtn.c.

152 {
153
154 /* Extract the (i,j) pixel from pixdata and return it
155 * in texel[RCOMP], texel[GCOMP], texel[BCOMP], texel[ACOMP].
156 */
157
158 GLchan *rgba = (GLchan *) texel;
159 const GLubyte *blksrc = (pixdata + ((srcRowStride + 3) / 4 * (j / 4) + (i / 4)) * 16);
160 const GLubyte alpha0 = blksrc[0];
161 const GLubyte alpha1 = blksrc[1];
162#if 0
163 const GLubyte bit_pos = 3 * ((j&3) * 4 + (i&3));
164 /* simple 32bit version */
165 const GLuint bits_low = blksrc[2] | (blksrc[3] << 8) | (blksrc[4] << 16) | (blksrc[5] << 24);
166 const GLuint bits_high = blksrc[6] | (blksrc[7] << 8);
168
169 if (bit_pos < 30)
170 code = (GLubyte) ((bits_low >> bit_pos) & 7);
171 else if (bit_pos == 30)
172 code = (GLubyte) ((bits_low >> 30) & 3) | ((bits_high << 2) & 4);
173 else
174 code = (GLubyte) ((bits_high >> (bit_pos - 32)) & 7);
175#endif
176#if 1
177/* TODO test this! */
178 const GLubyte bit_pos = ((j&3) * 4 + (i&3)) * 3;
179 const GLubyte acodelow = blksrc[2 + bit_pos / 8];
180 const GLubyte acodehigh = blksrc[3 + bit_pos / 8];
181 const GLubyte code = (acodelow >> (bit_pos & 0x7) |
182 (acodehigh << (8 - (bit_pos & 0x7)))) & 0x7;
183#endif
184 dxt135_decode_imageblock(blksrc + 8, (i&3), (j&3), 2, texel);
185#if 0
186 if (alpha0 > alpha1) {
187 switch (code) {
188 case 0:
189 rgba[ACOMP] = UBYTE_TO_CHAN( alpha0 );
190 break;
191 case 1:
192 rgba[ACOMP] = UBYTE_TO_CHAN( alpha1 );
193 break;
194 case 2:
195 case 3:
196 case 4:
197 case 5:
198 case 6:
199 case 7:
200 rgba[ACOMP] = UBYTE_TO_CHAN( ((alpha0 * (8 - code) + (alpha1 * (code - 1))) / 7) );
201 break;
202 }
203 }
204 else {
205 switch (code) {
206 case 0:
207 rgba[ACOMP] = UBYTE_TO_CHAN( alpha0 );
208 break;
209 case 1:
210 rgba[ACOMP] = UBYTE_TO_CHAN( alpha1 );
211 break;
212 case 2:
213 case 3:
214 case 4:
215 case 5:
216 rgba[ACOMP] = UBYTE_TO_CHAN( ((alpha0 * (6 - code) + (alpha1 * (code - 1))) / 5) );
217 break;
218 case 6:
219 rgba[ACOMP] = 0;
220 break;
221 case 7:
222 rgba[ACOMP] = CHAN_MAX;
223 break;
224 }
225 }
226#endif
227/* not sure. Which version is faster? */
228#if 1
229/* TODO test this */
230 if (code == 0)
231 rgba[ACOMP] = UBYTE_TO_CHAN( alpha0 );
232 else if (code == 1)
233 rgba[ACOMP] = UBYTE_TO_CHAN( alpha1 );
234 else if (alpha0 > alpha1)
235 rgba[ACOMP] = UBYTE_TO_CHAN( ((alpha0 * (8 - code) + (alpha1 * (code - 1))) / 7) );
236 else if (code < 6)
237 rgba[ACOMP] = UBYTE_TO_CHAN( ((alpha0 * (6 - code) + (alpha1 * (code - 1))) / 5) );
238 else if (code == 6)
239 rgba[ACOMP] = 0;
240 else
241 rgba[ACOMP] = CHAN_MAX;
242#endif
243}