diff options
author | Daniel Levin <dendy@ti.com> | 2012-06-21 13:53:27 +0300 |
---|---|---|
committer | Daniel Levin <dendy@ti.com> | 2012-07-25 08:56:45 -0500 |
commit | 0db69e2a940fea8c70c8259d74358c6dfd6ff1bf (patch) | |
tree | 71b7d35a15b4499dec0e33e7fd4cf0230f2f0b55 /camera | |
parent | f998f57b85b1a6eda8ea1c4b511199eb2d122a9f (diff) | |
download | hardware_ti_omap4-0db69e2a940fea8c70c8259d74358c6dfd6ff1bf.zip hardware_ti_omap4-0db69e2a940fea8c70c8259d74358c6dfd6ff1bf.tar.gz hardware_ti_omap4-0db69e2a940fea8c70c8259d74358c6dfd6ff1bf.tar.bz2 |
CameraHAL: Fixed NV12_resize coding style
- Added license
- Fixed indentation
- Replaced TRUE/FALSE with true/false
No functional changes.
Change-Id: Iea364bbb33e1abaa28284cb9083622e163ab122d
Signed-off-by: Daniel Levin <dendy@ti.com>
Diffstat (limited to 'camera')
-rw-r--r-- | camera/NV12_resize.cpp | 232 | ||||
-rw-r--r-- | camera/inc/NV12_resize.h | 143 |
2 files changed, 170 insertions, 205 deletions
diff --git a/camera/NV12_resize.cpp b/camera/NV12_resize.cpp index 2ce6c0c..971ee38 100644 --- a/camera/NV12_resize.cpp +++ b/camera/NV12_resize.cpp @@ -1,8 +1,20 @@ -#include "NV12_resize.h" +/* + * Copyright (C) Texas Instruments - http://www.ti.com/ + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ -//#define LOG_NDEBUG 0 -#define LOG_NIDEBUG 0 -#define LOG_NDDEBUG 0 +#include "NV12_resize.h" #ifdef LOG_TAG #undef LOG_TAG @@ -11,22 +23,6 @@ #define STRIDE 4096 -/*---------------------------------------------------------------------------- - Define : TRUE/FALSE for boolean operations -----------------------------------------------------------------------------*/ - -#ifndef TRUE - #define TRUE 1 -#endif - -#ifndef FALSE - #define FALSE 0 -#endif - -#ifndef NULL - #define NULL 0 -#endif - /*========================================================================== * Function Name : VT_resizeFrame_Video_opt2_lp * @@ -42,95 +38,82 @@ * faster version. ============================================================================*/ mmBool -VT_resizeFrame_Video_opt2_lp -( - structConvImage* i_img_ptr, /* Points to the input image */ - structConvImage* o_img_ptr, /* Points to the output image */ - IC_rect_type* cropout, /* how much to resize to in final image */ - mmUint16 dummy /* Transparent pixel value */ - ) -{ - CAMHAL_LOGV("VT_resizeFrame_Video_opt2_lp+"); - - mmUint16 row,col; - mmUint32 resizeFactorX; - mmUint32 resizeFactorY; - - - mmUint16 x, y; - - mmUchar* ptr8; - mmUchar *ptr8Cb, *ptr8Cr; - - - mmUint16 xf, yf; - mmUchar* inImgPtrY; - mmUchar* inImgPtrU; - mmUchar* inImgPtrV; - mmUint32 cox, coy, codx, cody; - mmUint16 idx,idy, idxC; - - if(i_img_ptr->uWidth == o_img_ptr->uWidth) - { - if(i_img_ptr->uHeight == o_img_ptr->uHeight) - { - CAMHAL_LOGV("************************f(i_img_ptr->uHeight == o_img_ptr->uHeight) are same *********************\n"); - CAMHAL_LOGV("************************(i_img_ptr->width == %d" , i_img_ptr->uWidth ); - CAMHAL_LOGV("************************(i_img_ptr->uHeight == %d" , i_img_ptr->uHeight ); - CAMHAL_LOGV("************************(o_img_ptr->width == %d" ,o_img_ptr->uWidth ); - CAMHAL_LOGV("************************(o_img_ptr->uHeight == %d" , o_img_ptr->uHeight ); - } - } - - if (!i_img_ptr || !i_img_ptr->imgPtr || - !o_img_ptr || !o_img_ptr->imgPtr) - { - CAMHAL_LOGE("Image Point NULL"); - CAMHAL_LOGV("VT_resizeFrame_Video_opt2_lp-"); - return FALSE; - } - - inImgPtrY = (mmUchar *) i_img_ptr->imgPtr + i_img_ptr->uOffset; - inImgPtrU = (mmUchar *) i_img_ptr->clrPtr + i_img_ptr->uOffset/2; - inImgPtrV = (mmUchar*)inImgPtrU + 1; - - if (cropout == NULL) - { - cox = 0; - coy = 0; - codx = o_img_ptr->uWidth; - cody = o_img_ptr->uHeight; - } - else - { - cox = cropout->x; - coy = cropout->y; - codx = cropout->uWidth; - cody = cropout->uHeight; - } - idx = i_img_ptr->uWidth; - idy = i_img_ptr->uHeight; - - /* make sure valid input size */ - if (idx < 1 || idy < 1 || i_img_ptr->uStride < 1) - { - CAMHAL_LOGE("idx or idy less then 1 idx = %d idy = %d stride = %d", idx, idy, i_img_ptr->uStride); - CAMHAL_LOGV("VT_resizeFrame_Video_opt2_lp-"); - return FALSE; - } - - resizeFactorX = ((idx-1)<<9) / codx; - resizeFactorY = ((idy-1)<<9) / cody; - - if(i_img_ptr->eFormat == IC_FORMAT_YCbCr420_lp && - o_img_ptr->eFormat == IC_FORMAT_YCbCr420_lp) - { - ptr8 = (mmUchar*)o_img_ptr->imgPtr + cox + coy*o_img_ptr->uWidth; +VT_resizeFrame_Video_opt2_lp( + structConvImage* i_img_ptr, /* Points to the input image */ + structConvImage* o_img_ptr, /* Points to the output image */ + IC_rect_type* cropout, /* how much to resize to in final image */ + mmUint16 dummy /* Transparent pixel value */ + ) { + LOG_FUNCTION_NAME; + + mmUint16 row,col; + mmUint32 resizeFactorX; + mmUint32 resizeFactorY; + + mmUint16 x, y; + + mmUchar* ptr8; + mmUchar *ptr8Cb, *ptr8Cr; + + mmUint16 xf, yf; + mmUchar* inImgPtrY; + mmUchar* inImgPtrU; + mmUchar* inImgPtrV; + mmUint32 cox, coy, codx, cody; + mmUint16 idx,idy, idxC; + + if ( i_img_ptr->uWidth == o_img_ptr->uWidth ) { + if ( i_img_ptr->uHeight == o_img_ptr->uHeight ) { + CAMHAL_LOGV("************************f(i_img_ptr->uHeight == o_img_ptr->uHeight) are same *********************\n"); + CAMHAL_LOGV("************************(i_img_ptr->width == %d" , i_img_ptr->uWidth ); + CAMHAL_LOGV("************************(i_img_ptr->uHeight == %d" , i_img_ptr->uHeight ); + CAMHAL_LOGV("************************(o_img_ptr->width == %d" ,o_img_ptr->uWidth ); + CAMHAL_LOGV("************************(o_img_ptr->uHeight == %d" , o_img_ptr->uHeight ); + } + } + + if ( !i_img_ptr || !i_img_ptr->imgPtr || !o_img_ptr || !o_img_ptr->imgPtr ) { + CAMHAL_LOGE("Image Point NULL"); + return false; + } + + inImgPtrY = (mmUchar *) i_img_ptr->imgPtr + i_img_ptr->uOffset; + inImgPtrU = (mmUchar *) i_img_ptr->clrPtr + i_img_ptr->uOffset/2; + inImgPtrV = (mmUchar*)inImgPtrU + 1; + + if ( !cropout ) { + cox = 0; + coy = 0; + codx = o_img_ptr->uWidth; + cody = o_img_ptr->uHeight; + } else { + cox = cropout->x; + coy = cropout->y; + codx = cropout->uWidth; + cody = cropout->uHeight; + } + idx = i_img_ptr->uWidth; + idy = i_img_ptr->uHeight; + /* make sure valid input size */ + if ( idx < 1 || idy < 1 || i_img_ptr->uStride < 1 ) { + CAMHAL_LOGE("idx or idy less then 1 idx = %d idy = %d stride = %d", idx, idy, i_img_ptr->uStride); + return false; + } + + resizeFactorX = ((idx-1)<<9) / codx; + resizeFactorY = ((idy-1)<<9) / cody; + + if( i_img_ptr->eFormat != IC_FORMAT_YCbCr420_lp || + o_img_ptr->eFormat != IC_FORMAT_YCbCr420_lp ) { + CAMHAL_LOGE("eFormat not supported"); + return false; + } + + ptr8 = (mmUchar*)o_img_ptr->imgPtr + cox + coy*o_img_ptr->uWidth; ////////////////////////////for Y////////////////////////// - for (row=0; row < cody; row++) - { + for ( row = 0; row < cody; row++ ) { mmUchar *pu8Yrow1 = NULL; mmUchar *pu8Yrow2 = NULL; y = (mmUint16) ((mmUint32) (row*resizeFactorY) >> 9); @@ -138,8 +121,7 @@ VT_resizeFrame_Video_opt2_lp pu8Yrow1 = inImgPtrY + (y) * i_img_ptr->uStride; pu8Yrow2 = pu8Yrow1 + i_img_ptr->uStride; - for (col=0; col < codx; col++) - { + for ( col = 0; col < codx; col++ ) { mmUchar in11, in12, in21, in22; mmUchar *pu8ptr1 = NULL; mmUchar *pu8ptr2 = NULL; @@ -147,12 +129,9 @@ VT_resizeFrame_Video_opt2_lp mmUint16 accum_1; //mmUint32 accum_W; - - x = (mmUint16) ((mmUint32) (col*resizeFactorX) >> 9); xf = (mmUchar) ((mmUint32) ((col*resizeFactorX) >> 6) & 0x7); - //accum_W = 0; accum_1 = 0; @@ -194,7 +173,6 @@ VT_resizeFrame_Video_opt2_lp accum_1 = (accum_1>>6); *ptr8 = (mmUchar)accum_1 ; - ptr8++; } ptr8 = ptr8 + (o_img_ptr->uStride - codx); @@ -208,8 +186,7 @@ VT_resizeFrame_Video_opt2_lp ptr8Cr = (mmUchar*)(ptr8Cb+1); idxC = (idx>>1); - for (row=0; row < (((cody)>>1)); row++) - { + for ( row = 0; row < (((cody)>>1)); row++ ) { mmUchar *pu8Cbr1 = NULL; mmUchar *pu8Cbr2 = NULL; mmUchar *pu8Crr1 = NULL; @@ -223,8 +200,7 @@ VT_resizeFrame_Video_opt2_lp pu8Crr1 = inImgPtrV + (y) * i_img_ptr->uStride; pu8Crr2 = pu8Crr1 + i_img_ptr->uStride; - for (col=0; col < (((codx)>>1)); col++) - { + for ( col = 0; col < (((codx)>>1)); col++ ) { mmUchar in11, in12, in21, in22; mmUchar *pu8Cbc1 = NULL; mmUchar *pu8Cbc2 = NULL; @@ -235,21 +211,17 @@ VT_resizeFrame_Video_opt2_lp mmUint16 accum_1Cb, accum_1Cr; //mmUint32 accum_WCb, accum_WCr; - x = (mmUint16) ((mmUint32) (col*resizeFactorX) >> 9); xf = (mmUchar) ((mmUint32) ((col*resizeFactorX) >> 6) & 0x7); - //accum_WCb = accum_WCr = 0; accum_1Cb = accum_1Cr = 0; pu8Cbc1 = pu8Cbr1 + (x*2); pu8Cbc2 = pu8Cbr2 + (x*2); - pu8Crc1 = pu8Crr1 + (x*2); + pu8Crc1 = pu8Crr1 + (x*2); pu8Crc2 = pu8Crr2 + (x*2); - - /* A pixel */ w = bWeights[xf][yf][0]; @@ -257,7 +229,7 @@ VT_resizeFrame_Video_opt2_lp accum_1Cb = (w * in11); // accum_WCb += (w); - in11 = *(pu8Crc1); + in11 = *(pu8Crc1); accum_1Cr = (w * in11); //accum_WCr += (w); @@ -279,7 +251,7 @@ VT_resizeFrame_Video_opt2_lp accum_1Cb += (w * in21); //accum_WCb += (w); - in21 = *(pu8Crc2); + in21 = *(pu8Crc2); accum_1Cr += (w * in21); //accum_WCr += (w); @@ -299,7 +271,6 @@ VT_resizeFrame_Video_opt2_lp accum_1Cb = (accum_1Cb>>6); *ptr8Cb = (mmUchar)accum_1Cb ; - accum_1Cr = (accum_1Cr >> 6); *ptr8Cr = (mmUchar)accum_1Cr ; @@ -313,14 +284,7 @@ VT_resizeFrame_Video_opt2_lp ptr8Cr = ptr8Cr + (o_img_ptr->uStride-codx); } ///////////////////For Cb- Cr//////////////////////////////////////// - } - else - { - CAMHAL_LOGE("eFormat not supported"); - CAMHAL_LOGV("VT_resizeFrame_Video_opt2_lp-"); - return FALSE; - } - CAMHAL_LOGV("success"); - CAMHAL_LOGV("VT_resizeFrame_Video_opt2_lp-"); - return TRUE; + + CAMHAL_LOGV("success"); + return true; } diff --git a/camera/inc/NV12_resize.h b/camera/inc/NV12_resize.h index 019b9eb..4b05a4f 100644 --- a/camera/inc/NV12_resize.h +++ b/camera/inc/NV12_resize.h @@ -1,50 +1,59 @@ +/* + * Copyright (C) Texas Instruments - http://www.ti.com/ + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + #ifndef NV12_RESIZE_H_ #define NV12_RESIZE_H_ #include "Common.h" -#ifdef __cplusplus -extern "C" { -#endif - -typedef unsigned char mmBool; -typedef unsigned char mmUchar; -typedef unsigned char mmUint8; -typedef unsigned char mmByte; -typedef unsigned short mmUint16; -typedef unsigned int mmUint32; -typedef unsigned long mmUint64; -typedef signed char mmInt8; -typedef char mmChar; -typedef signed short mmInt16; -typedef signed int mmInt32; -typedef signed long mmLong; -typedef signed int mmHandle; -typedef float mmFloat; -typedef double mmDouble; -typedef int HObj; -typedef HObj HFile; -typedef int HDir; -typedef void* mmMutexHandle; -typedef struct _fstat -{ - mmInt32 fileSize; -}VE_FileAttribute; - -typedef struct -{ - mmInt32 second; - mmInt32 millisecond; -}tsVE_Time; - -typedef struct -{ - mmInt32 year; - mmInt32 month; - mmInt32 day; - mmInt32 hour; - mmInt32 minute; - mmInt32 second; +typedef unsigned char mmBool; +typedef unsigned char mmUchar; +typedef unsigned char mmUint8; +typedef unsigned char mmByte; +typedef unsigned short mmUint16; +typedef unsigned int mmUint32; +typedef unsigned long mmUint64; +typedef signed char mmInt8; +typedef char mmChar; +typedef signed short mmInt16; +typedef signed int mmInt32; +typedef signed long mmLong; +typedef signed int mmHandle; +typedef float mmFloat; +typedef double mmDouble; +typedef int HObj; +typedef HObj HFile; +typedef int HDir; +typedef void* mmMutexHandle; +typedef struct _fstat { + mmInt32 fileSize; +} VE_FileAttribute; + +typedef struct { + mmInt32 second; + mmInt32 millisecond; +} tsVE_Time; + +typedef struct { + mmInt32 year; + mmInt32 month; + mmInt32 day; + mmInt32 hour; + mmInt32 minute; + mmInt32 second; } TmDateTime; const mmUint8 bWeights[8][8][4] = { @@ -73,8 +82,7 @@ const mmUint8 bWeights[8][8][4] = { { 4,28,28,4 }, { 3,21,35, 5}, { 2,14,42, 6}, { 1,7 ,49, 7}} }; -typedef enum -{ +typedef enum { IC_FORMAT_NONE, IC_FORMAT_RGB565, IC_FORMAT_RGB888, @@ -82,26 +90,24 @@ typedef enum IC_FORMAT_YCbCr, IC_FORMAT_YCbCr420_FRAME_PK, IC_FORMAT_MAX -}enumImageFormat; +} enumImageFormat; /* This structure defines the format of an image */ -typedef struct -{ - mmInt32 uWidth; - mmInt32 uHeight; - mmInt32 uStride; - enumImageFormat eFormat; - mmByte *imgPtr; - mmByte *clrPtr; - mmInt32 uOffset; +typedef struct { + mmInt32 uWidth; + mmInt32 uHeight; + mmInt32 uStride; + enumImageFormat eFormat; + mmByte *imgPtr; + mmByte *clrPtr; + mmInt32 uOffset; } structConvImage; -typedef struct IC_crop_struct -{ - mmUint32 x; /* x pos of rectangle */ - mmUint32 y; /* y pos of rectangle */ - mmUint32 uWidth; /* dx of rectangle */ - mmUint32 uHeight; /* dy of rectangle */ +typedef struct IC_crop_struct { + mmUint32 x; /* x pos of rectangle */ + mmUint32 y; /* y pos of rectangle */ + mmUint32 uWidth; /* dx of rectangle */ + mmUint32 uHeight; /* dy of rectangle */ } IC_rect_type; /*========================================================================== @@ -119,16 +125,11 @@ typedef struct IC_crop_struct * faster version. ============================================================================*/ mmBool -VT_resizeFrame_Video_opt2_lp -( - structConvImage* i_img_ptr, /* Points to the input image */ - structConvImage* o_img_ptr, /* Points to the output image */ - IC_rect_type* cropout, /* how much to resize to in final image */ - mmUint16 dummy /* Transparent pixel value */ - ); - -#ifdef __cplusplus -} -#endif +VT_resizeFrame_Video_opt2_lp( + structConvImage* i_img_ptr, /* Points to the input image */ + structConvImage* o_img_ptr, /* Points to the output image */ + IC_rect_type* cropout, /* how much to resize to in final image */ + mmUint16 dummy /* Transparent pixel value */ + ); #endif //#define NV12_RESIZE_H_ |