2011-10-25 21:14:16 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2011 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LIBYUV_SOURCE_ROW_H_
|
|
|
|
#define LIBYUV_SOURCE_ROW_H_
|
|
|
|
|
|
|
|
#include "third_party/libyuv/include/libyuv/basic_types.h"
|
|
|
|
|
|
|
|
#define kMaxStride (2048 * 4)
|
2011-12-08 18:31:01 +01:00
|
|
|
#define IS_ALIGNED(p, a) (!((uintptr_t)(p) & ((a) - 1)))
|
2011-10-25 21:14:16 +02:00
|
|
|
|
|
|
|
#if defined(COVERAGE_ENABLED) || defined(TARGET_IPHONE_SIMULATOR)
|
|
|
|
#define YUV_DISABLE_ASM
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(__ARM_NEON__) && !defined(YUV_DISABLE_ASM)
|
|
|
|
#define HAS_FASTCONVERTYUVTOARGBROW_NEON
|
|
|
|
void FastConvertYUVToARGBRow_NEON(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
#define HAS_FASTCONVERTYUVTOBGRAROW_NEON
|
|
|
|
void FastConvertYUVToBGRARow_NEON(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
#define HAS_FASTCONVERTYUVTOABGRROW_NEON
|
|
|
|
void FastConvertYUVToABGRRow_NEON(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// The following are available on all x86 platforms
|
|
|
|
#if (defined(_M_IX86) || defined(__x86_64__) || defined(__i386__)) && \
|
|
|
|
!defined(YUV_DISABLE_ASM)
|
|
|
|
#define HAS_ABGRTOARGBROW_SSSE3
|
|
|
|
#define HAS_BGRATOARGBROW_SSSE3
|
|
|
|
#define HAS_BG24TOARGBROW_SSSE3
|
|
|
|
#define HAS_RAWTOARGBROW_SSSE3
|
|
|
|
#define HAS_RGB24TOYROW_SSSE3
|
|
|
|
#define HAS_RAWTOYROW_SSSE3
|
|
|
|
#define HAS_RGB24TOUVROW_SSSE3
|
|
|
|
#define HAS_RAWTOUVROW_SSSE3
|
|
|
|
#define HAS_ARGBTOYROW_SSSE3
|
|
|
|
#define HAS_BGRATOYROW_SSSE3
|
|
|
|
#define HAS_ABGRTOYROW_SSSE3
|
|
|
|
#define HAS_ARGBTOUVROW_SSSE3
|
|
|
|
#define HAS_BGRATOUVROW_SSSE3
|
|
|
|
#define HAS_ABGRTOUVROW_SSSE3
|
|
|
|
#define HAS_I400TOARGBROW_SSE2
|
|
|
|
#define HAS_FASTCONVERTYTOARGBROW_SSE2
|
|
|
|
#define HAS_FASTCONVERTYUVTOARGBROW_SSSE3
|
|
|
|
#define HAS_FASTCONVERTYUVTOBGRAROW_SSSE3
|
|
|
|
#define HAS_FASTCONVERTYUVTOABGRROW_SSSE3
|
|
|
|
#define HAS_FASTCONVERTYUV444TOARGBROW_SSSE3
|
|
|
|
#define HAS_REVERSE_ROW_SSSE3
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// The following are available on Neon platforms
|
|
|
|
#if defined(__ARM_NEON__) && !defined(YUV_DISABLE_ASM)
|
|
|
|
#define HAS_REVERSE_ROW_NEON
|
|
|
|
#endif
|
|
|
|
|
2011-12-08 18:31:01 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
namespace libyuv {
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2011-10-25 21:14:16 +02:00
|
|
|
|
|
|
|
#ifdef HAS_ARGBTOYROW_SSSE3
|
|
|
|
void ARGBToYRow_SSSE3(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void BGRAToYRow_SSSE3(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void ABGRToYRow_SSSE3(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void ARGBToUVRow_SSSE3(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void BGRAToUVRow_SSSE3(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void ABGRToUVRow_SSSE3(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
#endif
|
|
|
|
#if defined(HAS_BG24TOARGBROW_SSSE3) && defined(HAS_ARGBTOYROW_SSSE3)
|
|
|
|
#define HASRGB24TOYROW_SSSE3
|
|
|
|
#endif
|
|
|
|
#ifdef HASRGB24TOYROW_SSSE3
|
|
|
|
void RGB24ToYRow_SSSE3(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void RAWToYRow_SSSE3(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void RGB24ToUVRow_SSSE3(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void RAWToUVRow_SSSE3(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
#endif
|
|
|
|
#ifdef HAS_REVERSE_ROW_SSSE3
|
|
|
|
void ReverseRow_SSSE3(const uint8* src, uint8* dst, int width);
|
|
|
|
#endif
|
|
|
|
#ifdef HAS_REVERSE_ROW_NEON
|
|
|
|
void ReverseRow_NEON(const uint8* src, uint8* dst, int width);
|
|
|
|
#endif
|
|
|
|
void ReverseRow_C(const uint8* src, uint8* dst, int width);
|
|
|
|
|
|
|
|
void ARGBToYRow_C(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void BGRAToYRow_C(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void ABGRToYRow_C(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void RGB24ToYRow_C(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void RAWToYRow_C(const uint8* src_argb, uint8* dst_y, int pix);
|
|
|
|
void ARGBToUVRow_C(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void BGRAToUVRow_C(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void ABGRToUVRow_C(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void RGB24ToUVRow_C(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
void RAWToUVRow_C(const uint8* src_argb0, int src_stride_argb,
|
|
|
|
uint8* dst_u, uint8* dst_v, int width);
|
|
|
|
|
|
|
|
#ifdef HAS_BG24TOARGBROW_SSSE3
|
|
|
|
void ABGRToARGBRow_SSSE3(const uint8* src_abgr, uint8* dst_argb, int pix);
|
|
|
|
void BGRAToARGBRow_SSSE3(const uint8* src_bgra, uint8* dst_argb, int pix);
|
|
|
|
void BG24ToARGBRow_SSSE3(const uint8* src_bg24, uint8* dst_argb, int pix);
|
|
|
|
void RAWToARGBRow_SSSE3(const uint8* src_bg24, uint8* dst_argb, int pix);
|
|
|
|
#endif
|
|
|
|
void ABGRToARGBRow_C(const uint8* src_abgr, uint8* dst_argb, int pix);
|
|
|
|
void BGRAToARGBRow_C(const uint8* src_bgra, uint8* dst_argb, int pix);
|
|
|
|
void BG24ToARGBRow_C(const uint8* src_bg24, uint8* dst_argb, int pix);
|
|
|
|
void RAWToARGBRow_C(const uint8* src_bg24, uint8* dst_argb, int pix);
|
|
|
|
|
|
|
|
#ifdef HAS_I400TOARGBROW_SSE2
|
|
|
|
void I400ToARGBRow_SSE2(const uint8* src_y, uint8* dst_argb, int pix);
|
|
|
|
#endif
|
|
|
|
void I400ToARGBRow_C(const uint8* src_y, uint8* dst_argb, int pix);
|
|
|
|
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#define SIMD_ALIGNED(var) __declspec(align(16)) var
|
|
|
|
typedef __declspec(align(16)) signed char vec8[16];
|
|
|
|
typedef __declspec(align(16)) unsigned char uvec8[16];
|
|
|
|
typedef __declspec(align(16)) signed short vec16[8];
|
|
|
|
#else // __GNUC__
|
|
|
|
#define SIMD_ALIGNED(var) var __attribute__((aligned(16)))
|
|
|
|
typedef signed char __attribute__((vector_size(16))) vec8;
|
|
|
|
typedef unsigned char __attribute__((vector_size(16))) uvec8;
|
|
|
|
typedef signed short __attribute__((vector_size(16))) vec16;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//extern "C"
|
|
|
|
SIMD_ALIGNED(const int16 kCoefficientsRgbY[768][4]);
|
|
|
|
//extern "C"
|
|
|
|
SIMD_ALIGNED(const int16 kCoefficientsBgraY[768][4]);
|
|
|
|
//extern "C"
|
|
|
|
SIMD_ALIGNED(const int16 kCoefficientsAbgrY[768][4]);
|
|
|
|
|
|
|
|
void FastConvertYUVToARGBRow_C(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToBGRARow_C(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToABGRRow_C(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUV444ToARGBRow_C(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYToARGBRow_C(const uint8* y_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
#ifdef HAS_FASTCONVERTYUVTOARGBROW_SSE2
|
|
|
|
void FastConvertYUVToARGBRow_SSE2(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToARGBRow4_SSE2(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToBGRARow_SSE2(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToABGRRow_SSE2(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUV444ToARGBRow_SSE2(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYToARGBRow_SSE2(const uint8* y_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAS_FASTCONVERTYUVTOARGBROW_SSSE3
|
|
|
|
void FastConvertYUVToARGBRow_SSSE3(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToBGRARow_SSSE3(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUVToABGRRow_SSSE3(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
void FastConvertYUV444ToARGBRow_SSSE3(const uint8* y_buf,
|
|
|
|
const uint8* u_buf,
|
|
|
|
const uint8* v_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAS_FASTCONVERTYTOARGBROW_SSE2
|
|
|
|
void FastConvertYToARGBRow_SSE2(const uint8* y_buf,
|
|
|
|
uint8* rgb_buf,
|
|
|
|
int width);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2011-12-08 18:31:01 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
} // namespace libyuv
|
|
|
|
#endif
|
2011-10-25 21:14:16 +02:00
|
|
|
|
|
|
|
#endif // LIBYUV_SOURCE_ROW_H_
|