blob: 7128d4ec073d689dbed1fc2bf09c49aca1f185aa [file] [log] [blame]
/*
**
** Copyright 2015, Samsung Electronics Co. LTD
**
** 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_TAG "SecCameraUtil"
#include <log/log.h>
#include "SecCameraUtil.h"
namespace android {
#ifdef SENSOR_NAME_GET_FROM_FILE
#define SENSOR_NAME_PATH_BACK "/sys/class/camera/rear/rear_sensorid"
#define SENSOR_NAME_PATH_BACK_1 "/sys/class/camera/rear/rear2_sensorid"
#define SENSOR_NAME_PATH_FRONT "/sys/class/camera/front/front_sensorid"
#endif
#define SENSOR_FW_PATH_BACK "/sys/class/camera/rear/rear_camfw"
#define SENSOR_FW_PATH_BACK_1 "/sys/class/camera/rear/rear2_camfw"
#define SENSOR_FW_PATH_FRONT "/sys/class/camera/front/front_camfw"
#ifdef SAMSUNG_OIS
#define OIS_EXIF_PATH_BACK "/sys/class/camera/ois/ois_exif"
#endif
#ifdef SAMSUNG_MTF
#define SENSOR_MTF_EXIF_PATH_BACK "/sys/class/camera/rear/rear_mtf_exif" /* Wide original aperture : F1.5 */
#define SENSOR_MTF2_EXIF_PATH_BACK "/sys/class/camera/rear/rear_mtf2_exif" /* Wide iris aperture : F2.4 */
#define SENSOR_MTF_EXIF_PATH_BACK_1 "/sys/class/camera/rear/rear2_mtf_exif" /* Tele */
#define SENSOR_MTF_EXIF_PATH_FRONT "/sys/class/camera/front/front_mtf_exif" /* Front */
#endif
#define SENSOR_ID_EXIF_PATH_BACK "/sys/class/camera/rear/rear_sensorid_exif"
#define SENSOR_ID_EXIF_PATH_BACK_1 "/sys/class/camera/rear/rear2_sensorid_exif"
#define SENSOR_ID_EXIF_PATH_FRONT "/sys/class/camera/front/front_sensorid_exif"
#ifdef SAMSUNG_FRONT_LCD_FLASH
#define HBM_DATA_MAX_LEN 4
#define HBM_BRIGHTNESS_DATA "255"
#define HBM_AUTO_BRIGHTNESS_DATA "12"
#define HBM_BACKUP_DEFUALT_STRING "LCDF"
#define HBM_AUTO_BRIGHTNESS_LEVEL_MAX "12"
#define HBM_BRIGHTNESS "/sys/class/backlight/panel/brightness"
#define HBM_AUTO_BRIGHTNESS "/sys/class/backlight/panel/auto_brightness"
#define HBM_AUTO_BRIGHTNESS_LEVEL "/sys/class/backlight/panel/auto_brightness_level"
#endif
#define SENSOR_AWB_MASTER_PATH_BACK "/sys/class/camera/rear/rear_awb_master"
#define SENSOR_AWB_MODULE_PATH_BACK "/sys/class/camera/rear/rear_awb_module"
#define BATTERY_TEMPERATURE "/sys/class/power_supply/battery/usb_temp"
int checkColorCodeProperty(void)
{
int ret_val = -1;
#ifdef SAMSUNG_READ_PRODUCT_COLOR_INFO
char propertyValue[PROPERTY_VALUE_MAX];
char colorInfo[2] = {0, 0};
property_get("ril.product_code", propertyValue, "0");
if (strcmp(propertyValue, "0") == 0) {
ALOGI("Invalid product_code");
} else if (strncmp(&propertyValue[8], "ZK", 2) == 0) {
ret_val = 0; /* BLACK */
} else if (strncmp(&propertyValue[8], "ZB", 2) == 0) {
ret_val = 1; /* BLUE */
} else if (strncmp(&propertyValue[8], "ZS", 2) == 0) {
ret_val = 2; /* SILVER(TITAN) */
} else if (strncmp(&propertyValue[8], "ZN", 2) == 0) {
ret_val = 3; /* BROWN(COPPER) */
} else if (strncmp(&propertyValue[8], "ZP", 2) == 0) {
ret_val = 4; /* PURPLE(LAVENDER) */
} else if (strncmp(&propertyValue[8], "ZD", 2) == 0) {
ret_val = 5; /* GOLD */
} else if (strncmp(&propertyValue[8], "ZI", 2) == 0
|| strncmp(&propertyValue[8], "DI", 2) == 0) {
ret_val = 6; /* PINK */
} else if (strncmp(&propertyValue[8], "ZA", 2) == 0
|| strncmp(&propertyValue[8], "ZV", 2) == 0
|| strncmp(&propertyValue[8], "ZR", 2) == 0) {
ret_val = 7; /* ORCHID */
} else {
ret_val = -1;
}
ALOGI("color info(%c%c) / %d", propertyValue[8], propertyValue[9], ret_val);
#endif
return ret_val;
}
int checkFpsProperty(void)
{
int fps = 0;
char propertyValue[PROPERTY_VALUE_MAX];
#ifdef USE_LIMITATION_FOR_THIRD_PARTY
property_get("sys.cameramode.cam_fps", propertyValue, "0");
fps = atoi(propertyValue);
ALOGI("INFO(%s[%d]): set cam_fps property (%d).", __FUNCTION__, __LINE__, fps);
#endif
return fps;
}
bool checkBinningProperty(void)
{
bool ret = false;
char propertyValue[PROPERTY_VALUE_MAX];
property_get("sys.cameramode.cam_binning", propertyValue, "0");
if (strcmp(propertyValue, "1") == 0) {
ret = true;
ALOGI("INFO(%s[%d]): set cam_binning property %d", __FUNCTION__, __LINE__, ret);
} else {
ret = false;
ALOGI("INFO(%s[%d]): set cam_binning property %d", __FUNCTION__, __LINE__, ret);
}
return ret;
}
bool checkCCProperty(void)
{
char propertyValue[PROPERTY_VALUE_MAX];
property_get("system.camera.CC.disable", propertyValue, "0");
if (strcmp(propertyValue, "0") != 0) {
return true;
} else {
property_get("system.camera.CC.fac.disable", propertyValue, "0");
if (strcmp(propertyValue, "1") == 0) {
property_set("system.camera.CC.fac.disable", "0");
return true;
}
}
return false;
}
#ifdef USE_PREVIEW_CROP_FOR_ROATAION
int checkRotationProperty(void)
{
char propertyValue[PROPERTY_VALUE_MAX];
property_get("system.camera.force.preview", propertyValue, "0");
ALOGI("INFO(%s[%d]): set rotation property %s", __FUNCTION__, __LINE__, propertyValue);
if (strcmp(propertyValue, "1") == 0) {
return FORCE_PREVIEW_WINDOW_SET_CROP;
} else if (strcmp(propertyValue, "2") == 0) {
return FORCE_PREVIEW_BUFFER_CROP_ROTATION_270;
}
return 0;
}
#endif
bool isEEprom(int cameraId)
{
bool ret = false;
if (cameraId == CAMERA_ID_BACK) {
#ifdef SAMSUNG_EEPROM_REAR
ret = SAMSUNG_EEPROM_REAR;
#else
ALOGI("INFO(%s[%d]): SAMSUNG_EEPROM_REAR is not defined", __FUNCTION__, __LINE__);
#endif
} else {
#ifdef SAMSUNG_EEPROM_FRONT
ret = SAMSUNG_EEPROM_FRONT;
#else
ALOGI("INFO(%s[%d]): SAMSUNG_EEPROM_FRONT is not defined", __FUNCTION__, __LINE__);
#endif
}
return ret;
}
bool isFastenAeStableSupported(int cameraId)
{
bool ret = false;
if (cameraId == CAMERA_ID_BACK) {
#ifdef USE_FASTEN_AE_STABLE
ret = USE_FASTEN_AE_STABLE;
#else
ALOGI("INFO(%s[%d]): USE_FASTEN_AE_STABLE is not defined", __FUNCTION__, __LINE__);
#endif
}
#ifdef USE_DUAL_CAMERA
else if (cameraId == CAMERA_ID_BACK_1) {
ret = USE_FASTEN_AE_STABLE;
}
#endif
else if (cameraId == CAMERA_ID_SECURE) {
ret = false; /* not use */
} else {
#ifdef USE_FASTEN_AE_STABLE_FRONT
ret = USE_FASTEN_AE_STABLE_FRONT;
#else
ALOGI("INFO(%s[%d]): USE_FASTEN_AE_STABLE_FRONT is not defined", __FUNCTION__, __LINE__);
#endif
}
return ret;
}
/* LLS_Deblur Capture */
bool isLDCapture(int cameraId)
{
bool ret = false;
if (cameraId == CAMERA_ID_BACK) {
#ifdef SAMSUNG_LDCAPTURE_REAR
ret = SAMSUNG_LDCAPTURE_REAR;
#else
ALOGI("INFO(%s[%d]): SAMSUNG_LDCAPTURE_REAR is not defined", __FUNCTION__, __LINE__);
#endif
} else {
#ifdef SAMSUNG_LDCAPTURE_FRONT
ret = SAMSUNG_LDCAPTURE_FRONT;
#else
ALOGI("INFO(%s[%d]): SAMSUNG_LDCAPTURE_FRONT is not defined", __FUNCTION__, __LINE__);
#endif
}
return ret;
}
void setMetaCtlPaf(struct camera2_shot_ext *shot_ext, enum camera2_paf_mode mode)
{
shot_ext->shot.uctl.isModeUd.paf_mode = mode;
}
void getMetaCtlPaf(struct camera2_shot_ext *shot_ext, enum camera2_paf_mode *mode)
{
*mode = shot_ext->shot.uctl.isModeUd.paf_mode;
}
void setMetaCtlRTHdr(struct camera2_shot_ext *shot_ext, enum camera2_wdr_mode mode)
{
shot_ext->shot.uctl.isModeUd.wdr_mode = mode;
}
void getMetaCtlRTHdr(struct camera2_shot_ext *shot_ext, enum camera2_wdr_mode *mode)
{
*mode = shot_ext->shot.uctl.isModeUd.wdr_mode;
}
#ifdef SAMSUNG_OIS
void setMetaCtlOIS(struct camera2_shot_ext *shot_ext, enum optical_stabilization_mode mode)
{
shot_ext->shot.ctl.lens.opticalStabilizationMode = mode;
}
void getMetaCtlOIS(struct camera2_shot_ext *shot_ext, enum optical_stabilization_mode *mode)
{
*mode = shot_ext->shot.ctl.lens.opticalStabilizationMode;
}
#endif
#ifdef SAMSUNG_MANUAL_FOCUS
void setMetaCtlFocusDistance(struct camera2_shot_ext *shot_ext, float distance)
{
shot_ext->shot.ctl.lens.focusDistance = distance;
}
void getMetaCtlFocusDistance(struct camera2_shot_ext *shot_ext, float *distance)
{
*distance = shot_ext->shot.ctl.lens.focusDistance;
}
#endif
#ifdef SAMSUNG_DOF
void setMetaCtlLensPos(struct camera2_shot_ext *shot_ext, int value)
{
if (value) {
shot_ext->shot.uctl.lensUd.pos = value;
shot_ext->shot.uctl.lensUd.posSize = 10;
shot_ext->shot.uctl.lensUd.direction = 0;
shot_ext->shot.uctl.lensUd.slewRate = 0;
} else {
shot_ext->shot.uctl.lensUd.pos = 0;
shot_ext->shot.uctl.lensUd.posSize = 0;
shot_ext->shot.uctl.lensUd.direction = 0;
shot_ext->shot.uctl.lensUd.slewRate = 0;
}
ALOGD("[DOF][%s][%d] lens pos : %d", __func__, __LINE__, value);
}
#endif
#ifdef SAMSUNG_HRM
void setMetaCtlHRM(struct camera2_shot_ext *shot_ext, int ir_data, int flicker_data, int status)
{
shot_ext->shot.uctl.aaUd.hrmInfo.ir_data = ir_data;
shot_ext->shot.uctl.aaUd.hrmInfo.flicker_data = flicker_data;
shot_ext->shot.uctl.aaUd.hrmInfo.status = status;
}
#endif
#ifdef SAMSUNG_LIGHT_IR
void setMetaCtlLight_IR(struct camera2_shot_ext *shot_ext, SensorListenerEvent_t data)
{
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_cdata = data.light_ir.light_white;
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_rdata = data.light_ir.light_red;
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_gdata = data.light_ir.light_green;
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_bdata = data.light_ir.light_blue;
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_gain = data.light_ir.ir_again;
shot_ext->shot.uctl.aaUd.illuminationInfo.visible_exptime = data.light_ir.ir_atime;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_north = data.light_ir.ir_data;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_south = data.light_ir.ir_data;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_east = data.light_ir.ir_data;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_west = data.light_ir.ir_data;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_gain = data.light_ir.ir_again;
shot_ext->shot.uctl.aaUd.illuminationInfo.ir_exptime = data.light_ir.ir_atime;
}
#endif
#ifdef SAMSUNG_GYRO
void setMetaCtlGyro(struct camera2_shot_ext *shot_ext, SensorListenerEvent_t data)
{
shot_ext->shot.uctl.aaUd.gyroInfo.x = data.gyro.x;
shot_ext->shot.uctl.aaUd.gyroInfo.y = data.gyro.y;
shot_ext->shot.uctl.aaUd.gyroInfo.z = data.gyro.z;
}
#endif
#ifdef SAMSUNG_ACCELEROMETER
void setMetaCtlAcceleration(struct camera2_shot_ext * shot_ext,SensorListenerEvent_t data)
{
shot_ext->shot.uctl.aaUd.accInfo.x = data.acceleration.x;
shot_ext->shot.uctl.aaUd.accInfo.y = data.acceleration.y;
shot_ext->shot.uctl.aaUd.accInfo.z = data.acceleration.z;
}
#endif
#ifdef SAMSUNG_PROX_FLICKER
void setMetaCtlProxFlicker(struct camera2_shot_ext * shot_ext, SensorListenerEvent_t data)
{
shot_ext->shot.uctl.aaUd.proximityInfo.flicker_data = data.proximity.flicker_data;
}
#endif
#ifdef SAMSUNG_SW_VDIS_USE_OIS
void setMetaCtlOISCoef(struct camera2_shot_ext *shot_ext, uint32_t data)
{
shot_ext->shot.uctl.lensUd.oisCoefVal = data;
}
#endif
void setMetaUctlFlashMode(struct camera2_shot_ext *shot_ext, enum camera_flash_mode mode)
{
shot_ext->shot.uctl.flashMode = mode;
}
void setMetaUctlOPMode(struct camera2_shot_ext *shot_ext, enum camera_op_mode mode)
{
shot_ext->shot.uctl.opMode = mode;
}
#ifdef SAMSUNG_OIS
char *getOisEXIFFromFile(struct ExynosCameraSensorInfoBase *info, int mode)
{
FILE *fp = NULL;
char ois_mode[5] = {0, };
char ois_data[OIS_EXIF_SIZE] = {0, };
fp = fopen(OIS_EXIF_PATH_BACK, "r");
if (fp == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* ois tag */
memset(info->ois_exif_info.ois_exif, 0, OIS_EXIF_SIZE);
memcpy(info->ois_exif_info.ois_exif, OIS_EXIF_TAG, sizeof(OIS_EXIF_TAG));
if (fgets(ois_data, sizeof(ois_data), fp) == NULL) {
ALOGE("ERR(%s[%d]):failed to read sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* ois data */
sprintf(ois_mode, "%d\n", mode);
strncat(ois_data, " ", 1);
strncat(ois_data, ois_mode, sizeof(ois_mode));
strncat(info->ois_exif_info.ois_exif, ois_data, OIS_EXIF_SIZE - (sizeof(OIS_EXIF_TAG) + 1));
ALOGD("DEBUG(%s[%d]):ois exif data : %s", __FUNCTION__, __LINE__, info->ois_exif_info.ois_exif);
err:
if (fp != NULL)
fclose(fp);
return info->ois_exif_info.ois_exif;
}
#endif
#ifdef SAMSUNG_MTF
char *getMTFdataEXIFFromFile(struct ExynosCameraSensorInfoBase *info, int camid, int aperture)
{
FILE *fp = NULL;
char mtf_data[MTF_EXIF_SIZE] = {0, };
if (camid == CAMERA_ID_BACK) {
if (aperture == 240) /* iris aperture : F2.4 */
fp = fopen(SENSOR_MTF2_EXIF_PATH_BACK, "r");
else /* original aperture : F1.5 */
fp = fopen(SENSOR_MTF_EXIF_PATH_BACK, "r");
}
#ifdef USE_DUAL_CAMERA
else if (camid == CAMERA_ID_BACK_1) {
fp = fopen(SENSOR_MTF_EXIF_PATH_BACK_1, "r");
}
#endif
else {
fp = fopen(SENSOR_MTF_EXIF_PATH_FRONT, "r");
}
if (fp == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* mtf tag */
memset(info->mtf_exif_info.mtf_exif, 0, MTF_EXIF_SIZE);
memcpy(info->mtf_exif_info.mtf_exif, MTF_EXIF_TAG, sizeof(MTF_EXIF_TAG));
if (fgets(mtf_data, sizeof(mtf_data), fp) == NULL) {
ALOGE("ERR(%s[%d]):failed to read sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* mtf data */
memcpy(&info->mtf_exif_info.mtf_exif[sizeof(MTF_EXIF_TAG)], mtf_data, MTF_EXIF_SIZE - (sizeof(MTF_EXIF_TAG) + 1));
err:
if (fp != NULL)
fclose(fp);
return info->mtf_exif_info.mtf_exif;
}
#endif
#ifdef SAMSUNG_FRONT_LCD_FLASH
void setHighBrightnessModeOfLCD(int on, char *prevHBM, char *prevAutoHBM) {
FILE *fp_hbm = NULL;
#ifndef UNSUPPORTED_AUTO_BRIGHTNESS_LCD_FLASH
FILE *fp_auto_hbm = NULL;
FILE *fp_auto_hbm_level = NULL;
char autoHbmLevel[HBM_DATA_MAX_LEN] = {0, };
#endif
fp_hbm = fopen(HBM_BRIGHTNESS, "w+");
if (fp_hbm == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry(%s)",
__FUNCTION__, __LINE__, HBM_BRIGHTNESS);
goto err;
}
#ifndef UNSUPPORTED_AUTO_BRIGHTNESS_LCD_FLASH
fp_auto_hbm = fopen(HBM_AUTO_BRIGHTNESS, "w+");
if (fp_auto_hbm == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry(%s)",
__FUNCTION__, __LINE__, HBM_AUTO_BRIGHTNESS);
goto err;
}
fp_auto_hbm_level = fopen(HBM_AUTO_BRIGHTNESS_LEVEL, "r");
if (fp_auto_hbm_level == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry(%s)",
__FUNCTION__, __LINE__, HBM_AUTO_BRIGHTNESS_LEVEL);
goto err;
}
#endif
if (on == 1) {
/* Check Backup data. -> Read Brightness. -> backup */
if (!strncmp(prevHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN)) {
memset(prevHBM, 0, HBM_DATA_MAX_LEN);
fread(prevHBM, sizeof(char), HBM_DATA_MAX_LEN, fp_hbm);
prevHBM[HBM_DATA_MAX_LEN - 1] = 0;
ALOGD("(%s[%d]):E:on(%d), HBM(%s)", __FUNCTION__, __LINE__, on, prevHBM);
} else {
ALOGE("(%s):BackUp Data isn't empty.", __FUNCTION__);
}
/* Write Brightness */
fwrite(HBM_BRIGHTNESS_DATA,
sizeof(char),
strlen(HBM_BRIGHTNESS_DATA),
fp_hbm);
#ifndef UNSUPPORTED_AUTO_BRIGHTNESS_LCD_FLASH
/* Read Auto Brightness Level*/
fread(autoHbmLevel, sizeof(char), 2, fp_auto_hbm_level);
ALOGD("(%s[%d]):E:on(%d),%d/autoHbmLevel(%c%c)",
__FUNCTION__, __LINE__, on,
strncmp(autoHbmLevel, HBM_AUTO_BRIGHTNESS_LEVEL_MAX, strlen(HBM_AUTO_BRIGHTNESS_LEVEL_MAX)),
autoHbmLevel[0], autoHbmLevel[1]);
/* Check Backup data. -> Read Auto Brightness. -> backup */
if (!strncmp(prevAutoHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN)) {
memset(prevAutoHBM, 0, HBM_DATA_MAX_LEN);
fread(prevAutoHBM, sizeof(char), HBM_DATA_MAX_LEN, fp_auto_hbm);
prevAutoHBM[HBM_DATA_MAX_LEN - 1] = 0;
ALOGD("(%s[%d]):E:on(%d), AutoHBM(%s)", __FUNCTION__, __LINE__, on, prevAutoHBM);
} else {
ALOGE("(%s):BackUp Data in't empty.", __FUNCTION__);
}
if (!strncmp(autoHbmLevel, HBM_AUTO_BRIGHTNESS_LEVEL_MAX,
strlen(HBM_AUTO_BRIGHTNESS_LEVEL_MAX))) {
/* Write Auto Brightness */
fwrite(HBM_AUTO_BRIGHTNESS_DATA,
sizeof(char),
strlen(HBM_AUTO_BRIGHTNESS_DATA),
fp_auto_hbm);
} else {
ALOGE("(%s)LCD isn't supported HBM Mode.(%d)",
__FUNCTION__, autoHbmLevel);
}
#endif
} else {
/* Check Data & Restore */
if (!strncmp(prevHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN)) {
ALOGE("(%s[%d]):backUp Data is wrong.(%c%c%c)",
__FUNCTION__, __LINE__,
prevHBM[0], prevHBM[1], prevHBM[2]);
} else {
fwrite(prevHBM, sizeof(char), HBM_DATA_MAX_LEN, fp_hbm);
}
#ifndef UNSUPPORTED_AUTO_BRIGHTNESS_LCD_FLASH
if (!strncmp(prevAutoHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN)) {
ALOGE("(%s[%d]):backUp Data is wrong.(%c%c)",
__FUNCTION__, __LINE__,
prevAutoHBM[0], prevAutoHBM[1]);
} else {
fwrite(prevAutoHBM, sizeof(char), HBM_DATA_MAX_LEN, fp_auto_hbm);
}
#endif
/* Set Default BackUp Data for defence*/
strncpy(prevHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN);
strncpy(prevAutoHBM, HBM_BACKUP_DEFUALT_STRING, HBM_DATA_MAX_LEN);
}
err:
#ifndef UNSUPPORTED_AUTO_BRIGHTNESS_LCD_FLASH
if (fp_auto_hbm_level) {
fclose(fp_auto_hbm_level);
}
if (fp_auto_hbm) {
fclose(fp_auto_hbm);
}
#endif
if (fp_hbm) {
fclose(fp_hbm);
}
}
#endif
#ifdef SAMSUNG_UNIPLUGIN
UNI_PLUGIN_CAMERA_TYPE getUniCameraType(int scenario, int cameraId)
{
UNI_PLUGIN_CAMERA_TYPE cameraType = UNI_PLUGIN_CAMERA_TYPE_END;
if (scenario == SCENARIO_DUAL_REAR_ZOOM || scenario == SCENARIO_DUAL_REAR_PORTRAIT) {
switch(cameraId) {
case CAMERA_ID_BACK:
cameraType = UNI_PLUGIN_CAMERA_TYPE_WIDE;
break;
case CAMERA_ID_BACK_1:
cameraType = UNI_PLUGIN_CAMERA_TYPE_TELE;
break;
default:
ALOGE("invalid cameraId(%d)", cameraId);
break;
}
} else {
switch(cameraId) {
case CAMERA_ID_BACK:
cameraType = UNI_PLUGIN_CAMERA_TYPE_REAR_0;
break;
case CAMERA_ID_BACK_1:
cameraType = UNI_PLUGIN_CAMERA_TYPE_REAR_1;
break;
case CAMERA_ID_FRONT:
cameraType = UNI_PLUGIN_CAMERA_TYPE_FRONT_0;
break;
case CAMERA_ID_FRONT_1:
cameraType = UNI_PLUGIN_CAMERA_TYPE_FRONT_1;
break;
default:
ALOGE("invalid cameraId(%d)", cameraId);
break;
}
}
return cameraType;
}
#endif
char *getSensorIdEXIFFromFile(struct ExynosCameraSensorInfoBase *info, int cameraId, int *realDataSize)
{
FILE *fp = NULL, *fp2 = NULL;
char sensor_id_data[SENSOR_ID_EXIF_SIZE] = {0, };
*realDataSize = SENSOR_ID_EXIF_SIZE - SENSOR_ID_EXIF_UNIT_SIZE;
if (cameraId == CAMERA_ID_BACK
#ifdef USE_DUAL_CAMERA
|| cameraId == CAMERA_ID_BACK_1
#endif
) {
fp = fopen(SENSOR_ID_EXIF_PATH_BACK, "r");
fp2 = fopen(SENSOR_ID_EXIF_PATH_BACK_1, "r");
} else {
fp = fopen(SENSOR_ID_EXIF_PATH_FRONT, "r");
}
if (fp == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* sensorID tag */
memset(info->sensor_id_exif_info.sensor_id_exif, 0, SENSOR_ID_EXIF_SIZE);
memcpy(info->sensor_id_exif_info.sensor_id_exif, SENSOR_ID_EXIF_TAG, sizeof(SENSOR_ID_EXIF_TAG));
if (fread(sensor_id_data, sizeof(char), SENSOR_ID_EXIF_UNIT_SIZE, fp) == 0) {
ALOGE("ERR(%s[%d]):failed to read sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* sensorID data */
memcpy(&info->sensor_id_exif_info.sensor_id_exif[strlen(SENSOR_ID_EXIF_TAG)], sensor_id_data, SENSOR_ID_EXIF_UNIT_SIZE);
if (fp2 != NULL) {
if (fread(sensor_id_data, sizeof(char), SENSOR_ID_EXIF_UNIT_SIZE, fp2) == 0) {
ALOGE("ERR(%s[%d]):failed to read sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
/* sensorID data for rear2 */
memcpy(&info->sensor_id_exif_info.sensor_id_exif[strlen(SENSOR_ID_EXIF_TAG) + SENSOR_ID_EXIF_UNIT_SIZE],
sensor_id_data, SENSOR_ID_EXIF_UNIT_SIZE);
*realDataSize = SENSOR_ID_EXIF_SIZE;
}
ALOGD("DEBUG(%s[%d]):sensorId exif data : %s", __FUNCTION__, __LINE__, info->sensor_id_exif_info.sensor_id_exif);
err:
if (fp != NULL)
fclose(fp);
if (fp2 != NULL)
fclose(fp2);
return info->sensor_id_exif_info.sensor_id_exif;
}
void getAWBCalibrationGain(int32_t *calibrationRG, int32_t *calibrationBG, float f_masterRG, float f_masterBG)
{
FILE *fp1 = NULL;
FILE *fp2 = NULL;
uint16_t awb_master_data[4] = {0, };
uint16_t awb_module_data[4] = {0, };
float moduleRG, moduleBG;
float masterRG, masterBG;
*calibrationRG = 1024;
*calibrationBG = 1024;
fp1 = fopen(SENSOR_AWB_MASTER_PATH_BACK, "r");
fp2 = fopen(SENSOR_AWB_MODULE_PATH_BACK, "r");
if (fp1 == NULL || fp2 == NULL) {
ALOGD("DEBUG(%s[%d]):failed to open sysfs entry", __FUNCTION__, __LINE__);
goto err;
} else {
if (fread(awb_master_data, sizeof(uint16_t), 4, fp1) == 0) {
ALOGD("DEBUG(%s[%d]):awb_master_data is NULL", __FUNCTION__, __LINE__);
goto err;
}
if (fread(awb_module_data, sizeof(uint16_t), 4, fp2) == 0) {
ALOGD("DEBUG(%s[%d]):awb_module_data is NULL", __FUNCTION__, __LINE__);
goto err;
}
}
if (awb_module_data[0] != 0 && awb_module_data[0] != 0xFFFF
&& awb_module_data[1] != 0 && awb_module_data[1] != 0xFFFF
&& awb_module_data[2] != 0 && awb_module_data[2] != 0xFFFF
&& awb_module_data[3] != 0 && awb_module_data[3] != 0xFFFF) {
if (awb_master_data[0] != 0 && awb_master_data[0] != 0xFFFF
&& awb_master_data[1] != 0 && awb_master_data[1] != 0xFFFF
&& awb_master_data[2] != 0 && awb_master_data[2] != 0xFFFF
&& awb_master_data[3] != 0 && awb_master_data[3] != 0xFFFF) {
masterRG = awb_master_data[0] / ((awb_master_data[1] + awb_master_data[2])/2.0f);
masterBG = awb_master_data[3] / ((awb_master_data[1] + awb_master_data[2])/2.0f);
} else if (f_masterRG != 0.0f && f_masterBG != 0.0f) {
masterRG = f_masterRG;
masterBG = f_masterBG;
} else {
ALOGD("DEBUG(%s[%d]): fail f_masterRG(%.1f) f_masterBG(%.1f)",
__FUNCTION__, __LINE__, f_masterRG, f_masterBG);
goto err;
}
moduleRG = awb_module_data[0] / ((awb_module_data[1] + awb_module_data[2])/2.0f);
moduleBG = awb_module_data[3] / ((awb_module_data[1] + awb_module_data[2])/2.0f);
*calibrationRG = (moduleRG/masterRG) * 1024;
*calibrationBG = (moduleBG/masterBG) * 1024;
}
err:
if (fp1 != NULL)
fclose(fp1);
if (fp2 != NULL)
fclose(fp2);
}
void storeSsrmCameraInfo(struct ssrmCameraInfo *info)
{
FILE *fp = NULL;
char buffer[100];
int ret = 0;
fp = fopen("/sys/class/camera/rear/ssrm_camera_info", "w+");
if (fp == NULL) {
ALOGE("ERR(%s[%d]):failed to open sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
sprintf(buffer, "%d %d %d %d %d %d %d", info->operation, info->cameraId, info->minFPS * 1000,
info->maxFPS * 1000, info->width, info->height, info->sensorOn);
ret = fwrite(buffer, sizeof(char), strlen(buffer), fp);
if (ret == 0) {
ALOGE("ERR(%s[%d]):failed to write sysfs entry", __FUNCTION__, __LINE__);
goto err;
}
err:
if (fp != NULL)
fclose(fp);
}
#ifdef LLS_CAPTURE
#define LLS_LEVEL_ZSL (0)
#define CALC_METADATA(x) ((x < 1)? 0 : x - 1)
int getLLS(struct camera2_shot_ext *shot)
{
int ret = LLS_LEVEL_ZSL;
const uint8_t flashMode = (uint8_t)CALC_METADATA(shot->shot.dm.flash.flashMode);
#ifdef RAWDUMP_CAPTURE
ret = LLS_LEVEL_ZSL;
return ret;
#endif
ret = shot->shot.dm.stats.vendor_LowLightMode;
ALOGV("FlashMode(%d), LowLightMode(%d)",
flashMode, shot->shot.dm.stats.vendor_LowLightMode);
return ret;
}
#endif
int readTemperature(void)
{
char buf[10];
int temperature = 0;
FILE *fp = NULL;
memset(buf, 0, sizeof(buf));
fp = fopen(BATTERY_TEMPERATURE, "r");
if (fp == NULL) {
ALOGE("failed to open temperature sysfs");
goto err;
}
if (fgets(buf, sizeof(buf), fp) == NULL) {
ALOGE("failed to read sysfs entry");
goto err;
}
temperature = atoi(buf);
ALOGD("read temperature complete. Temperature is : %d", temperature);
err:
if (fp != NULL)
fclose(fp);
return temperature;
}
}