Commit 05d025df authored by fbarchard@google.com's avatar fbarchard@google.com

Convert common low levels use malloc

BUG=296
TESTED=untested
R=tpsiaki@google.com

Review URL: https://webrtc-codereview.appspot.com/6379004

git-svn-id: http://libyuv.googlecode.com/svn/trunk@926 16f28f9a-4ce2-e073-06de-1de4eb20be90
parent e86abbd2
Name: libyuv Name: libyuv
URL: http://code.google.com/p/libyuv/ URL: http://code.google.com/p/libyuv/
Version: 925 Version: 926
License: BSD License: BSD
License File: LICENSE License File: LICENSE
......
...@@ -11,6 +11,6 @@ ...@@ -11,6 +11,6 @@
#ifndef INCLUDE_LIBYUV_VERSION_H_ // NOLINT #ifndef INCLUDE_LIBYUV_VERSION_H_ // NOLINT
#define INCLUDE_LIBYUV_VERSION_H_ #define INCLUDE_LIBYUV_VERSION_H_
#define LIBYUV_VERSION 925 #define LIBYUV_VERSION 926
#endif // INCLUDE_LIBYUV_VERSION_H_ NOLINT #endif // INCLUDE_LIBYUV_VERSION_H_ NOLINT
...@@ -1952,8 +1952,7 @@ void I422ToUYVYRow_C(const uint8* src_y, ...@@ -1952,8 +1952,7 @@ void I422ToUYVYRow_C(const uint8* src_y,
#if !defined(LIBYUV_DISABLE_X86) && defined(HAS_I422TOARGBROW_SSSE3) #if !defined(LIBYUV_DISABLE_X86) && defined(HAS_I422TOARGBROW_SSSE3)
// row_win.cc has asm version, but GCC uses 2 step wrapper. 5% slower. // row_win.cc has asm version, but GCC uses 2 step wrapper.
// TODO(fbarchard): Handle width > kMaxStride here instead of calling code.
#if defined(__x86_64__) || defined(__i386__) #if defined(__x86_64__) || defined(__i386__)
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
void I422ToRGB565Row_SSSE3(const uint8* src_y, void I422ToRGB565Row_SSSE3(const uint8* src_y,
...@@ -1961,9 +1960,11 @@ void I422ToRGB565Row_SSSE3(const uint8* src_y, ...@@ -1961,9 +1960,11 @@ void I422ToRGB565Row_SSSE3(const uint8* src_y,
const uint8* src_v, const uint8* src_v,
uint8* rgb_buf, uint8* rgb_buf,
int width) { int width) {
SIMD_ALIGNED(uint8 row[kMaxStride]); // Allocate a row of ARGB.
align_buffer_64(row, width * 4);
I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width); I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width);
ARGBToRGB565Row_SSE2(row, rgb_buf, width); ARGBToRGB565Row_SSE2(row, rgb_buf, width);
free_aligned_buffer_64(row);
} }
#endif // defined(__x86_64__) || defined(__i386__) #endif // defined(__x86_64__) || defined(__i386__)
...@@ -1974,9 +1975,11 @@ void I422ToARGB1555Row_SSSE3(const uint8* src_y, ...@@ -1974,9 +1975,11 @@ void I422ToARGB1555Row_SSSE3(const uint8* src_y,
const uint8* src_v, const uint8* src_v,
uint8* rgb_buf, uint8* rgb_buf,
int width) { int width) {
SIMD_ALIGNED(uint8 row[kMaxStride]); // Allocate a row of ARGB.
align_buffer_64(row, width * 4);
I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width); I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width);
ARGBToARGB1555Row_SSE2(row, rgb_buf, width); ARGBToARGB1555Row_SSE2(row, rgb_buf, width);
free_aligned_buffer_64(row);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
...@@ -1985,9 +1988,11 @@ void I422ToARGB4444Row_SSSE3(const uint8* src_y, ...@@ -1985,9 +1988,11 @@ void I422ToARGB4444Row_SSSE3(const uint8* src_y,
const uint8* src_v, const uint8* src_v,
uint8* rgb_buf, uint8* rgb_buf,
int width) { int width) {
SIMD_ALIGNED(uint8 row[kMaxStride]); // Allocate a row of ARGB.
align_buffer_64(row, width * 4);
I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width); I422ToARGBRow_SSSE3(src_y, src_u, src_v, row, width);
ARGBToARGB4444Row_SSE2(row, rgb_buf, width); ARGBToARGB4444Row_SSE2(row, rgb_buf, width);
free_aligned_buffer_64(row);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
...@@ -1995,9 +2000,11 @@ void NV12ToRGB565Row_SSSE3(const uint8* src_y, ...@@ -1995,9 +2000,11 @@ void NV12ToRGB565Row_SSSE3(const uint8* src_y,
const uint8* src_uv, const uint8* src_uv,
uint8* dst_rgb565, uint8* dst_rgb565,
int width) { int width) {
SIMD_ALIGNED(uint8 row[kMaxStride]); // Allocate a row of ARGB.
align_buffer_64(row, width * 4);
NV12ToARGBRow_SSSE3(src_y, src_uv, row, width); NV12ToARGBRow_SSSE3(src_y, src_uv, row, width);
ARGBToRGB565Row_SSE2(row, dst_rgb565, width); ARGBToRGB565Row_SSE2(row, dst_rgb565, width);
free_aligned_buffer_64(row);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
...@@ -2005,57 +2012,75 @@ void NV21ToRGB565Row_SSSE3(const uint8* src_y, ...@@ -2005,57 +2012,75 @@ void NV21ToRGB565Row_SSSE3(const uint8* src_y,
const uint8* src_vu, const uint8* src_vu,
uint8* dst_rgb565, uint8* dst_rgb565,
int width) { int width) {
SIMD_ALIGNED(uint8 row[kMaxStride]); // Allocate a row of ARGB.
align_buffer_64(row, width * 4);
NV21ToARGBRow_SSSE3(src_y, src_vu, row, width); NV21ToARGBRow_SSSE3(src_y, src_vu, row, width);
ARGBToRGB565Row_SSE2(row, dst_rgb565, width); ARGBToRGB565Row_SSE2(row, dst_rgb565, width);
free_aligned_buffer_64(row);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
void YUY2ToARGBRow_SSSE3(const uint8* src_yuy2, void YUY2ToARGBRow_SSSE3(const uint8* src_yuy2,
uint8* dst_argb, uint8* dst_argb,
int width) { int width) {
SIMD_ALIGNED(uint8 row_y[kMaxStride]); // Allocate a row of yuv.
SIMD_ALIGNED(uint8 row_u[kMaxStride / 2]); align_buffer_64(row_y, width);
SIMD_ALIGNED(uint8 row_v[kMaxStride / 2]); align_buffer_64(row_u, (width + 1) / 2);
align_buffer_64(row_v, (width + 1) / 2);
YUY2ToUV422Row_SSE2(src_yuy2, row_u, row_v, width); YUY2ToUV422Row_SSE2(src_yuy2, row_u, row_v, width);
YUY2ToYRow_SSE2(src_yuy2, row_y, width); YUY2ToYRow_SSE2(src_yuy2, row_y, width);
I422ToARGBRow_SSSE3(row_y, row_u, row_v, dst_argb, width); I422ToARGBRow_SSSE3(row_y, row_u, row_v, dst_argb, width);
free_aligned_buffer_64(row_y);
free_aligned_buffer_64(row_u);
free_aligned_buffer_64(row_v);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
void YUY2ToARGBRow_Unaligned_SSSE3(const uint8* src_yuy2, void YUY2ToARGBRow_Unaligned_SSSE3(const uint8* src_yuy2,
uint8* dst_argb, uint8* dst_argb,
int width) { int width) {
SIMD_ALIGNED(uint8 row_y[kMaxStride]); // Allocate a row of yuv.
SIMD_ALIGNED(uint8 row_u[kMaxStride / 2]); align_buffer_64(row_y, width);
SIMD_ALIGNED(uint8 row_v[kMaxStride / 2]); align_buffer_64(row_u, (width + 1) / 2);
align_buffer_64(row_v, (width + 1) / 2);
YUY2ToUV422Row_Unaligned_SSE2(src_yuy2, row_u, row_v, width); YUY2ToUV422Row_Unaligned_SSE2(src_yuy2, row_u, row_v, width);
YUY2ToYRow_Unaligned_SSE2(src_yuy2, row_y, width); YUY2ToYRow_Unaligned_SSE2(src_yuy2, row_y, width);
I422ToARGBRow_Unaligned_SSSE3(row_y, row_u, row_v, dst_argb, width); I422ToARGBRow_Unaligned_SSSE3(row_y, row_u, row_v, dst_argb, width);
free_aligned_buffer_64(row_y);
free_aligned_buffer_64(row_u);
free_aligned_buffer_64(row_v);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
void UYVYToARGBRow_SSSE3(const uint8* src_uyvy, void UYVYToARGBRow_SSSE3(const uint8* src_uyvy,
uint8* dst_argb, uint8* dst_argb,
int width) { int width) {
SIMD_ALIGNED(uint8 row_y[kMaxStride]); // Allocate a row of yuv.
SIMD_ALIGNED(uint8 row_u[kMaxStride / 2]); align_buffer_64(row_y, width);
SIMD_ALIGNED(uint8 row_v[kMaxStride / 2]); align_buffer_64(row_u, (width + 1) / 2);
align_buffer_64(row_v, (width + 1) / 2);
UYVYToUV422Row_SSE2(src_uyvy, row_u, row_v, width); UYVYToUV422Row_SSE2(src_uyvy, row_u, row_v, width);
UYVYToYRow_SSE2(src_uyvy, row_y, width); UYVYToYRow_SSE2(src_uyvy, row_y, width);
I422ToARGBRow_SSSE3(row_y, row_u, row_v, dst_argb, width); I422ToARGBRow_SSSE3(row_y, row_u, row_v, dst_argb, width);
free_aligned_buffer_64(row_y);
free_aligned_buffer_64(row_u);
free_aligned_buffer_64(row_v);
} }
MAYBE_SAFEBUFFERS MAYBE_SAFEBUFFERS
void UYVYToARGBRow_Unaligned_SSSE3(const uint8* src_uyvy, void UYVYToARGBRow_Unaligned_SSSE3(const uint8* src_uyvy,
uint8* dst_argb, uint8* dst_argb,
int width) { int width) {
SIMD_ALIGNED(uint8 row_y[kMaxStride]); // Allocate a row of yuv.
SIMD_ALIGNED(uint8 row_u[kMaxStride / 2]); align_buffer_64(row_y, width);
SIMD_ALIGNED(uint8 row_v[kMaxStride / 2]); align_buffer_64(row_u, (width + 1) / 2);
align_buffer_64(row_v, (width + 1) / 2);
UYVYToUV422Row_Unaligned_SSE2(src_uyvy, row_u, row_v, width); UYVYToUV422Row_Unaligned_SSE2(src_uyvy, row_u, row_v, width);
UYVYToYRow_Unaligned_SSE2(src_uyvy, row_y, width); UYVYToYRow_Unaligned_SSE2(src_uyvy, row_y, width);
I422ToARGBRow_Unaligned_SSSE3(row_y, row_u, row_v, dst_argb, width); I422ToARGBRow_Unaligned_SSSE3(row_y, row_u, row_v, dst_argb, width);
free_aligned_buffer_64(row_y);
free_aligned_buffer_64(row_u);
free_aligned_buffer_64(row_v);
} }
#endif // defined(_M_IX86) || defined(__x86_64__) || defined(__i386__) #endif // defined(_M_IX86) || defined(__x86_64__) || defined(__i386__)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment