/* * 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. */ /** * @file OMXAlgo.cpp * * This file contains functionality for handling algorithm configurations. * */ #undef LOG_TAG #define LOG_TAG "CameraHAL" #include "CameraHal.h" #include "OMXCameraAdapter.h" #include "ErrorUtils.h" #undef TRUE namespace android { status_t OMXCameraAdapter::setParametersAlgo(const CameraParameters ¶ms, BaseCameraAdapter::AdapterState state) { status_t ret = NO_ERROR; const char *valstr = NULL; const char *oldstr = NULL; LOG_FUNCTION_NAME; CaptureMode capMode; CAMHAL_LOGDB("Capture mode %s", params.get(TICameraParameters::KEY_CAP_MODE)); if ( (valstr = params.get(TICameraParameters::KEY_CAP_MODE)) != NULL ) { if (strcmp(valstr, (const char *) TICameraParameters::HIGH_PERFORMANCE_MODE) == 0) { capMode = OMXCameraAdapter::HIGH_SPEED; } else if (strcmp(valstr, (const char *) TICameraParameters::HIGH_QUALITY_MODE) == 0) { capMode = OMXCameraAdapter::HIGH_QUALITY; } else if (strcmp(valstr, (const char *) TICameraParameters::HIGH_QUALITY_ZSL_MODE) == 0) { capMode = OMXCameraAdapter::HIGH_QUALITY_ZSL; } else if (strcmp(valstr, (const char *) TICameraParameters::VIDEO_MODE) == 0) { capMode = OMXCameraAdapter::VIDEO_MODE; } else { capMode = OMXCameraAdapter::HIGH_QUALITY; } } else { capMode = OMXCameraAdapter::HIGH_QUALITY_ZSL; } if ( mCapMode != capMode ) { mCapMode = capMode; mOMXStateSwitch = true; } CAMHAL_LOGDB("Capture Mode set %d", mCapMode); /// Configure IPP, LDCNSF, GBCE and GLBCE only in HQ mode IPPMode ipp; if((mCapMode == OMXCameraAdapter::HIGH_QUALITY) || (mCapMode == OMXCameraAdapter::HIGH_QUALITY_ZSL) || (mCapMode == OMXCameraAdapter::VIDEO_MODE) ) { if ( (valstr = params.get(TICameraParameters::KEY_IPP)) != NULL ) { if (strcmp(valstr, (const char *) TICameraParameters::IPP_LDCNSF) == 0) { ipp = OMXCameraAdapter::IPP_LDCNSF; } else if (strcmp(valstr, (const char *) TICameraParameters::IPP_LDC) == 0) { ipp = OMXCameraAdapter::IPP_LDC; } else if (strcmp(valstr, (const char *) TICameraParameters::IPP_NSF) == 0) { ipp = OMXCameraAdapter::IPP_NSF; } else if (strcmp(valstr, (const char *) TICameraParameters::IPP_NONE) == 0) { ipp = OMXCameraAdapter::IPP_NONE; } else { ipp = OMXCameraAdapter::IPP_NONE; } } else { ipp = OMXCameraAdapter::IPP_NONE; } CAMHAL_LOGVB("IPP Mode set %d", ipp); if (((valstr = params.get(TICameraParameters::KEY_GBCE)) != NULL) ) { // Configure GBCE only if the setting has changed since last time oldstr = mParams.get(TICameraParameters::KEY_GBCE); bool cmpRes = true; if ( NULL != oldstr ) { cmpRes = strcmp(valstr, oldstr) != 0; } else { cmpRes = true; } if( cmpRes ) { if (strcmp(valstr, ( const char * ) TICameraParameters::GBCE_ENABLE ) == 0) { setGBCE(OMXCameraAdapter::BRIGHTNESS_ON); } else if (strcmp(valstr, ( const char * ) TICameraParameters::GBCE_DISABLE ) == 0) { setGBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } else { setGBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } } } else if(mParams.get(TICameraParameters::KEY_GBCE) || mFirstTimeInit) { //Disable GBCE by default setGBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } if ( ( valstr = params.get(TICameraParameters::KEY_GLBCE) ) != NULL ) { // Configure GLBCE only if the setting has changed since last time oldstr = mParams.get(TICameraParameters::KEY_GLBCE); bool cmpRes = true; if ( NULL != oldstr ) { cmpRes = strcmp(valstr, oldstr) != 0; } else { cmpRes = true; } if( cmpRes ) { if (strcmp(valstr, ( const char * ) TICameraParameters::GLBCE_ENABLE ) == 0) { setGLBCE(OMXCameraAdapter::BRIGHTNESS_ON); } else if (strcmp(valstr, ( const char * ) TICameraParameters::GLBCE_DISABLE ) == 0) { setGLBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } else { setGLBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } } } else if(mParams.get(TICameraParameters::KEY_GLBCE) || mFirstTimeInit) { //Disable GLBCE by default setGLBCE(OMXCameraAdapter::BRIGHTNESS_OFF); } } else { ipp = OMXCameraAdapter::IPP_NONE; } if ( mIPP != ipp ) { mIPP = ipp; mOMXStateSwitch = true; } ///Set VNF Configuration bool vnfEnabled = false; if ( params.getInt(TICameraParameters::KEY_VNF) > 0 ) { CAMHAL_LOGDA("VNF Enabled"); vnfEnabled = true; } else { CAMHAL_LOGDA("VNF Disabled"); vnfEnabled = false; } if ( mVnfEnabled != vnfEnabled ) { mVnfEnabled = vnfEnabled; mOMXStateSwitch = true; } ///Set VSTAB Configuration bool vstabEnabled = false; valstr = params.get(CameraParameters::KEY_VIDEO_STABILIZATION); if (valstr && strcmp(valstr, CameraParameters::TRUE) == 0) { CAMHAL_LOGDA("VSTAB Enabled"); vstabEnabled = true; } else { CAMHAL_LOGDA("VSTAB Disabled"); vstabEnabled = false; } if ( mVstabEnabled != vstabEnabled ) { mVstabEnabled = vstabEnabled; mOMXStateSwitch = true; } //A work-around for a failing call to OMX flush buffers if ( ( capMode = OMXCameraAdapter::VIDEO_MODE ) && ( mVstabEnabled ) ) { mOMXStateSwitch = true; } //Set Auto Convergence Mode valstr = params.get((const char *) TICameraParameters::KEY_AUTOCONVERGENCE); if ( valstr != NULL ) { // Set ManualConvergence default value OMX_S32 manualconvergence = -30; if ( strcmp (valstr, (const char *) TICameraParameters::AUTOCONVERGENCE_MODE_DISABLE) == 0 ) { setAutoConvergence(OMX_TI_AutoConvergenceModeDisable, manualconvergence); } else if ( strcmp (valstr, (const char *) TICameraParameters::AUTOCONVERGENCE_MODE_FRAME) == 0 ) { setAutoConvergence(OMX_TI_AutoConvergenceModeFrame, manualconvergence); } else if ( strcmp (valstr, (const char *) TICameraParameters::AUTOCONVERGENCE_MODE_CENTER) == 0 ) { setAutoConvergence(OMX_TI_AutoConvergenceModeCenter, manualconvergence); } else if ( strcmp (valstr, (const char *) TICameraParameters::AUTOCONVERGENCE_MODE_FFT) == 0 ) { setAutoConvergence(OMX_TI_AutoConvergenceModeFocusFaceTouch, manualconvergence); } else if ( strcmp (valstr, (const char *) TICameraParameters::AUTOCONVERGENCE_MODE_MANUAL) == 0 ) { manualconvergence = (OMX_S32)params.getInt(TICameraParameters::KEY_MANUALCONVERGENCE_VALUES); setAutoConvergence(OMX_TI_AutoConvergenceModeManual, manualconvergence); } CAMHAL_LOGVB("AutoConvergenceMode %s, value = %d", valstr, (int) manualconvergence); } LOG_FUNCTION_NAME_EXIT; return ret; } // Get AutoConvergence status_t OMXCameraAdapter::getAutoConvergence(OMX_TI_AUTOCONVERGENCEMODETYPE *pACMode, OMX_S32 *pManualConverence) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_TI_CONFIG_CONVERGENCETYPE ACParams; ACParams.nSize = sizeof(OMX_TI_CONFIG_CONVERGENCETYPE); ACParams.nVersion = mLocalVersionParam; ACParams.nPortIndex = OMX_ALL; LOG_FUNCTION_NAME; eError = OMX_GetConfig(mCameraAdapterParameters.mHandleComp, (OMX_INDEXTYPE)OMX_TI_IndexConfigAutoConvergence, &ACParams); if ( eError != OMX_ErrorNone ) { CAMHAL_LOGEB("Error while getting AutoConvergence 0x%x", eError); ret = -EINVAL; } else { *pManualConverence = ACParams.nManualConverence; *pACMode = ACParams.eACMode; CAMHAL_LOGDA("AutoConvergence got successfully"); } LOG_FUNCTION_NAME_EXIT; return ret; } // Set AutoConvergence status_t OMXCameraAdapter::setAutoConvergence(OMX_TI_AUTOCONVERGENCEMODETYPE pACMode, OMX_S32 pManualConverence) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_TI_CONFIG_CONVERGENCETYPE ACParams; LOG_FUNCTION_NAME; ACParams.nSize = sizeof(OMX_TI_CONFIG_CONVERGENCETYPE); ACParams.nVersion = mLocalVersionParam; ACParams.nPortIndex = OMX_ALL; ACParams.nManualConverence = pManualConverence; ACParams.eACMode = pACMode; eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, (OMX_INDEXTYPE)OMX_TI_IndexConfigAutoConvergence, &ACParams); if ( eError != OMX_ErrorNone ) { CAMHAL_LOGEB("Error while setting AutoConvergence 0x%x", eError); ret = -EINVAL; } else { CAMHAL_LOGDA("AutoConvergence applied successfully"); } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::enableVideoNoiseFilter(bool enable) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_PARAM_VIDEONOISEFILTERTYPE vnfCfg; LOG_FUNCTION_NAME; if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&vnfCfg, OMX_PARAM_VIDEONOISEFILTERTYPE); if ( enable ) { CAMHAL_LOGDA("VNF is enabled"); vnfCfg.eMode = OMX_VideoNoiseFilterModeOn; } else { CAMHAL_LOGDA("VNF is disabled"); vnfCfg.eMode = OMX_VideoNoiseFilterModeOff; } eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexParamVideoNoiseFilter, &vnfCfg); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring video noise filter 0x%x", eError); ret = -1; } else { CAMHAL_LOGDA("Video noise filter is configured successfully"); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::enableVideoStabilization(bool enable) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_CONFIG_FRAMESTABTYPE frameStabCfg; LOG_FUNCTION_NAME; if ( NO_ERROR == ret ) { OMX_CONFIG_BOOLEANTYPE vstabp; OMX_INIT_STRUCT_PTR (&vstabp, OMX_CONFIG_BOOLEANTYPE); if(enable) { vstabp.bEnabled = OMX_TRUE; } else { vstabp.bEnabled = OMX_FALSE; } eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, (OMX_INDEXTYPE)OMX_IndexParamFrameStabilisation, &vstabp); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring video stabilization param 0x%x", eError); ret = -1; } else { CAMHAL_LOGDA("Video stabilization param configured successfully"); } } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&frameStabCfg, OMX_CONFIG_FRAMESTABTYPE); eError = OMX_GetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexConfigCommonFrameStabilisation, &frameStabCfg); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while getting video stabilization mode 0x%x", (unsigned int)eError); ret = -1; } CAMHAL_LOGDB("VSTAB Port Index = %d", (int)frameStabCfg.nPortIndex); frameStabCfg.nPortIndex = mCameraAdapterParameters.mPrevPortIndex; if ( enable ) { CAMHAL_LOGDA("VSTAB is enabled"); frameStabCfg.bStab = OMX_TRUE; } else { CAMHAL_LOGDA("VSTAB is disabled"); frameStabCfg.bStab = OMX_FALSE; } eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexConfigCommonFrameStabilisation, &frameStabCfg); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring video stabilization mode 0x%x", eError); ret = -1; } else { CAMHAL_LOGDA("Video stabilization mode configured successfully"); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setGBCE(OMXCameraAdapter::BrightnessMode mode) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_TI_CONFIG_LOCAL_AND_GLOBAL_BRIGHTNESSCONTRASTTYPE bControl; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&bControl, OMX_TI_CONFIG_LOCAL_AND_GLOBAL_BRIGHTNESSCONTRASTTYPE); bControl.nPortIndex = OMX_ALL; switch ( mode ) { case OMXCameraAdapter::BRIGHTNESS_ON: { bControl.eControl = OMX_TI_BceModeOn; break; } case OMXCameraAdapter::BRIGHTNESS_AUTO: { bControl.eControl = OMX_TI_BceModeAuto; break; } case OMXCameraAdapter::BRIGHTNESS_OFF: default: { bControl.eControl = OMX_TI_BceModeOff; break; } } eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_TI_IndexConfigGlobalBrightnessContrastEnhance, &bControl); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while setting GBCE 0x%x", eError); } else { CAMHAL_LOGDB("GBCE configured successfully 0x%x", mode); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setGLBCE(OMXCameraAdapter::BrightnessMode mode) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_TI_CONFIG_LOCAL_AND_GLOBAL_BRIGHTNESSCONTRASTTYPE bControl; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&bControl, OMX_TI_CONFIG_LOCAL_AND_GLOBAL_BRIGHTNESSCONTRASTTYPE); bControl.nPortIndex = OMX_ALL; switch ( mode ) { case OMXCameraAdapter::BRIGHTNESS_ON: { bControl.eControl = OMX_TI_BceModeOn; break; } case OMXCameraAdapter::BRIGHTNESS_AUTO: { bControl.eControl = OMX_TI_BceModeAuto; break; } case OMXCameraAdapter::BRIGHTNESS_OFF: default: { bControl.eControl = OMX_TI_BceModeOff; break; } } eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_TI_IndexConfigLocalBrightnessContrastEnhance, &bControl); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configure GLBCE 0x%x", eError); } else { CAMHAL_LOGDA("GLBCE configured successfully"); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setCaptureMode(OMXCameraAdapter::CaptureMode mode) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_CONFIG_CAMOPERATINGMODETYPE camMode; OMX_TI_PARAM_ZSLHISTORYLENTYPE zslHistoryLen; OMX_CONFIG_BOOLEANTYPE bCAC; LOG_FUNCTION_NAME; //ZSL have 4 buffers history by default OMX_INIT_STRUCT_PTR (&zslHistoryLen, OMX_TI_PARAM_ZSLHISTORYLENTYPE); zslHistoryLen.nHistoryLen = 4; //CAC is disabled by default OMX_INIT_STRUCT_PTR (&bCAC, OMX_CONFIG_BOOLEANTYPE); bCAC.bEnabled = OMX_FALSE; if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&camMode, OMX_CONFIG_CAMOPERATINGMODETYPE); if ( mSensorIndex == OMX_TI_StereoSensor ) { CAMHAL_LOGDA("Camera mode: STEREO"); camMode.eCamOperatingMode = OMX_CaptureStereoImageCapture; } else if ( OMXCameraAdapter::HIGH_SPEED == mode ) { CAMHAL_LOGDA("Camera mode: HIGH SPEED"); camMode.eCamOperatingMode = OMX_CaptureImageHighSpeedTemporalBracketing; } else if( OMXCameraAdapter::HIGH_QUALITY == mode ) { CAMHAL_LOGDA("Camera mode: HIGH QUALITY"); camMode.eCamOperatingMode = OMX_CaptureImageProfileBase; } else if( OMXCameraAdapter::HIGH_QUALITY_ZSL== mode ) { const char* valstr = NULL; CAMHAL_LOGDA("Camera mode: HIGH QUALITY_ZSL"); camMode.eCamOperatingMode = OMX_TI_CaptureImageProfileZeroShutterLag; valstr = mParams.get(TICameraParameters::KEY_RECORDING_HINT); if (!valstr || (valstr && (strcmp(valstr, "false")))) { zslHistoryLen.nHistoryLen = 5; } } else if( OMXCameraAdapter::VIDEO_MODE == mode ) { CAMHAL_LOGDA("Camera mode: VIDEO MODE"); camMode.eCamOperatingMode = OMX_CaptureVideo; } else { CAMHAL_LOGEA("Camera mode: INVALID mode passed!"); return BAD_VALUE; } if( NO_ERROR == ret ) { eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_TI_IndexParamZslHistoryLen, &zslHistoryLen); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring ZSL History len 0x%x", eError); // Don't return status for now // as high history values might lead // to errors on some platforms. // ret = ErrorUtils::omxToAndroidError(eError); } else { CAMHAL_LOGDA("ZSL History len configured successfully"); } } if( NO_ERROR == ret ) { eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexCameraOperatingMode, &camMode); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring camera mode 0x%x", eError); ret = ErrorUtils::omxToAndroidError(eError); } else { CAMHAL_LOGDA("Camera mode configured successfully"); } } if( NO_ERROR == ret ) { //Configure CAC eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexConfigChromaticAberrationCorrection, &bCAC); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring CAC 0x%x", eError); ret = ErrorUtils::omxToAndroidError(eError); } else { CAMHAL_LOGDA("CAC configured successfully"); } } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setLDC(OMXCameraAdapter::IPPMode mode) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_CONFIG_BOOLEANTYPE bOMX; LOG_FUNCTION_NAME; if ( OMX_StateLoaded != mComponentState ) { CAMHAL_LOGEA("OMX component is not in loaded state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&bOMX, OMX_CONFIG_BOOLEANTYPE); switch ( mode ) { case OMXCameraAdapter::IPP_LDCNSF: case OMXCameraAdapter::IPP_LDC: { bOMX.bEnabled = OMX_TRUE; break; } case OMXCameraAdapter::IPP_NONE: case OMXCameraAdapter::IPP_NSF: default: { bOMX.bEnabled = OMX_FALSE; break; } } CAMHAL_LOGVB("Configuring LDC mode 0x%x", bOMX.bEnabled); eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexParamLensDistortionCorrection, &bOMX); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEA("Error while setting LDC"); ret = -1; } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setNSF(OMXCameraAdapter::IPPMode mode) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_PARAM_ISONOISEFILTERTYPE nsf; LOG_FUNCTION_NAME; if ( OMX_StateLoaded != mComponentState ) { CAMHAL_LOGEA("OMX component is not in loaded state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&nsf, OMX_PARAM_ISONOISEFILTERTYPE); nsf.nPortIndex = OMX_ALL; switch ( mode ) { case OMXCameraAdapter::IPP_LDCNSF: case OMXCameraAdapter::IPP_NSF: { nsf.eMode = OMX_ISONoiseFilterModeOn; break; } case OMXCameraAdapter::IPP_LDC: case OMXCameraAdapter::IPP_NONE: default: { nsf.eMode = OMX_ISONoiseFilterModeOff; break; } } CAMHAL_LOGVB("Configuring NSF mode 0x%x", nsf.eMode); eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, (OMX_INDEXTYPE)OMX_IndexParamHighISONoiseFiler, &nsf); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEA("Error while setting NSF"); ret = -1; } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setImageQuality(unsigned int quality) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_IMAGE_PARAM_QFACTORTYPE jpegQualityConf; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT(jpegQualityConf, OMX_IMAGE_PARAM_QFACTORTYPE); jpegQualityConf.nQFactor = quality; jpegQualityConf.nPortIndex = mCameraAdapterParameters.mImagePortIndex; eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, OMX_IndexParamQFactor, &jpegQualityConf); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring jpeg Quality 0x%x", eError); ret = -1; } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setThumbnailParams(unsigned int width, unsigned int height, unsigned int quality) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_PARAM_THUMBNAILTYPE thumbConf; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -EINVAL; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT(thumbConf, OMX_PARAM_THUMBNAILTYPE); thumbConf.nPortIndex = mCameraAdapterParameters.mImagePortIndex; eError = OMX_GetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexParamThumbnail, &thumbConf); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while retrieving thumbnail size 0x%x", eError); ret = -1; } //CTS Requirement: width or height equal to zero should //result in absent EXIF thumbnail if ( ( 0 == width ) || ( 0 == height ) ) { thumbConf.nWidth = mThumbRes[0].width; thumbConf.nHeight = mThumbRes[0].height; thumbConf.eCompressionFormat = OMX_IMAGE_CodingUnused; } else { thumbConf.nWidth = width; thumbConf.nHeight = height; thumbConf.nQuality = quality; thumbConf.eCompressionFormat = OMX_IMAGE_CodingJPEG; } CAMHAL_LOGDB("Thumbnail width = %d, Thumbnail Height = %d", width, height); eError = OMX_SetParameter(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_IndexParamThumbnail, &thumbConf); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring thumbnail size 0x%x", eError); ret = -1; } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setAlgoPriority(AlgoPriority priority, Algorithm3A algo, bool enable) { OMX_ERRORTYPE eError = OMX_ErrorNone; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); return NO_INIT; } if ( FACE_PRIORITY == priority ) { if ( algo & WHITE_BALANCE_ALGO ) { if ( enable ) { mFacePriority.bAwbFaceEnable = OMX_TRUE; } else { mFacePriority.bAwbFaceEnable = OMX_FALSE; } } if ( algo & EXPOSURE_ALGO ) { if ( enable ) { mFacePriority.bAeFaceEnable = OMX_TRUE; } else { mFacePriority.bAeFaceEnable = OMX_FALSE; } } if ( algo & FOCUS_ALGO ) { if ( enable ) { mFacePriority.bAfFaceEnable = OMX_TRUE; } else { mFacePriority.bAfFaceEnable = OMX_FALSE; } } eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_TI_IndexConfigFacePriority3a, &mFacePriority); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring face priority 0x%x", eError); } else { CAMHAL_LOGDB("Face priority for algorithms set successfully 0x%x, 0x%x, 0x%x", mFacePriority.bAfFaceEnable, mFacePriority.bAeFaceEnable, mFacePriority.bAwbFaceEnable); } } else if ( REGION_PRIORITY == priority ) { if ( algo & WHITE_BALANCE_ALGO ) { if ( enable ) { mRegionPriority.bAwbRegionEnable= OMX_TRUE; } else { mRegionPriority.bAwbRegionEnable = OMX_FALSE; } } if ( algo & EXPOSURE_ALGO ) { if ( enable ) { mRegionPriority.bAeRegionEnable = OMX_TRUE; } else { mRegionPriority.bAeRegionEnable = OMX_FALSE; } } if ( algo & FOCUS_ALGO ) { if ( enable ) { mRegionPriority.bAfRegionEnable = OMX_TRUE; } else { mRegionPriority.bAfRegionEnable = OMX_FALSE; } } eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, ( OMX_INDEXTYPE ) OMX_TI_IndexConfigRegionPriority3a, &mRegionPriority); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring region priority 0x%x", eError); } else { CAMHAL_LOGDB("Region priority for algorithms set successfully 0x%x, 0x%x, 0x%x", mRegionPriority.bAfRegionEnable, mRegionPriority.bAeRegionEnable, mRegionPriority.bAwbRegionEnable); } } LOG_FUNCTION_NAME_EXIT; return ErrorUtils::omxToAndroidError(eError); } status_t OMXCameraAdapter::setPictureRotation(unsigned int degree) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_CONFIG_ROTATIONTYPE rotation; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -1; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT(rotation, OMX_CONFIG_ROTATIONTYPE); rotation.nRotation = degree; rotation.nPortIndex = mCameraAdapterParameters.mImagePortIndex; eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, OMX_IndexConfigCommonRotate, &rotation); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring rotation 0x%x", eError); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setSensorOrientation(unsigned int degree) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_CONFIG_ROTATIONTYPE sensorOrientation; int tmpHeight, tmpWidth; OMXCameraPortParameters *mPreviewData = &mCameraAdapterParameters.mCameraPortParams[mCameraAdapterParameters.mPrevPortIndex]; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -1; } /* Set Temproary Port resolution. * For resolution with height > 1008,resolution cannot be set without configuring orientation. * So we first set a temp resolution. We have used VGA */ tmpHeight = mPreviewData->mHeight; tmpWidth = mPreviewData->mWidth; mPreviewData->mWidth = 640; mPreviewData->mHeight = 480; ret = setFormat(OMX_CAMERA_PORT_VIDEO_OUT_PREVIEW, *mPreviewData); if ( ret != NO_ERROR ) { CAMHAL_LOGEB("setFormat() failed %d", ret); } /* Now set Required Orientation*/ if ( NO_ERROR == ret ) { OMX_INIT_STRUCT(sensorOrientation, OMX_CONFIG_ROTATIONTYPE); sensorOrientation.nPortIndex = mCameraAdapterParameters.mPrevPortIndex; eError = OMX_GetConfig(mCameraAdapterParameters.mHandleComp, OMX_IndexConfigCommonRotate, &sensorOrientation); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while Reading Sensor Orientation : 0x%x", eError); } CAMHAL_LOGVB(" Currently Sensor Orientation is set to : %d", ( unsigned int ) sensorOrientation.nRotation); sensorOrientation.nPortIndex = mCameraAdapterParameters.mPrevPortIndex; sensorOrientation.nRotation = degree; eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, OMX_IndexConfigCommonRotate, &sensorOrientation); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while configuring rotation 0x%x", eError); } CAMHAL_LOGVA(" Read the Parameters that are set"); eError = OMX_GetConfig(mCameraAdapterParameters.mHandleComp, OMX_IndexConfigCommonRotate, &sensorOrientation); if ( OMX_ErrorNone != eError ) { CAMHAL_LOGEB("Error while Reading Sensor Orientation : 0x%x", eError); } CAMHAL_LOGVB(" Currently Sensor Orientation is set to : %d", ( unsigned int ) sensorOrientation.nRotation); CAMHAL_LOGVB(" Sensor Configured for Port : %d", ( unsigned int ) sensorOrientation.nPortIndex); } /* Now set the required resolution as requested */ mPreviewData->mWidth = tmpWidth; mPreviewData->mHeight = tmpHeight; if ( NO_ERROR == ret ) { ret = setFormat (mCameraAdapterParameters.mPrevPortIndex, mCameraAdapterParameters.mCameraPortParams[mCameraAdapterParameters.mPrevPortIndex]); if ( NO_ERROR != ret ) { CAMHAL_LOGEB("setFormat() failed %d", ret); } } LOG_FUNCTION_NAME_EXIT; return ret; } status_t OMXCameraAdapter::setVFramerate(OMX_U32 minFrameRate, OMX_U32 maxFrameRate) { status_t ret = NO_ERROR; OMX_ERRORTYPE eError = OMX_ErrorNone; OMX_TI_CONFIG_VARFRMRANGETYPE vfr; OMXCameraPortParameters * mPreviewData = &mCameraAdapterParameters.mCameraPortParams[mCameraAdapterParameters.mPrevPortIndex]; LOG_FUNCTION_NAME; if ( OMX_StateInvalid == mComponentState ) { CAMHAL_LOGEA("OMX component is in invalid state"); ret = -EINVAL; } // The port framerate should never be smaller // than max framerate. if ( mPreviewData->mFrameRate < maxFrameRate ) { return NO_INIT; } if ( NO_ERROR == ret ) { OMX_INIT_STRUCT_PTR (&vfr, OMX_TI_CONFIG_VARFRMRANGETYPE); vfr.xMin = minFrameRate<<16; vfr.xMax = maxFrameRate<<16; eError = OMX_SetConfig(mCameraAdapterParameters.mHandleComp, (OMX_INDEXTYPE)OMX_TI_IndexConfigVarFrmRange, &vfr); if(OMX_ErrorNone != eError) { CAMHAL_LOGEB("Error while setting VFR min = %d, max = %d, error = 0x%x", ( unsigned int ) minFrameRate, ( unsigned int ) maxFrameRate, eError); ret = -1; } else { CAMHAL_LOGDB("VFR Configured Successfully [%d:%d]", ( unsigned int ) minFrameRate, ( unsigned int ) maxFrameRate); } } return ret; } };