Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(415)

Side by Side Diff: source/rotate_any.cc

Issue 2617703002: Add MSA optimized rotate functions (used 16x16 transpose) (Closed)
Patch Set: correct file mode Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « source/rotate.cc ('k') | source/rotate_msa.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2015 The LibYuv Project Authors. All rights reserved. 2 * Copyright 2015 The LibYuv Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 23 matching lines...) Expand all
34 #endif 34 #endif
35 #ifdef HAS_TRANSPOSEWX8_SSSE3 35 #ifdef HAS_TRANSPOSEWX8_SSSE3
36 TANY(TransposeWx8_Any_SSSE3, TransposeWx8_SSSE3, 7) 36 TANY(TransposeWx8_Any_SSSE3, TransposeWx8_SSSE3, 7)
37 #endif 37 #endif
38 #ifdef HAS_TRANSPOSEWX8_FAST_SSSE3 38 #ifdef HAS_TRANSPOSEWX8_FAST_SSSE3
39 TANY(TransposeWx8_Fast_Any_SSSE3, TransposeWx8_Fast_SSSE3, 15) 39 TANY(TransposeWx8_Fast_Any_SSSE3, TransposeWx8_Fast_SSSE3, 15)
40 #endif 40 #endif
41 #ifdef HAS_TRANSPOSEWX8_DSPR2 41 #ifdef HAS_TRANSPOSEWX8_DSPR2
42 TANY(TransposeWx8_Any_DSPR2, TransposeWx8_DSPR2, 7) 42 TANY(TransposeWx8_Any_DSPR2, TransposeWx8_DSPR2, 7)
43 #endif 43 #endif
44 #ifdef HAS_TRANSPOSEWX8_MSA 44 #ifdef HAS_TRANSPOSEWX16_MSA
45 TANY(TransposeWx8_Any_MSA, TransposeWx8_MSA, 15) 45 TANY(TransposeWx16_Any_MSA, TransposeWx16_MSA, 15)
46 #endif 46 #endif
47 #undef TANY 47 #undef TANY
48 48
49 #define TUVANY(NAMEANY, TPOS_SIMD, MASK) \ 49 #define TUVANY(NAMEANY, TPOS_SIMD, MASK) \
50 void NAMEANY(const uint8* src, int src_stride, uint8* dst_a, \ 50 void NAMEANY(const uint8* src, int src_stride, uint8* dst_a, \
51 int dst_stride_a, uint8* dst_b, int dst_stride_b, int width) { \ 51 int dst_stride_a, uint8* dst_b, int dst_stride_b, int width) { \
52 int r = width & MASK; \ 52 int r = width & MASK; \
53 int n = width - r; \ 53 int n = width - r; \
54 if (n > 0) { \ 54 if (n > 0) { \
55 TPOS_SIMD(src, src_stride, dst_a, dst_stride_a, dst_b, dst_stride_b, n); \ 55 TPOS_SIMD(src, src_stride, dst_a, dst_stride_a, dst_b, dst_stride_b, n); \
56 } \ 56 } \
57 TransposeUVWx8_C(src + n * 2, src_stride, dst_a + n * dst_stride_a, \ 57 TransposeUVWx8_C(src + n * 2, src_stride, dst_a + n * dst_stride_a, \
58 dst_stride_a, dst_b + n * dst_stride_b, dst_stride_b, r); \ 58 dst_stride_a, dst_b + n * dst_stride_b, dst_stride_b, r); \
59 } 59 }
60 60
61 #ifdef HAS_TRANSPOSEUVWX8_NEON 61 #ifdef HAS_TRANSPOSEUVWX8_NEON
62 TUVANY(TransposeUVWx8_Any_NEON, TransposeUVWx8_NEON, 7) 62 TUVANY(TransposeUVWx8_Any_NEON, TransposeUVWx8_NEON, 7)
63 #endif 63 #endif
64 #ifdef HAS_TRANSPOSEUVWX8_SSE2 64 #ifdef HAS_TRANSPOSEUVWX8_SSE2
65 TUVANY(TransposeUVWx8_Any_SSE2, TransposeUVWx8_SSE2, 7) 65 TUVANY(TransposeUVWx8_Any_SSE2, TransposeUVWx8_SSE2, 7)
66 #endif 66 #endif
67 #ifdef HAS_TRANSPOSEUVWX8_DSPR2 67 #ifdef HAS_TRANSPOSEUVWX8_DSPR2
68 TUVANY(TransposeUVWx8_Any_DSPR2, TransposeUVWx8_DSPR2, 7) 68 TUVANY(TransposeUVWx8_Any_DSPR2, TransposeUVWx8_DSPR2, 7)
69 #endif 69 #endif
70 #ifdef HAS_TRANSPOSEUVWX8_MSA 70 #ifdef HAS_TRANSPOSEUVWX16_MSA
71 TUVANY(TransposeUVWx8_Any_MSA, TransposeUVWx8_MSA, 7) 71 TUVANY(TransposeUVWx16_Any_MSA, TransposeUVWx16_MSA, 7)
72 #endif 72 #endif
73 #undef TUVANY 73 #undef TUVANY
74 74
75 #ifdef __cplusplus 75 #ifdef __cplusplus
76 } // extern "C" 76 } // extern "C"
77 } // namespace libyuv 77 } // namespace libyuv
78 #endif 78 #endif
OLDNEW
« no previous file with comments | « source/rotate.cc ('k') | source/rotate_msa.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698