1 /*
2 * SIMD-optimized pixel operations
3 *
4 * This file is part of FFmpeg.
5 *
6 * FFmpeg is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
10 *
11 * FFmpeg is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with FFmpeg; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
24
26 const uint8_t *restrict pixels, ptrdiff_t
stride)
27 {
29
30 do {
31 uint64_t p;
32
36
40 }
41
44 {
46 uint64_t
mask = 0x4040;
47
50 do {
51 uint64_t x, y,
c,
d,
a;
52 uint64_t signs;
53
58 a =
zap(
mask,
c);
/* We use 0x4040404040404040 here... */
59 d += 4 *
a;
/* ...so we can use s4addq here. */
61
64
69 }
70
72 unsigned high_bit_depth)
73 {
75 if (!high_bit_depth)
78 }
79 }