| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // yuv_row internal functions to handle YUV conversion and scaling to RGB. | 5 // yuv_row internal functions to handle YUV conversion and scaling to RGB. |
| 6 // These functions are used from both yuv_convert.cc and yuv_scale.cc. | 6 // These functions are used from both yuv_convert.cc and yuv_scale.cc. |
| 7 | 7 |
| 8 // TODO(fbarchard): Write function that can handle rotation and scaling. | 8 // TODO(fbarchard): Write function that can handle rotation and scaling. |
| 9 | 9 |
| 10 #ifndef MEDIA_BASE_YUV_ROW_H_ | 10 #ifndef MEDIA_BASE_YUV_ROW_H_ |
| 11 #define MEDIA_BASE_YUV_ROW_H_ | 11 #define MEDIA_BASE_YUV_ROW_H_ |
| 12 | 12 |
| 13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
| 14 | 14 |
| 15 extern "C" { | 15 extern "C" { |
| 16 // Can only do 1x. | 16 // Can only do 1x. |
| 17 // This is the second fastest of the scalers. | 17 // This is the second fastest of the scalers. |
| 18 void FastConvertYUVToRGB32Row(const uint8* y_buf, | 18 void FastConvertYUVToRGB32Row(const uint8* y_buf, |
| 19 const uint8* u_buf, | 19 const uint8* u_buf, |
| 20 const uint8* v_buf, | 20 const uint8* v_buf, |
| 21 uint8* rgb_buf, | 21 uint8* rgb_buf, |
| 22 int width); | 22 int source_width); |
| 23 | 23 |
| 24 // Can do 1x, half size or any scale down by an integer amount. | 24 // Can do 1x, half size or any scale down by an integer amount. |
| 25 // Step can be negative (mirroring, rotate 180). | 25 // Step can be negative (mirroring, rotate 180). |
| 26 // This is the third fastest of the scalers. | 26 // This is the third fastest of the scalers. |
| 27 void ConvertYUVToRGB32Row(const uint8* y_buf, | 27 void ConvertYUVToRGB32Row(const uint8* y_buf, |
| 28 const uint8* u_buf, | 28 const uint8* u_buf, |
| 29 const uint8* v_buf, | 29 const uint8* v_buf, |
| 30 uint8* rgb_buf, | 30 uint8* rgb_buf, |
| 31 int width, | 31 int source_width, |
| 32 int step); | 32 int step); |
| 33 | 33 |
| 34 // Rotate is like Convert, but applies different step to Y versus U and V. | 34 // Rotate is like Convert, but applies different step to Y versus U and V. |
| 35 // This allows rotation by 90 or 270, by stepping by stride. | 35 // This allows rotation by 90 or 270, by stepping by stride. |
| 36 // This is the forth fastest of the scalers. | 36 // This is the forth fastest of the scalers. |
| 37 void RotateConvertYUVToRGB32Row(const uint8* y_buf, | 37 void RotateConvertYUVToRGB32Row(const uint8* y_buf, |
| 38 const uint8* u_buf, | 38 const uint8* u_buf, |
| 39 const uint8* v_buf, | 39 const uint8* v_buf, |
| 40 uint8* rgb_buf, | 40 uint8* rgb_buf, |
| 41 int width, | 41 int source_width, |
| 42 int ystep, | 42 int ystep, |
| 43 int uvstep); | 43 int uvstep); |
| 44 | 44 |
| 45 // Doubler does 4 pixels at a time. Each pixel is replicated. | 45 // Doubler does 4 pixels at a time. Each pixel is replicated. |
| 46 // This is the fastest of the scalers. | 46 // This is the fastest of the scalers. |
| 47 void DoubleYUVToRGB32Row(const uint8* y_buf, | 47 void DoubleYUVToRGB32Row(const uint8* y_buf, |
| 48 const uint8* u_buf, | 48 const uint8* u_buf, |
| 49 const uint8* v_buf, | 49 const uint8* v_buf, |
| 50 uint8* rgb_buf, | 50 uint8* rgb_buf, |
| 51 int width); | 51 int source_width); |
| 52 | 52 |
| 53 // Handles arbitrary scaling up or down. | 53 // Handles arbitrary scaling up or down. |
| 54 // Mirroring is supported, but not 90 or 270 degree rotation. | 54 // Mirroring is supported, but not 90 or 270 degree rotation. |
| 55 // Chroma is under sampled every 2 pixels for performance. | 55 // Chroma is under sampled every 2 pixels for performance. |
| 56 // This is the slowest of the scalers. | 56 // This is the slowest of the scalers. |
| 57 void ScaleYUVToRGB32Row(const uint8* y_buf, | 57 void ScaleYUVToRGB32Row(const uint8* y_buf, |
| 58 const uint8* u_buf, | 58 const uint8* u_buf, |
| 59 const uint8* v_buf, | 59 const uint8* v_buf, |
| 60 uint8* rgb_buf, | 60 uint8* rgb_buf, |
| 61 int width, | 61 int source_width, |
| 62 int scaled_dx); | 62 int source_dx); |
| 63 | 63 |
| 64 void LinearScaleYUVToRGB32Row(const uint8* y_buf, | 64 void LinearScaleYUVToRGB32Row(const uint8* y_buf, |
| 65 const uint8* u_buf, | 65 const uint8* u_buf, |
| 66 const uint8* v_buf, | 66 const uint8* v_buf, |
| 67 uint8* rgb_buf, | 67 uint8* rgb_buf, |
| 68 int width, | 68 int source_width, |
| 69 int dx); | 69 int dx); |
| 70 } // extern "C" | 70 |
| 71 #if defined(_MSC_VER) |
| 72 #define SIMD_ALIGNED(var) __declspec(align(16)) var |
| 73 #else |
| 74 #define SIMD_ALIGNED(var) var __attribute__((aligned(16))) |
| 75 #endif |
| 76 extern SIMD_ALIGNED(int16 kCoefficientsRgbY[768][4]); |
| 77 |
| 78 // Method to force C version. |
| 79 //#define USE_MMX 0 |
| 80 //#define USE_SSE2 0 |
| 71 | 81 |
| 72 #if !defined(USE_MMX) | 82 #if !defined(USE_MMX) |
| 73 // Windows, Mac and Linux/BSD use MMX | 83 // Windows, Mac and Linux/BSD use MMX |
| 74 #if defined(__MMX__) || defined(_MSC_VER) | 84 #if defined(__MMX__) || defined(_MSC_VER) |
| 75 #define USE_MMX 1 | 85 #define USE_MMX 1 |
| 76 #else | 86 #else |
| 77 #define USE_MMX 0 | 87 #define USE_MMX 0 |
| 78 #endif | 88 #endif |
| 79 #endif | 89 #endif |
| 80 | 90 |
| 81 #if !defined(USE_SSE) | 91 #if !defined(USE_SSE2) |
| 82 #if defined(__SSE2__) || defined(ARCH_CPU_X86_64) || _M_IX86_FP==2 | 92 #if defined(__SSE2__) || defined(ARCH_CPU_X86_64) || _M_IX86_FP==2 |
| 83 #define USE_SSE 1 | 93 #define USE_SSE2 1 |
| 84 #else | 94 #else |
| 85 #define USE_SSE 0 | 95 #define USE_SSE2 0 |
| 86 #endif | 96 #endif |
| 87 #endif | 97 #endif |
| 88 | 98 |
| 89 // x64 uses MMX2 (SSE) so emms is not required. | 99 // x64 uses MMX2 (SSE) so emms is not required. |
| 100 // Warning C4799: function has no EMMS instruction. |
| 101 // EMMS() is slow and should be called by the calling function once per image. |
| 90 #if USE_MMX && !defined(ARCH_CPU_X86_64) | 102 #if USE_MMX && !defined(ARCH_CPU_X86_64) |
| 91 #if defined(_MSC_VER) | 103 #if defined(_MSC_VER) |
| 92 #define EMMS() __asm emms | 104 #define EMMS() __asm emms |
| 93 #pragma warning(disable: 4799) | 105 #pragma warning(disable: 4799) |
| 94 #else | 106 #else |
| 95 #define EMMS() asm("emms") | 107 #define EMMS() asm("emms") |
| 96 #endif | 108 #endif |
| 97 #else | 109 #else |
| 98 #define EMMS() | 110 #define EMMS() |
| 99 #endif | 111 #endif |
| 100 | 112 |
| 113 } // extern "C" |
| 114 |
| 101 #endif // MEDIA_BASE_YUV_ROW_H_ | 115 #endif // MEDIA_BASE_YUV_ROW_H_ |
| OLD | NEW |