2015-07-24 16:54:51 -07:00
|
|
|
/*
|
|
|
|
* Copyright 2015 The LibYuv Project Authors. All rights reserved.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "libyuv/rotate.h"
|
|
|
|
#include "libyuv/rotate_row.h"
|
|
|
|
|
|
|
|
#include "libyuv/basic_types.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
namespace libyuv {
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-08-25 06:39:38 -07:00
|
|
|
#define TANY(NAMEANY, TPOS_SIMD, MASK) \
|
2015-07-24 16:54:51 -07:00
|
|
|
void NAMEANY(const uint8* src, int src_stride, \
|
|
|
|
uint8* dst, int dst_stride, int width) { \
|
|
|
|
int r = width & MASK; \
|
|
|
|
int n = width - r; \
|
|
|
|
if (n > 0) { \
|
|
|
|
TPOS_SIMD(src, src_stride, dst, dst_stride, n); \
|
|
|
|
} \
|
2016-08-25 06:39:38 -07:00
|
|
|
TransposeWx8_C(src + n, src_stride, dst + n * dst_stride, dst_stride, r);\
|
2015-07-24 16:54:51 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef HAS_TRANSPOSEWX8_NEON
|
2016-08-25 06:39:38 -07:00
|
|
|
TANY(TransposeWx8_Any_NEON, TransposeWx8_NEON, 7)
|
2015-07-24 16:54:51 -07:00
|
|
|
#endif
|
|
|
|
#ifdef HAS_TRANSPOSEWX8_SSSE3
|
2016-08-25 06:39:38 -07:00
|
|
|
TANY(TransposeWx8_Any_SSSE3, TransposeWx8_SSSE3, 7)
|
2015-07-24 16:54:51 -07:00
|
|
|
#endif
|
|
|
|
#ifdef HAS_TRANSPOSEWX8_FAST_SSSE3
|
2016-08-25 06:39:38 -07:00
|
|
|
TANY(TransposeWx8_Fast_Any_SSSE3, TransposeWx8_Fast_SSSE3, 15)
|
2015-07-24 16:54:51 -07:00
|
|
|
#endif
|
2016-08-25 06:39:38 -07:00
|
|
|
#ifdef HAS_TRANSPOSEWX8_DSPR2
|
|
|
|
TANY(TransposeWx8_Any_DSPR2, TransposeWx8_DSPR2, 7)
|
2015-07-24 16:54:51 -07:00
|
|
|
#endif
|
2016-07-01 19:08:04 +00:00
|
|
|
#undef TANY
|
2016-06-29 16:18:01 -07:00
|
|
|
|
2016-08-25 06:39:38 -07:00
|
|
|
#define TUVANY(NAMEANY, TPOS_SIMD, MASK) \
|
|
|
|
void NAMEANY(const uint8* src, int src_stride, \
|
|
|
|
uint8* dst_a, int dst_stride_a, \
|
|
|
|
uint8* dst_b, int dst_stride_b, int width) { \
|
|
|
|
int r = width & MASK; \
|
|
|
|
int n = width - r; \
|
|
|
|
if (n > 0) { \
|
|
|
|
TPOS_SIMD(src, src_stride, dst_a, dst_stride_a, dst_b, dst_stride_b, \
|
|
|
|
n); \
|
|
|
|
} \
|
|
|
|
TransposeUVWx8_C(src + n * 2, src_stride, \
|
|
|
|
dst_a + n * dst_stride_a, dst_stride_a, \
|
|
|
|
dst_b + n * dst_stride_b, dst_stride_b, r); \
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef HAS_TRANSPOSEUVWX8_NEON
|
|
|
|
TUVANY(TransposeUVWx8_Any_NEON, TransposeUVWx8_NEON, 7)
|
|
|
|
#endif
|
|
|
|
#ifdef HAS_TRANSPOSEUVWX8_SSE2
|
|
|
|
TUVANY(TransposeUVWx8_Any_SSE2, TransposeUVWx8_SSE2, 7)
|
|
|
|
#endif
|
|
|
|
#ifdef HAS_TRANSPOSEUVWX8_DSPR2
|
|
|
|
TUVANY(TransposeUVWx8_Any_DSPR2, TransposeUVWx8_DSPR2, 7)
|
|
|
|
#endif
|
|
|
|
#undef TUVANY
|
|
|
|
|
2015-07-24 16:54:51 -07:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
} // namespace libyuv
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|