Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
1 /*
2 * Copyright © 2010 Nokia Corporation
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
13 * Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
22 *
23 * Author: Siarhei Siamashka (siarhei.siamashka@nokia.com)
24 */
26 #ifndef PIXMAN_ARM_COMMON_H
27 #define PIXMAN_ARM_COMMON_H
29 #include "pixman-inlines.h"
31 /* Define some macros which can expand into proxy functions between
32 * ARM assembly optimized functions and the rest of pixman fast path API.
33 *
34 * All the low level ARM assembly functions have to use ARM EABI
35 * calling convention and take up to 8 arguments:
36 * width, height, dst, dst_stride, src, src_stride, mask, mask_stride
37 *
38 * The arguments are ordered with the most important coming first (the
39 * first 4 arguments are passed to function in registers, the rest are
40 * on stack). The last arguments are optional, for example if the
41 * function is not using mask, then 'mask' and 'mask_stride' can be
42 * omitted when doing a function call.
43 *
44 * Arguments 'src' and 'mask' contain either a pointer to the top left
45 * pixel of the composited rectangle or a pixel color value depending
46 * on the function type. In the case of just a color value (solid source
47 * or mask), the corresponding stride argument is unused.
48 */
50 #define SKIP_ZERO_SRC 1
51 #define SKIP_ZERO_MASK 2
53 #define PIXMAN_ARM_BIND_FAST_PATH_SRC_DST(cputype, name, \
54 src_type, src_cnt, \
55 dst_type, dst_cnt) \
56 void \
57 pixman_composite_##name##_asm_##cputype (int32_t w, \
58 int32_t h, \
59 dst_type *dst, \
60 int32_t dst_stride, \
61 src_type *src, \
62 int32_t src_stride); \
63 \
64 static void \
65 cputype##_composite_##name (pixman_implementation_t *imp, \
66 pixman_composite_info_t *info) \
67 { \
68 PIXMAN_COMPOSITE_ARGS (info); \
69 dst_type *dst_line; \
70 src_type *src_line; \
71 int32_t dst_stride, src_stride; \
72 \
73 PIXMAN_IMAGE_GET_LINE (src_image, src_x, src_y, src_type, \
74 src_stride, src_line, src_cnt); \
75 PIXMAN_IMAGE_GET_LINE (dest_image, dest_x, dest_y, dst_type, \
76 dst_stride, dst_line, dst_cnt); \
77 \
78 pixman_composite_##name##_asm_##cputype (width, height, \
79 dst_line, dst_stride, \
80 src_line, src_stride); \
81 }
83 #define PIXMAN_ARM_BIND_FAST_PATH_N_DST(flags, cputype, name, \
84 dst_type, dst_cnt) \
85 void \
86 pixman_composite_##name##_asm_##cputype (int32_t w, \
87 int32_t h, \
88 dst_type *dst, \
89 int32_t dst_stride, \
90 uint32_t src); \
91 \
92 static void \
93 cputype##_composite_##name (pixman_implementation_t *imp, \
94 pixman_composite_info_t *info) \
95 { \
96 PIXMAN_COMPOSITE_ARGS (info); \
97 dst_type *dst_line; \
98 int32_t dst_stride; \
99 uint32_t src; \
100 \
101 src = _pixman_image_get_solid ( \
102 imp, src_image, dest_image->bits.format); \
103 \
104 if ((flags & SKIP_ZERO_SRC) && src == 0) \
105 return; \
106 \
107 PIXMAN_IMAGE_GET_LINE (dest_image, dest_x, dest_y, dst_type, \
108 dst_stride, dst_line, dst_cnt); \
109 \
110 pixman_composite_##name##_asm_##cputype (width, height, \
111 dst_line, dst_stride, \
112 src); \
113 }
115 #define PIXMAN_ARM_BIND_FAST_PATH_N_MASK_DST(flags, cputype, name, \
116 mask_type, mask_cnt, \
117 dst_type, dst_cnt) \
118 void \
119 pixman_composite_##name##_asm_##cputype (int32_t w, \
120 int32_t h, \
121 dst_type *dst, \
122 int32_t dst_stride, \
123 uint32_t src, \
124 int32_t unused, \
125 mask_type *mask, \
126 int32_t mask_stride); \
127 \
128 static void \
129 cputype##_composite_##name (pixman_implementation_t *imp, \
130 pixman_composite_info_t *info) \
131 { \
132 PIXMAN_COMPOSITE_ARGS (info); \
133 dst_type *dst_line; \
134 mask_type *mask_line; \
135 int32_t dst_stride, mask_stride; \
136 uint32_t src; \
137 \
138 src = _pixman_image_get_solid ( \
139 imp, src_image, dest_image->bits.format); \
140 \
141 if ((flags & SKIP_ZERO_SRC) && src == 0) \
142 return; \
143 \
144 PIXMAN_IMAGE_GET_LINE (dest_image, dest_x, dest_y, dst_type, \
145 dst_stride, dst_line, dst_cnt); \
146 PIXMAN_IMAGE_GET_LINE (mask_image, mask_x, mask_y, mask_type, \
147 mask_stride, mask_line, mask_cnt); \
148 \
149 pixman_composite_##name##_asm_##cputype (width, height, \
150 dst_line, dst_stride, \
151 src, 0, \
152 mask_line, mask_stride); \
153 }
155 #define PIXMAN_ARM_BIND_FAST_PATH_SRC_N_DST(flags, cputype, name, \
156 src_type, src_cnt, \
157 dst_type, dst_cnt) \
158 void \
159 pixman_composite_##name##_asm_##cputype (int32_t w, \
160 int32_t h, \
161 dst_type *dst, \
162 int32_t dst_stride, \
163 src_type *src, \
164 int32_t src_stride, \
165 uint32_t mask); \
166 \
167 static void \
168 cputype##_composite_##name (pixman_implementation_t *imp, \
169 pixman_composite_info_t *info) \
170 { \
171 PIXMAN_COMPOSITE_ARGS (info); \
172 dst_type *dst_line; \
173 src_type *src_line; \
174 int32_t dst_stride, src_stride; \
175 uint32_t mask; \
176 \
177 mask = _pixman_image_get_solid ( \
178 imp, mask_image, dest_image->bits.format); \
179 \
180 if ((flags & SKIP_ZERO_MASK) && mask == 0) \
181 return; \
182 \
183 PIXMAN_IMAGE_GET_LINE (dest_image, dest_x, dest_y, dst_type, \
184 dst_stride, dst_line, dst_cnt); \
185 PIXMAN_IMAGE_GET_LINE (src_image, src_x, src_y, src_type, \
186 src_stride, src_line, src_cnt); \
187 \
188 pixman_composite_##name##_asm_##cputype (width, height, \
189 dst_line, dst_stride, \
190 src_line, src_stride, \
191 mask); \
192 }
194 #define PIXMAN_ARM_BIND_FAST_PATH_SRC_MASK_DST(cputype, name, \
195 src_type, src_cnt, \
196 mask_type, mask_cnt, \
197 dst_type, dst_cnt) \
198 void \
199 pixman_composite_##name##_asm_##cputype (int32_t w, \
200 int32_t h, \
201 dst_type *dst, \
202 int32_t dst_stride, \
203 src_type *src, \
204 int32_t src_stride, \
205 mask_type *mask, \
206 int32_t mask_stride); \
207 \
208 static void \
209 cputype##_composite_##name (pixman_implementation_t *imp, \
210 pixman_composite_info_t *info) \
211 { \
212 PIXMAN_COMPOSITE_ARGS (info); \
213 dst_type *dst_line; \
214 src_type *src_line; \
215 mask_type *mask_line; \
216 int32_t dst_stride, src_stride, mask_stride; \
217 \
218 PIXMAN_IMAGE_GET_LINE (dest_image, dest_x, dest_y, dst_type, \
219 dst_stride, dst_line, dst_cnt); \
220 PIXMAN_IMAGE_GET_LINE (src_image, src_x, src_y, src_type, \
221 src_stride, src_line, src_cnt); \
222 PIXMAN_IMAGE_GET_LINE (mask_image, mask_x, mask_y, mask_type, \
223 mask_stride, mask_line, mask_cnt); \
224 \
225 pixman_composite_##name##_asm_##cputype (width, height, \
226 dst_line, dst_stride, \
227 src_line, src_stride, \
228 mask_line, mask_stride); \
229 }
231 #define PIXMAN_ARM_BIND_SCALED_NEAREST_SRC_DST(cputype, name, op, \
232 src_type, dst_type) \
233 void \
234 pixman_scaled_nearest_scanline_##name##_##op##_asm_##cputype ( \
235 int32_t w, \
236 dst_type * dst, \
237 const src_type * src, \
238 pixman_fixed_t vx, \
239 pixman_fixed_t unit_x, \
240 pixman_fixed_t max_vx); \
241 \
242 static force_inline void \
243 scaled_nearest_scanline_##cputype##_##name##_##op (dst_type * pd, \
244 const src_type * ps, \
245 int32_t w, \
246 pixman_fixed_t vx, \
247 pixman_fixed_t unit_x, \
248 pixman_fixed_t max_vx, \
249 pixman_bool_t zero_src) \
250 { \
251 pixman_scaled_nearest_scanline_##name##_##op##_asm_##cputype (w, pd, ps, \
252 vx, unit_x, \
253 max_vx); \
254 } \
255 \
256 FAST_NEAREST_MAINLOOP (cputype##_##name##_cover_##op, \
257 scaled_nearest_scanline_##cputype##_##name##_##op, \
258 src_type, dst_type, COVER) \
259 FAST_NEAREST_MAINLOOP (cputype##_##name##_none_##op, \
260 scaled_nearest_scanline_##cputype##_##name##_##op, \
261 src_type, dst_type, NONE) \
262 FAST_NEAREST_MAINLOOP (cputype##_##name##_pad_##op, \
263 scaled_nearest_scanline_##cputype##_##name##_##op, \
264 src_type, dst_type, PAD) \
265 FAST_NEAREST_MAINLOOP (cputype##_##name##_normal_##op, \
266 scaled_nearest_scanline_##cputype##_##name##_##op, \
267 src_type, dst_type, NORMAL)
269 /* Provide entries for the fast path table */
270 #define PIXMAN_ARM_SIMPLE_NEAREST_FAST_PATH(op,s,d,func) \
271 SIMPLE_NEAREST_FAST_PATH_COVER (op,s,d,func), \
272 SIMPLE_NEAREST_FAST_PATH_NONE (op,s,d,func), \
273 SIMPLE_NEAREST_FAST_PATH_PAD (op,s,d,func), \
274 SIMPLE_NEAREST_FAST_PATH_NORMAL (op,s,d,func)
276 #define PIXMAN_ARM_BIND_SCALED_NEAREST_SRC_A8_DST(flags, cputype, name, op, \
277 src_type, dst_type) \
278 void \
279 pixman_scaled_nearest_scanline_##name##_##op##_asm_##cputype ( \
280 int32_t w, \
281 dst_type * dst, \
282 const src_type * src, \
283 pixman_fixed_t vx, \
284 pixman_fixed_t unit_x, \
285 pixman_fixed_t max_vx, \
286 const uint8_t * mask); \
287 \
288 static force_inline void \
289 scaled_nearest_scanline_##cputype##_##name##_##op (const uint8_t * mask, \
290 dst_type * pd, \
291 const src_type * ps, \
292 int32_t w, \
293 pixman_fixed_t vx, \
294 pixman_fixed_t unit_x, \
295 pixman_fixed_t max_vx, \
296 pixman_bool_t zero_src) \
297 { \
298 if ((flags & SKIP_ZERO_SRC) && zero_src) \
299 return; \
300 pixman_scaled_nearest_scanline_##name##_##op##_asm_##cputype (w, pd, ps, \
301 vx, unit_x, \
302 max_vx, \
303 mask); \
304 } \
305 \
306 FAST_NEAREST_MAINLOOP_COMMON (cputype##_##name##_cover_##op, \
307 scaled_nearest_scanline_##cputype##_##name##_##op,\
308 src_type, uint8_t, dst_type, COVER, TRUE, FALSE)\
309 FAST_NEAREST_MAINLOOP_COMMON (cputype##_##name##_none_##op, \
310 scaled_nearest_scanline_##cputype##_##name##_##op,\
311 src_type, uint8_t, dst_type, NONE, TRUE, FALSE) \
312 FAST_NEAREST_MAINLOOP_COMMON (cputype##_##name##_pad_##op, \
313 scaled_nearest_scanline_##cputype##_##name##_##op,\
314 src_type, uint8_t, dst_type, PAD, TRUE, FALSE) \
315 FAST_NEAREST_MAINLOOP_COMMON (cputype##_##name##_normal_##op, \
316 scaled_nearest_scanline_##cputype##_##name##_##op,\
317 src_type, uint8_t, dst_type, NORMAL, TRUE, FALSE)
319 /* Provide entries for the fast path table */
320 #define PIXMAN_ARM_SIMPLE_NEAREST_A8_MASK_FAST_PATH(op,s,d,func) \
321 SIMPLE_NEAREST_A8_MASK_FAST_PATH_COVER (op,s,d,func), \
322 SIMPLE_NEAREST_A8_MASK_FAST_PATH_NONE (op,s,d,func), \
323 SIMPLE_NEAREST_A8_MASK_FAST_PATH_PAD (op,s,d,func), \
324 SIMPLE_NEAREST_A8_MASK_FAST_PATH_NORMAL (op,s,d,func)
326 /*****************************************************************************/
328 #define PIXMAN_ARM_BIND_SCALED_BILINEAR_SRC_DST(flags, cputype, name, op, \
329 src_type, dst_type) \
330 void \
331 pixman_scaled_bilinear_scanline_##name##_##op##_asm_##cputype ( \
332 dst_type * dst, \
333 const src_type * top, \
334 const src_type * bottom, \
335 int wt, \
336 int wb, \
337 pixman_fixed_t x, \
338 pixman_fixed_t ux, \
339 int width); \
340 \
341 static force_inline void \
342 scaled_bilinear_scanline_##cputype##_##name##_##op ( \
343 dst_type * dst, \
344 const uint32_t * mask, \
345 const src_type * src_top, \
346 const src_type * src_bottom, \
347 int32_t w, \
348 int wt, \
349 int wb, \
350 pixman_fixed_t vx, \
351 pixman_fixed_t unit_x, \
352 pixman_fixed_t max_vx, \
353 pixman_bool_t zero_src) \
354 { \
355 if ((flags & SKIP_ZERO_SRC) && zero_src) \
356 return; \
357 pixman_scaled_bilinear_scanline_##name##_##op##_asm_##cputype ( \
358 dst, src_top, src_bottom, wt, wb, vx, unit_x, w); \
359 } \
360 \
361 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_cover_##op, \
362 scaled_bilinear_scanline_##cputype##_##name##_##op, \
363 NULL, src_type, uint32_t, dst_type, COVER, FLAG_NONE) \
364 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_none_##op, \
365 scaled_bilinear_scanline_##cputype##_##name##_##op, \
366 NULL, src_type, uint32_t, dst_type, NONE, FLAG_NONE) \
367 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_pad_##op, \
368 scaled_bilinear_scanline_##cputype##_##name##_##op, \
369 NULL, src_type, uint32_t, dst_type, PAD, FLAG_NONE) \
370 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_normal_##op, \
371 scaled_bilinear_scanline_##cputype##_##name##_##op, \
372 NULL, src_type, uint32_t, dst_type, NORMAL, \
373 FLAG_NONE)
376 #define PIXMAN_ARM_BIND_SCALED_BILINEAR_SRC_A8_DST(flags, cputype, name, op, \
377 src_type, dst_type) \
378 void \
379 pixman_scaled_bilinear_scanline_##name##_##op##_asm_##cputype ( \
380 dst_type * dst, \
381 const uint8_t * mask, \
382 const src_type * top, \
383 const src_type * bottom, \
384 int wt, \
385 int wb, \
386 pixman_fixed_t x, \
387 pixman_fixed_t ux, \
388 int width); \
389 \
390 static force_inline void \
391 scaled_bilinear_scanline_##cputype##_##name##_##op ( \
392 dst_type * dst, \
393 const uint8_t * mask, \
394 const src_type * src_top, \
395 const src_type * src_bottom, \
396 int32_t w, \
397 int wt, \
398 int wb, \
399 pixman_fixed_t vx, \
400 pixman_fixed_t unit_x, \
401 pixman_fixed_t max_vx, \
402 pixman_bool_t zero_src) \
403 { \
404 if ((flags & SKIP_ZERO_SRC) && zero_src) \
405 return; \
406 pixman_scaled_bilinear_scanline_##name##_##op##_asm_##cputype ( \
407 dst, mask, src_top, src_bottom, wt, wb, vx, unit_x, w); \
408 } \
409 \
410 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_cover_##op, \
411 scaled_bilinear_scanline_##cputype##_##name##_##op, \
412 NULL, src_type, uint8_t, dst_type, COVER, \
413 FLAG_HAVE_NON_SOLID_MASK) \
414 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_none_##op, \
415 scaled_bilinear_scanline_##cputype##_##name##_##op, \
416 NULL, src_type, uint8_t, dst_type, NONE, \
417 FLAG_HAVE_NON_SOLID_MASK) \
418 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_pad_##op, \
419 scaled_bilinear_scanline_##cputype##_##name##_##op, \
420 NULL, src_type, uint8_t, dst_type, PAD, \
421 FLAG_HAVE_NON_SOLID_MASK) \
422 FAST_BILINEAR_MAINLOOP_COMMON (cputype##_##name##_normal_##op, \
423 scaled_bilinear_scanline_##cputype##_##name##_##op, \
424 NULL, src_type, uint8_t, dst_type, NORMAL, \
425 FLAG_HAVE_NON_SOLID_MASK)
428 #endif