Mercurial > hg > dmlib
annotate dmblitfunc.h @ 100:f16d102dbbac
Add a function for setting bitmapped font palette.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Tue, 02 Oct 2012 20:33:01 +0300 |
parents | 0430f484641b |
children | afa28947e400 |
rev | line source |
---|---|
0 | 1 /* |
2 * DMLib | |
3 * -- Sprite / surface blitting functions | |
4 * Programmed and designed by Matti 'ccr' Hamalainen | |
5 * (C) Copyright 2011-2012 Tecnic Software productions (TNSP) | |
6 */ | |
7 | |
8 // ======================================================================= | |
9 // DMD_NONE | |
10 // ======================================================================= | |
11 | |
85 | 12 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to8 |
13 #define DM_BLITFUNC_SRC_BYTES 1 | |
14 #define DM_BLITFUNC_DST_BYTES 1 | |
15 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
16 #define DM_BLITFUNC_DST_TYPE Uint8 | |
0 | 17 |
85 | 18 #define DM_BLITFUNC_INNER *dp++ = sp[FP_GETH(xv)]; |
0 | 19 |
20 #include "dmscaledblit.h" | |
21 | |
22 // ----------------------------------------------------------------------- | |
23 | |
85 | 24 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to32 |
25 #define DM_BLITFUNC_SRC_BYTES 1 | |
26 #define DM_BLITFUNC_DST_BYTES 4 | |
27 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
28 #define DM_BLITFUNC_DST_TYPE Uint32 | |
0 | 29 |
85 | 30 #define DM_BLITFUNC_VARS const Uint32 *pal; |
31 #define DM_BLITFUNC_INIT \ | |
0 | 32 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
33 pal = (Uint32 *) src->format->palette->colors; | |
34 | |
85 | 35 #define DM_BLITFUNC_INNER *dp++ = pal[sp[FP_GETH(xv)]]; |
0 | 36 |
37 #include "dmscaledblit.h" | |
38 | |
39 // ----------------------------------------------------------------------- | |
40 | |
85 | 41 #define DM_BLITFUNC_NAME dmScaledBlitSurface32to32 |
42 #define DM_BLITFUNC_SRC_BYTES 4 | |
43 #define DM_BLITFUNC_DST_BYTES 4 | |
44 #define DM_BLITFUNC_SRC_TYPE Uint32 | |
45 #define DM_BLITFUNC_DST_TYPE Uint32 | |
46 #define DM_BLITFUNC_INIT | |
47 #define DM_BLITFUNC_INNER *dp++ = sp[FP_GETH(xv)]; | |
0 | 48 |
49 #include "dmscaledblit.h" | |
50 | |
51 | |
52 // ======================================================================= | |
53 // DMD_TRANSPARENT | |
54 // ======================================================================= | |
55 | |
85 | 56 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to8Transparent |
57 #define DM_BLITFUNC_SRC_BYTES 1 | |
58 #define DM_BLITFUNC_DST_BYTES 1 | |
59 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
60 #define DM_BLITFUNC_DST_TYPE Uint8 | |
0 | 61 |
85 | 62 #define DM_BLITFUNC_INNER \ |
0 | 63 *dp = sp[FP_GETH(xv)] ? sp[FP_GETH(xv)] : *dp; dp++; |
64 | |
65 #include "dmscaledblit.h" | |
66 | |
67 // ----------------------------------------------------------------------- | |
68 | |
85 | 69 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to32Transparent |
70 #define DM_BLITFUNC_SRC_BYTES 1 | |
71 #define DM_BLITFUNC_DST_BYTES 4 | |
72 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
73 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
74 #define DM_BLITFUNC_VARS const DMRGBA32 *pal; | |
75 #define DM_BLITFUNC_INIT \ | |
0 | 76 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
77 pal = (DMRGBA32 *) src->format->palette->colors; | |
78 | |
85 | 79 #define DM_BLITFUNC_INNER \ |
0 | 80 const DMRGBA32 q = pal[sp[FP_GETH(xv)]]; \ |
81 dp->r += ((q.r - dp->r) * q.a) >> 8; \ | |
82 dp->g += ((q.g - dp->g) * q.a) >> 8; \ | |
83 dp->b += ((q.b - dp->b) * q.a) >> 8; \ | |
84 dp->a = q.a; \ | |
85 dp++; | |
86 | |
87 #include "dmscaledblit.h" | |
88 | |
89 | |
90 // ----------------------------------------------------------------------- | |
91 | |
85 | 92 #define DM_BLITFUNC_NAME dmScaledBlitSurface32to32Transparent |
93 #define DM_BLITFUNC_SRC_BYTES 4 | |
94 #define DM_BLITFUNC_DST_BYTES 4 | |
0 | 95 |
96 #ifdef DM_USE_SIMD | |
85 | 97 #define DM_BLITFUNC_VARS \ |
21 | 98 const Uint32 qpdmask = 0xff000000; \ |
12
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
99 const Uint64 qpdrm = 0xff00ff00ff00ffULL; |
0 | 100 |
85 | 101 #define DM_BLITFUNC_SRC_TYPE Uint32 |
102 #define DM_BLITFUNC_DST_TYPE Uint32 | |
103 #define DM_BLITFUNC_INNER \ | |
0 | 104 asm( \ |
105 "movd %2, %%mm1\n" \ | |
12
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
106 \ |
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
107 "movd %3, %%mm2\n" \ |
13
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
108 "movq %%mm1, %%mm5\n" \ |
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
109 "pand %%mm2, %%mm5\n" \ |
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
110 "psrlw $8, %%mm5\n" \ |
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
111 "punpcklwd %%mm5, %%mm5\n" \ |
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
112 "punpckhwd %%mm5, %%mm5\n" \ |
0 | 113 \ |
13
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
114 "pxor %%mm2, %%mm2\n" \ |
0 | 115 "movd %1, %%mm3\n" \ |
116 "punpcklbw %%mm2, %%mm1\n" \ | |
13
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
117 "punpcklbw %%mm2, %%mm3\n" \ |
12
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
118 \ |
0 | 119 "psubw %%mm3, %%mm1\n" \ |
12
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
120 "pmullw %%mm5, %%mm1\n" \ |
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
121 "psraw $8, %%mm1\n" \ |
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
122 "paddw %%mm3, %%mm1\n" \ |
13
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
123 "pand %4, %%mm1\n" \ |
0 | 124 "packuswb %%mm2, %%mm1\n" \ |
125 "movd %%mm1, %0\n" \ | |
126 : "=m" (*dp) \ | |
12
35b0c83af3ca
MMX-version of scaled 32-bit RGBA alpha blending blit works now.
Matti Hamalainen <ccr@tnsp.org>
parents:
10
diff
changeset
|
127 : "m" (*dp), "m" (sp[FP_GETH(xv)]), "m" (qpdmask), "m" (qpdrm) \ |
17
a60fe802636a
Add register clobbers to SIMD inline asm.
Matti Hamalainen <ccr@tnsp.org>
parents:
14
diff
changeset
|
128 : "memory", "%mm1", "%mm2", "%mm3", "%mm4", "%mm5" ); dp++; |
0 | 129 |
85 | 130 #define DM_BLITFUNC_FINISH asm("emms\n"); |
13
07bace8425d9
Optimize the scaled RGBA alpha blit MMX version further.
Matti Hamalainen <ccr@tnsp.org>
parents:
12
diff
changeset
|
131 |
0 | 132 #else |
21 | 133 |
85 | 134 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 |
135 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
136 #define DM_BLITFUNC_INNER \ | |
0 | 137 const DMRGBA32 q = sp[FP_GETH(xv)]; \ |
138 dp->r += ((q.r - dp->r) * q.a) >> 8; \ | |
139 dp->g += ((q.g - dp->g) * q.a) >> 8; \ | |
140 dp->b += ((q.b - dp->b) * q.a) >> 8; \ | |
141 dp->a = q.a; \ | |
142 dp++; | |
143 #endif | |
144 | |
145 #include "dmscaledblit.h" | |
146 | |
147 // ----------------------------------------------------------------------- | |
148 | |
85 | 149 #define DM_BLITFUNC_NAME dmScaledBlitSurface32to32TransparentX |
150 #define DM_BLITFUNC_SRC_BYTES 4 | |
151 #define DM_BLITFUNC_DST_BYTES 4 | |
152 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 | |
153 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
154 #define DM_BLITFUNC_INIT | |
0 | 155 |
85 | 156 #define DM_BLITFUNC_INNER \ |
0 | 157 const DMRGBA32 q = sp[FP_GETH(xv)]; \ |
14
a40c266a71a2
Bitshift less in dmScaledBlitSurface32to32TransparentX()
Matti Hamalainen <ccr@tnsp.org>
parents:
13
diff
changeset
|
158 dp->r = (q.r * q.a + dp->r * dp->a) >> 8; \ |
a40c266a71a2
Bitshift less in dmScaledBlitSurface32to32TransparentX()
Matti Hamalainen <ccr@tnsp.org>
parents:
13
diff
changeset
|
159 dp->g = (q.g * q.a + dp->g * dp->a) >> 8; \ |
a40c266a71a2
Bitshift less in dmScaledBlitSurface32to32TransparentX()
Matti Hamalainen <ccr@tnsp.org>
parents:
13
diff
changeset
|
160 dp->b = (q.b * q.a + dp->b * dp->a) >> 8; \ |
0 | 161 dp->a = q.a ? q.a : dp->a; \ |
162 dp++; | |
163 | |
164 #include "dmscaledblit.h" | |
165 | |
166 | |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
167 // ----------------------------------------------------------------------- |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
168 |
85 | 169 #define DM_BLITFUNC_NAME dmScaledBlitSurface32to32TransparentGA |
170 #define DM_BLITFUNC_SRC_BYTES 4 | |
171 #define DM_BLITFUNC_DST_BYTES 4 | |
172 #define DM_BLITFUNC_ARGS , Uint32 alpha | |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
173 |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
174 #ifdef DM_USE_SIMD |
85 | 175 #define DM_BLITFUNC_VARS \ |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
176 const Uint64 qpdrm = 0xff00ff00ff00ffULL; |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
177 |
85 | 178 #define DM_BLITFUNC_SRC_TYPE Uint32 |
179 #define DM_BLITFUNC_DST_TYPE Uint32 | |
180 #define DM_BLITFUNC_INNER_INIT \ | |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
181 asm( \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
182 "movd %0, %%mm4\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
183 "punpcklwd %%mm4, %%mm4\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
184 "punpckldq %%mm4, %%mm4\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
185 : \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
186 : "m" (alpha) \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
187 : "%mm4" ); |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
188 |
85 | 189 #define DM_BLITFUNC_INNER \ |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
190 asm( \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
191 "movd %2, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
192 "pxor %%mm2, %%mm2\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
193 "movd %1, %%mm3\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
194 "punpcklbw %%mm2, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
195 "punpcklbw %%mm2, %%mm3\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
196 \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
197 "psubw %%mm3, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
198 "pmullw %%mm4, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
199 "psraw $8, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
200 "paddw %%mm3, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
201 "pand %3, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
202 "packuswb %%mm2, %%mm1\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
203 "movd %%mm1, %0\n" \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
204 : "=m" (*dp) \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
205 : "m" (*dp), "m" (sp[FP_GETH(xv)]), "m" (qpdrm) \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
206 : "memory", "%mm1", "%mm2", "%mm3", "%mm4" ); dp++; |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
207 |
85 | 208 #define DM_BLITFUNC_FINISH asm("emms\n"); |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
209 |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
210 #else |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
211 |
85 | 212 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 |
213 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
214 #define DM_BLITFUNC_INNER \ | |
18
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
215 const DMRGBA32 q = sp[FP_GETH(xv)]; \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
216 dp->r += ((q.r - dp->r) * alpha) >> 8; \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
217 dp->g += ((q.g - dp->g) * alpha) >> 8; \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
218 dp->b += ((q.b - dp->b) * alpha) >> 8; \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
219 dp->a = alpha; \ |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
220 dp++; |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
221 #endif |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
222 |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
223 #include "dmscaledblit.h" |
022eee2e7de6
Add dmScaledBlitSurface32to32TransparentGA().
Matti Hamalainen <ccr@tnsp.org>
parents:
17
diff
changeset
|
224 |
0 | 225 // ======================================================================= |
226 // DMD_SATURATE | |
227 // ======================================================================= | |
228 | |
85 | 229 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to8Saturate |
230 #define DM_BLITFUNC_SRC_BYTES 1 | |
231 #define DM_BLITFUNC_DST_BYTES 1 | |
232 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
233 #define DM_BLITFUNC_DST_TYPE Uint8 | |
234 #define DM_BLITFUNC_INNER \ | |
92 | 235 const int q = sp[FP_GETH(xv)] + *dp; \ |
81
ba1987562a73
Fix 8to8 saturated scaled blit function.
Matti Hamalainen <ccr@tnsp.org>
parents:
21
diff
changeset
|
236 *(dp++) = q < 256 ? q : 255; |
ba1987562a73
Fix 8to8 saturated scaled blit function.
Matti Hamalainen <ccr@tnsp.org>
parents:
21
diff
changeset
|
237 |
0 | 238 #include "dmscaledblit.h" |
239 | |
240 // ----------------------------------------------------------------------- | |
241 | |
85 | 242 #define DM_BLITFUNC_NAME dmScaledBlitSurface8to32Saturate |
243 #define DM_BLITFUNC_SRC_BYTES 1 | |
244 #define DM_BLITFUNC_DST_BYTES 4 | |
245 #define DM_BLITFUNC_SRC_TYPE Uint8 | |
246 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
247 #define DM_BLITFUNC_VARS const DMRGBA32 *pal; | |
248 #define DM_BLITFUNC_INIT \ | |
0 | 249 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
250 pal = (DMRGBA32 *) src->format->palette->colors; | |
251 | |
252 #ifdef DM_USE_SIMD | |
85 | 253 #define DM_BLITFUNC_INNER \ |
0 | 254 asm("movd %2, %%mm1\n" \ |
255 "movd %1, %%mm2\n" \ | |
256 "paddusb %%mm2, %%mm1\n" \ | |
257 "movd %%mm1, %0\n" \ | |
258 : "=m" (*dp) \ | |
259 : "m" (*dp), "m" (pal[sp[FP_GETH(xv)]]) \ | |
17
a60fe802636a
Add register clobbers to SIMD inline asm.
Matti Hamalainen <ccr@tnsp.org>
parents:
14
diff
changeset
|
260 : "memory", "%mm1", "%mm2" ); dp++; |
0 | 261 |
85 | 262 #define DM_BLITFUNC_FINISH asm("emms\n"); |
0 | 263 #else |
85 | 264 #define DM_BLITFUNC_INNER \ |
0 | 265 const DMRGBA32 q = pal[sp[FP_GETH(xv)]]; \ |
266 const int qr = dp->r + q.r, qg = dp->g + q.g, qb = dp->b + q.b; \ | |
267 dp->r = qr < 256 ? qr : 255; \ | |
268 dp->g = qg < 256 ? qg : 255; \ | |
269 dp->b = qb < 256 ? qb : 255; \ | |
270 dp->a = q.a; \ | |
271 dp++; | |
272 #endif | |
273 | |
274 #include "dmscaledblit.h" | |
275 | |
276 // ----------------------------------------------------------------------- | |
277 | |
85 | 278 #define DM_BLITFUNC_NAME dmScaledBlitSurface32to32Saturate |
279 #define DM_BLITFUNC_SRC_BYTES 4 | |
280 #define DM_BLITFUNC_DST_BYTES 4 | |
281 #define DM_BLITFUNC_INIT | |
0 | 282 |
283 #ifdef DM_USE_SIMD | |
85 | 284 #define DM_BLITFUNC_SRC_TYPE Uint32 |
285 #define DM_BLITFUNC_DST_TYPE Uint32 | |
286 #define DM_BLITFUNC_INNER \ | |
0 | 287 asm("movd %2, %%mm1\n" \ |
288 "movd %1, %%mm2\n" \ | |
289 "paddusb %%mm2, %%mm1\n" \ | |
290 "movd %%mm1, %0\n" \ | |
291 : "=m" (*dp) \ | |
292 : "m" (*dp), "m" (sp[FP_GETH(xv)]) \ | |
17
a60fe802636a
Add register clobbers to SIMD inline asm.
Matti Hamalainen <ccr@tnsp.org>
parents:
14
diff
changeset
|
293 : "memory", "%mm1", "%mm2" ); dp++; |
0 | 294 |
85 | 295 #define DM_BLITFUNC_FINISH asm("emms\n"); |
0 | 296 #else |
85 | 297 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 |
298 #define DM_BLITFUNC_DST_TYPE DMRGBA32 | |
299 #define DM_BLITFUNC_INNER \ | |
0 | 300 const DMRGBA32 q = sp[FP_GETH(xv)]; \ |
301 const int qr = dp->r + q.r, qg = dp->g + q.g, qb = dp->b + q.b; \ | |
302 dp->r = qr < 256 ? qr : 255; \ | |
303 dp->g = qg < 256 ? qg : 255; \ | |
304 dp->b = qb < 256 ? qb : 255; \ | |
305 dp->a = q.a; \ | |
306 dp++; | |
307 #endif | |
308 | |
309 #include "dmscaledblit.h" | |
310 | |
311 | |
95
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
312 |
0 | 313 // ======================================================================= |
314 // ======================================================================= | |
95
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
315 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
316 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
317 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
318 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
319 // DMD_NONE |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
320 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
321 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
322 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
323 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
324 #define DM_BLITFUNC_DST_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
325 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
326 #define DM_BLITFUNC_DST_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
327 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
328 #define DM_BLITFUNC_INNER *dp++ = sp[xv]; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
329 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
330 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
331 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
332 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
333 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
334 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
335 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
336 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
337 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
338 #define DM_BLITFUNC_DST_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
339 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
340 #define DM_BLITFUNC_VARS const Uint32 *pal; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
341 #define DM_BLITFUNC_INIT \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
342 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
343 pal = (Uint32 *) src->format->palette->colors; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
344 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
345 #define DM_BLITFUNC_INNER *dp++ = pal[sp[xv]]; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
346 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
347 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
348 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
349 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
350 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
351 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface32to32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
352 #define DM_BLITFUNC_SRC_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
353 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
354 #define DM_BLITFUNC_SRC_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
355 #define DM_BLITFUNC_DST_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
356 #define DM_BLITFUNC_INIT |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
357 #define DM_BLITFUNC_INNER *dp++ = sp[xv]; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
358 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
359 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
360 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
361 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
362 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
363 // DMD_TRANSPARENT |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
364 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
365 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
366 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to8Transparent |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
367 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
368 #define DM_BLITFUNC_DST_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
369 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
370 #define DM_BLITFUNC_DST_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
371 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
372 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
373 *dp = sp[xv] ? sp[xv] : *dp; dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
374 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
375 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
376 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
377 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
378 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
379 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to32Transparent |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
380 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
381 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
382 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
383 #define DM_BLITFUNC_DST_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
384 #define DM_BLITFUNC_VARS const DMRGBA32 *pal; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
385 #define DM_BLITFUNC_INIT \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
386 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
387 pal = (DMRGBA32 *) src->format->palette->colors; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
388 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
389 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
390 const DMRGBA32 q = pal[sp[xv]]; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
391 dp->r += ((q.r - dp->r) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
392 dp->g += ((q.g - dp->g) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
393 dp->b += ((q.b - dp->b) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
394 dp->a = q.a; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
395 dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
396 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
397 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
398 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
399 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
400 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
401 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
402 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface32to32Transparent |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
403 #define DM_BLITFUNC_SRC_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
404 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
405 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
406 #ifdef DM_USE_SIMD |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
407 #define DM_BLITFUNC_VARS \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
408 const Uint32 qpdmask = 0xff000000; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
409 const Uint64 qpdrm = 0xff00ff00ff00ffULL; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
410 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
411 #define DM_BLITFUNC_SRC_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
412 #define DM_BLITFUNC_DST_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
413 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
414 asm( \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
415 "movd %2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
416 \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
417 "movd %3, %%mm2\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
418 "movq %%mm1, %%mm5\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
419 "pand %%mm2, %%mm5\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
420 "psrlw $8, %%mm5\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
421 "punpcklwd %%mm5, %%mm5\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
422 "punpckhwd %%mm5, %%mm5\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
423 \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
424 "pxor %%mm2, %%mm2\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
425 "movd %1, %%mm3\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
426 "punpcklbw %%mm2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
427 "punpcklbw %%mm2, %%mm3\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
428 \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
429 "psubw %%mm3, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
430 "pmullw %%mm5, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
431 "psraw $8, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
432 "paddw %%mm3, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
433 "pand %4, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
434 "packuswb %%mm2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
435 "movd %%mm1, %0\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
436 : "=m" (*dp) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
437 : "m" (*dp), "m" (sp[xv]), "m" (qpdmask), "m" (qpdrm) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
438 : "memory", "%mm1", "%mm2", "%mm3", "%mm4", "%mm5" ); dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
439 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
440 #define DM_BLITFUNC_FINISH asm("emms\n"); |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
441 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
442 #else |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
443 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
444 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
445 #define DM_BLITFUNC_DST_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
446 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
447 const DMRGBA32 q = sp[xv]; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
448 dp->r += ((q.r - dp->r) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
449 dp->g += ((q.g - dp->g) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
450 dp->b += ((q.b - dp->b) * q.a) >> 8; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
451 dp->a = q.a; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
452 dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
453 #endif |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
454 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
455 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
456 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
457 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
458 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
459 // DMD_SATURATE |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
460 // ======================================================================= |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
461 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
462 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to8Saturate |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
463 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
464 #define DM_BLITFUNC_DST_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
465 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
466 #define DM_BLITFUNC_DST_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
467 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
468 const int q = sp[xv] + *dp; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
469 *(dp++) = q < 256 ? q : 255; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
470 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
471 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
472 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
473 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
474 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
475 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface8to32Saturate |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
476 #define DM_BLITFUNC_SRC_BYTES 1 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
477 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
478 #define DM_BLITFUNC_SRC_TYPE Uint8 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
479 #define DM_BLITFUNC_DST_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
480 #define DM_BLITFUNC_VARS const DMRGBA32 *pal; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
481 #define DM_BLITFUNC_INIT \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
482 if (src->format->palette == NULL || src->format->palette->ncolors < 256) return -2; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
483 pal = (DMRGBA32 *) src->format->palette->colors; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
484 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
485 #ifdef DM_USE_SIMD |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
486 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
487 asm("movd %2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
488 "movd %1, %%mm2\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
489 "paddusb %%mm2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
490 "movd %%mm1, %0\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
491 : "=m" (*dp) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
492 : "m" (*dp), "m" (pal[sp[xv]]) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
493 : "memory", "%mm1", "%mm2" ); dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
494 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
495 #define DM_BLITFUNC_FINISH asm("emms\n"); |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
496 #else |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
497 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
498 const DMRGBA32 q = pal[sp[xv]]; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
499 const int qr = dp->r + q.r, qg = dp->g + q.g, qb = dp->b + q.b; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
500 dp->r = qr < 256 ? qr : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
501 dp->g = qg < 256 ? qg : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
502 dp->b = qb < 256 ? qb : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
503 dp->a = q.a; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
504 dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
505 #endif |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
506 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
507 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
508 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
509 // ----------------------------------------------------------------------- |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
510 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
511 #define DM_BLITFUNC_NAME dmUnscaledBlitSurface32to32Saturate |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
512 #define DM_BLITFUNC_SRC_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
513 #define DM_BLITFUNC_DST_BYTES 4 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
514 #define DM_BLITFUNC_INIT |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
515 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
516 #ifdef DM_USE_SIMD |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
517 #define DM_BLITFUNC_SRC_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
518 #define DM_BLITFUNC_DST_TYPE Uint32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
519 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
520 asm("movd %2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
521 "movd %1, %%mm2\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
522 "paddusb %%mm2, %%mm1\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
523 "movd %%mm1, %0\n" \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
524 : "=m" (*dp) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
525 : "m" (*dp), "m" (sp[xv]) \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
526 : "memory", "%mm1", "%mm2" ); dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
527 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
528 #define DM_BLITFUNC_FINISH asm("emms\n"); |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
529 #else |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
530 #define DM_BLITFUNC_SRC_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
531 #define DM_BLITFUNC_DST_TYPE DMRGBA32 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
532 #define DM_BLITFUNC_INNER \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
533 const DMRGBA32 q = sp[xv]; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
534 const int qr = dp->r + q.r, qg = dp->g + q.g, qb = dp->b + q.b; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
535 dp->r = qr < 256 ? qr : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
536 dp->g = qg < 256 ? qg : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
537 dp->b = qb < 256 ? qb : 255; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
538 dp->a = q.a; \ |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
539 dp++; |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
540 #endif |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
541 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
542 #include "dmunscaledblit.h" |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
543 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
544 |
0430f484641b
Add unscaled blitting functions.
Matti Hamalainen <ccr@tnsp.org>
parents:
92
diff
changeset
|
545 // ======================================================================= |