MM_ATTRS_VALID_TYPE_INT_ARRAY,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_camera_format,
},
{
MM_CAM_CAMERA_RECORDING_MOTION_RATE,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_camera_fps,
},
{
MM_CAM_CAMERA_DELAY_ATTR_SETTING,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_encoder_bitrate,
},
/* 40 */
{
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_encoder_bitrate,
},
{
MM_CAM_IMAGE_ENCODER_QUALITY,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_recording_max_limit,
},
{
MM_CAM_TARGET_TIME_LIMIT,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_recording_max_limit,
},
{
MM_CAM_TAG_ENABLE,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_IMAGE_DESCRIPTION,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_ORIENTATION,
MM_ATTRS_VALID_TYPE_INT_ARRAY,
{tag_orientation_values},
{ARRAY_SIZE(tag_orientation_values)},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_SOFTWARE,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
/* 70 */
{
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -360.0},
{.double_max = 360.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_LONGITUDE,
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -360.0},
{.double_max = 360.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_ALTITUDE,
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -999999.0},
{.double_max = 999999.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_STROBE_CONTROL,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_tag,
},
/* 90 */
{
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_GPS_DATE_STAMP,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_GPS_PROCESSING_METHOD,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_CAMERA_ROTATION,
NULL,
},
{
- MM_CAM_SOUND_STREAM_TYPE,
- "sound-stream-type",
- MMF_VALUE_TYPE_STRING,
- MM_ATTRS_FLAG_RW,
- {(void*)NULL},
- MM_ATTRS_VALID_TYPE_NONE,
- {0},
- {0},
- NULL,
- },
- {
MM_CAM_SOUND_STREAM_INDEX,
"sound-stream-index",
MMF_VALUE_TYPE_INT,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = -1},
{.int_max = _MMCAMCORDER_MAX_INT},
+ NULL,
+ },
+ {
+ MM_CAM_SOUND_STREAM_TYPE,
+ "sound-stream-type",
+ MMF_VALUE_TYPE_STRING,
+ MM_ATTRS_FLAG_RW,
+ {(void*)NULL},
+ MM_ATTRS_VALID_TYPE_NONE,
+ {0},
+ {0},
_mmcamcorder_commit_sound_stream_info,
},
{
{0},
{0},
NULL,
+ },
+ {
+ MM_CAM_GDBUS_CONNECTION,
+ "gdbus-connection",
+ MMF_VALUE_TYPE_DATA,
+ MM_ATTRS_FLAG_RW,
+ {(void*)NULL},
+ MM_ATTRS_VALID_TYPE_NONE,
+ {0},
+ {0},
+ NULL,
}
};
MMHandleType attrs = 0;
int ret = MM_ERROR_NONE;
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ va_list var_args_copy;
mmf_return_val_if_fail(handle, MM_ERROR_CAMCORDER_INVALID_ARGUMENT);
/*mmf_return_val_if_fail(err_attr_name, MM_ERROR_CAMCORDER_INVALID_ARGUMENT);*/
return MM_ERROR_CAMCORDER_CMD_IS_RUNNING;
}
+ /* copy var_args to keep original var_args */
+ va_copy(var_args_copy, var_args);
+
attrs = MMF_CAMCORDER_ATTRS(handle);
if (attrs) {
ret = __mmcamcorder_check_valid_pair(handle, err_attr_name, attribute_name, var_args);
if (ret == MM_ERROR_NONE) {
hcamcorder->error_code = MM_ERROR_NONE;
- ret = mm_attrs_set_valist(attrs, err_attr_name, attribute_name, var_args);
+ /* In 64bit environment, unexpected result is returned if var_args is used again. */
+ ret = mm_attrs_set_valist(attrs, err_attr_name, attribute_name, var_args_copy);
}
+ va_end(var_args_copy);
+
_MMCAMCORDER_UNLOCK_CMD(handle);
if (ret != MM_ERROR_NONE) {
MMHandleType attr = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
attr = MMF_CAMCORDER_ATTRS(handle);
mmf_return_val_if_fail(attr, FALSE);
bool _mmcamcorder_commit_capture_break_cont_shot(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
- int current_state = _mmcamcorder_get_state(handle);
- int ivalue = value->value.i_val;
-
- mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = 0;
+ int ivalue = 0;
+ const char *videosrc_name = NULL;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- GstCameraControl *control = NULL;
- type_element *VideosrcElement = NULL;
+ GstCameraControl *control = NULL;
+ type_element *VideosrcElement = NULL;
- const char *videosrc_name = NULL;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ ivalue = value->value.i_val;
_mmcamcorder_conf_get_element(handle, hcamcorder->conf_main,
CONFIGURE_CATEGORY_MAIN_VIDEO_INPUT,
{
int mode = MM_CAMCORDER_MODE_VIDEO_CAPTURE;
int current_state = MM_CAMCORDER_STATE_NONE;
-
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
mm_camcorder_get_attributes(handle, NULL, MMCAM_MODE, &mode, NULL);
{
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("shutter sound policy: %d", hcamcorder->shutter_sound_policy);
_MMCamcorderSubContext *sc = NULL;
bool bret = FALSE;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
+bool _mmcamcorder_commit_camera_format(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state > MM_CAMCORDER_STATE_READY) {
+ _mmcam_dbg_err("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+
bool _mmcamcorder_commit_camera_fps(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
MMCamAttrsInfo fps_info;
int resolution_width = 0;
int resolution_height = 0;
- int i;
- int ret;
+ int i = 0;
+ int ret = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state > MM_CAMCORDER_STATE_PREPARE) {
+ _mmcam_dbg_err("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ if (attr_idx == MM_CAM_CAMERA_FPS_AUTO)
+ return TRUE;
_mmcam_dbg_log("FPS(%d)", value->value.i_val);
}
_mmcam_dbg_err("FAILED : %d is not supported FPS", value->value.i_val);
+
return FALSE;
}
bool _mmcamcorder_commit_camera_recording_motion_rate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
-
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_warn("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("Resolution can't be changed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
int width = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Video Resolution can't be changed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
_mmcam_dbg_warn("Video Resolution %d [attr_idx %d] ",
bool _mmcamcorder_commit_camera_zoom(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- int zoom_level = value->value.i_val;
- int zoom_type;
+ int zoom_level = 0;
+ int zoom_type = 0;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
+ zoom_level = value->value.i_val;
+
_mmcam_dbg_log("(%d)", attr_idx);
current_state = _mmcamcorder_get_state(handle);
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_ptz_type(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_pan(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_tilt(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
{
MMHandleType attr = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
int mslVal;
int cur_focus_mode = 0;
int cur_focus_range = 0;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
attr = MMF_CAMCORDER_ATTRS(handle);
mmf_return_val_if_fail(attr, FALSE);
if (current_state < MM_CAMCORDER_STATE_NULL) {
_mmcam_dbg_log("Focus mode will be changed later.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_camera_af_scan_range(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
int msl_mode = MM_CAMCORDER_FOCUS_MODE_NONE;
int converted_mode = 0;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
if (current_state < MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_camera_af_touch_area(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
GstCameraControlRectType set_area = { 0, 0, 0, 0 };
MMCamAttrsInfo info_w;
MMCamAttrsInfo info_h;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
if (current_state < MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
ret = mm_camcorder_get_attributes(handle, NULL,
bool _mmcamcorder_commit_camera_capture_mode(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
GstCameraControl *control = NULL;
- int ivalue = value->value.i_val;
- int mslVal1 = 0, mslVal2 = 0;
- int newVal1 = 0, newVal2 = 0;
+ int ivalue = 0;
+ int mslVal1 = 0;
+ int mslVal2 = 0;
+ int newVal1 = 0;
+ int newVal2 = 0;
int exposure_type = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int scene_mode = MM_CAMCORDER_SCENE_MODE_NORMAL;
gboolean check_scene_mode = FALSE;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
current_state = _mmcamcorder_get_state(handle);
- if (current_state < MM_CAMCORDER_STATE_READY)
+ if (current_state < MM_CAMCORDER_STATE_READY) {
+ _mmcam_dbg_log("will be applied when preview starts");
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ ivalue = value->value.i_val;
if (attr_idx == MM_CAM_CAMERA_F_NUMBER) {
exposure_type = GST_CAMERA_CONTROL_F_NUMBER;
int mslVal = 0;
int newVal = 0;
int cur_value = 0;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
- mmf_return_val_if_fail(handle && value, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_anti_handshake(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
return TRUE;
} else if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Invaild state (state %d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
}
+bool _mmcamcorder_commit_encoder_bitrate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ int audio_enc = 0;
+ int bitrate = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ _MMCamcorderSubContext *sc = NULL;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ bitrate = value->value.i_val;
+
+ sc = MMF_CAMCORDER_SUBCONTEXT(handle);
+ if (!sc || !sc->encode_element) {
+ _mmcam_dbg_log("will be applied later - idx %d, bitrate %d", attr_idx, bitrate);
+ return TRUE;
+ }
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state >= MM_CAMCORDER_STATE_RECORDING) {
+ _mmcam_dbg_err("Can not set while RECORDING - attr idx %d", attr_idx);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ if (attr_idx == MM_CAM_AUDIO_ENCODER_BITRATE) {
+ mm_camcorder_get_attributes(handle, NULL, MMCAM_AUDIO_ENCODER, &audio_enc, NULL);
+
+ _mmcamcorder_set_encoder_bitrate(MM_CAMCORDER_ENCODER_TYPE_AUDIO, audio_enc,
+ bitrate, sc->encode_element[_MMCAMCORDER_ENCSINK_AENC].gst);
+ } else {
+ _mmcamcorder_set_encoder_bitrate(MM_CAMCORDER_ENCODER_TYPE_VIDEO, 0,
+ bitrate, sc->encode_element[_MMCAMCORDER_ENCSINK_VENC].gst);
+ }
+
+ return TRUE;
+}
+
+
bool _mmcamcorder_commit_camera_video_stabilization(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state < MM_CAMCORDER_STATE_READY) {
return TRUE;
} else if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Invaild state (state %d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_rotate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("rotate(%d)", value->value.i_val);
if (current_state > MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_err("camera rotation setting failed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
return _mmcamcorder_set_videosrc_rotation(handle, value->value.i_val);
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("NOT initialized. this will be applied later");
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
bool _mmcamcorder_commit_target_filename(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
_MMCamcorderSubContext *sc = NULL;
- const char * filename = NULL;
+ const char *filename = NULL;
int size = 0;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
+bool _mmcamcorder_commit_recording_max_limit(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state >= MM_CAMCORDER_STATE_RECORDING) {
+ _mmcam_dbg_err("Can not set while RECORDING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
+}
bool _mmcamcorder_commit_filter(MMHandleType handle, int attr_idx, const mmf_value_t *value)
int scene_mode = MM_CAMCORDER_SCENE_MODE_NORMAL;
gboolean check_scene_mode = FALSE;
- if (hcamcorder == NULL) {
- _mmcam_dbg_log("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_filter_scene_mode(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ int mslVal = 0;
+ int newVal = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- int mslVal = value->value.i_val;
- int newVal = _mmcamcorder_convert_msl_to_sensor(handle, MM_CAM_FILTER_SCENE_MODE, mslVal);
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
+ mslVal = value->value.i_val;
+ newVal = _mmcamcorder_convert_msl_to_sensor(handle, MM_CAM_FILTER_SCENE_MODE, mslVal);
+
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
_mmcam_dbg_log("skip set value %d", value->value.i_val);
if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_filter_flip(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_return_val_if_fail(handle && value, FALSE);
+
_mmcam_dbg_warn("Filter Flip(%d)", value->value.i_val);
+
return TRUE;
}
bool _mmcamcorder_commit_audio_input_route(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_return_val_if_fail(handle && value, FALSE);
+
_mmcam_dbg_log("Commit : Do nothing. this attr will be removed soon.");
+
return TRUE;
}
bool _mmcamcorder_commit_audio_disable(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_warn("Can NOT Disable AUDIO. invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
_mmcam_dbg_log("Disable AUDIO when Recording");
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
if (!strcmp(videosink_name, "xvimagesink") || !strcmp(videosink_name, "waylandsink")) {
_mmcam_dbg_log("Commit : display mode [%d]", value->value.i_val);
MMCAMCORDER_G_OBJECT_SET(sc->element[_MMCAMCORDER_VIDEOSINK_SINK].gst, "display-mode", value->value.i_val);
- return TRUE;
} else {
- _mmcam_dbg_warn("Commit : This element [%s] does not support display mode", videosink_name);
- return FALSE;
+ _mmcam_dbg_warn("[%s] does not support display mode, but no error", videosink_name);
}
+
+ return TRUE;
}
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
!strcmp(videosink_name, "evaspixmapsink") || !strcmp(videosink_name, "evasimagesink")) {
MMCAMCORDER_G_OBJECT_SET(sc->element[_MMCAMCORDER_VIDEOSINK_SINK].gst, "visible", value->value.i_val);
_mmcam_dbg_log("Set visible [%d] done.", value->value.i_val);
- return TRUE;
} else {
- _mmcam_dbg_warn("videosink[%s] does not support VISIBLE.", videosink_name);
- return FALSE;
+ _mmcam_dbg_warn("[%s] does not support VISIBLE, but no error", videosink_name);
}
+
+ return TRUE;
}
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
!strcmp(videosink_name, "evaspixmapsink") || !strcmp(videosink_name, "evasimagesink")) {
method = value->value.i_val;
MMCAMCORDER_G_OBJECT_SET(sc->element[_MMCAMCORDER_VIDEOSINK_SINK].gst, "display-geometry-method", method);
- return TRUE;
} else {
- _mmcam_dbg_warn("videosink[%s] does not support geometry method.", videosink_name);
- return FALSE;
+ _mmcam_dbg_warn("[%s] does not support geometry method, but no error", videosink_name);
}
+
+ return TRUE;
}
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(handle && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
int strobe_type, mslVal, newVal, cur_value;
int current_state = MM_CAMCORDER_STATE_NONE;
- if (hcamcorder == NULL) {
- _mmcam_dbg_err("NULL handle");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("invalid state[capturing]");
+ _mmcam_dbg_err("Can not set while CAPTURING");
hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
{
int ret = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("Commit : flip %d", value->value.i_val);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_err("Can not set camera FLIP horizontal at state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("Pipeline is not created yet. This will be set when create pipeline.");
{
int set_hdr_mode = MM_CAMCORDER_HDR_OFF;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/*_mmcam_dbg_log("Commit : HDR Capture %d", value->value.i_val);*/
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("can NOT set HDR capture at state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
int current_state = MM_CAMCORDER_STATE_NONE;
int preview_format = MM_PIXEL_FORMAT_NV12;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
_mmcam_dbg_log("Commit : encoded preview bitrate - %d", value->value.i_val);
int current_state = MM_CAMCORDER_STATE_NONE;
int preview_format = MM_PIXEL_FORMAT_NV12;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
_mmcam_dbg_log("Commit : encoded preview I-frame interval - %d", value->value.i_val);
int current_state = MM_CAMCORDER_STATE_NONE;
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- if (hcamcorder == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* state check */
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_NULL) {
_mmcam_dbg_log("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
new_pid = value->value.i_val;
- _mmcam_dbg_log("Commit : pid %d, current sound_focus_register %d, sound_focus_id %d",
- new_pid, hcamcorder->sound_focus_register, hcamcorder->sound_focus_id);
+ _mmcam_dbg_log("Commit : pid %d, current focus id %d, subscribe id %u",
+ new_pid, hcamcorder->sound_focus_id, hcamcorder->sound_focus_subscribe_id);
+
+ /* unregister sound focus and unsubscribe sound signal before set new one */
+ if (hcamcorder->sound_focus_id > 0) {
+ mm_sound_unregister_focus(hcamcorder->sound_focus_id);
+ _mmcam_dbg_log("unregister sound focus done");
+ hcamcorder->sound_focus_id = 0;
+ }
- /* unregister sound focus before set new one */
- if (hcamcorder->sound_focus_register && hcamcorder->sound_focus_id > 0) {
- if (MM_ERROR_NONE != mm_sound_unregister_focus(hcamcorder->sound_focus_id)) {
- _mmcam_dbg_err("mm_sound_unregister_focus[id %d] failed", hcamcorder->sound_focus_id);
+ if (hcamcorder->sound_focus_subscribe_id > 0) {
+ mm_sound_unsubscribe_signal(hcamcorder->sound_focus_subscribe_id);
+ _mmcam_dbg_log("unsubscribe sound signal done");
+ hcamcorder->sound_focus_subscribe_id = 0;
+ }
+
+ ret = _mm_session_util_read_information(new_pid, &hcamcorder->session_type, &hcamcorder->session_flags);
+ if (ret == MM_ERROR_NONE) {
+ if (hcamcorder->session_type == MM_SESSION_TYPE_REPLACED_BY_STREAM) {
+ hcamcorder->sound_focus_register = FALSE;
+ _mmcam_dbg_warn("no need to use sound focus internally");
} else {
- _mmcam_dbg_log("mm_sound_unregister_focus[id %d] done", hcamcorder->sound_focus_id);
+ ret = mm_sound_focus_get_id(&hcamcorder->sound_focus_id);
+ if (ret != MM_ERROR_NONE) {
+ _mmcam_dbg_err("mm_sound_focus_get_id failed");
+ hcamcorder->error_code = MM_ERROR_POLICY_BLOCKED;
+ return FALSE;
+ }
+
+ ret = mm_sound_register_focus_for_session(hcamcorder->sound_focus_id,
+ new_pid, "media", _mmcamcorder_sound_focus_cb, hcamcorder);
+ if (ret != MM_ERROR_NONE) {
+ _mmcam_dbg_err("mm_sound_register_focus_for_session failed 0x%x", ret);
+ hcamcorder->sound_focus_id = 0;
+ hcamcorder->error_code = MM_ERROR_POLICY_BLOCKED;
+ return FALSE;
+ }
+
+ hcamcorder->sound_focus_register = TRUE;
+
+ _mmcam_dbg_log("mm_sound_register_focus_for_session done - id %d, session type %d, flags 0x%x",
+ hcamcorder->sound_focus_id, hcamcorder->session_type, hcamcorder->session_flags);
}
} else {
- _mmcam_dbg_log("no need to unregister sound focus");
- }
+ hcamcorder->session_type = 0;
+ hcamcorder->session_flags = 0;
+ hcamcorder->sound_focus_register = TRUE;
- /* register sound focus */
- if (hcamcorder->sound_focus_register) {
- hcamcorder->sound_focus_id = 0;
- if (MM_ERROR_NONE != mm_sound_focus_get_id(&hcamcorder->sound_focus_id)) {
- _mmcam_dbg_err("mm_sound_focus_get_uniq failed");
- hcamcorder->error_code = MM_ERROR_POLICY_BLOCKED;
- return FALSE;
- }
+ _mmcam_dbg_warn("read session info failed. sound focus watch cb will be set.");
- ret = mm_sound_register_focus_for_session(hcamcorder->sound_focus_id,
- new_pid, "media", _mmcamcorder_sound_focus_cb, hcamcorder);
+ ret = mm_sound_subscribe_signal_for_daemon(MM_SOUND_SIGNAL_RELEASE_INTERNAL_FOCUS,
+ new_pid, &hcamcorder->sound_focus_subscribe_id,
+ (mm_sound_signal_callback)_mmcamcorder_sound_signal_callback, (void*)hcamcorder);
if (ret != MM_ERROR_NONE) {
- _mmcam_dbg_err("mm_sound_register_focus failed");
+ _mmcam_dbg_err("subscribe sound signal failed [0x%x]", ret);
hcamcorder->error_code = MM_ERROR_POLICY_BLOCKED;
return FALSE;
}
-
- _mmcam_dbg_log("mm_sound_register_focus done - id %d, session type %d, flags 0x%x",
- hcamcorder->sound_focus_id, hcamcorder->session_type, hcamcorder->session_flags);
- } else {
- _mmcam_dbg_log("no need to register sound focus");
}
return TRUE;
bool _mmcamcorder_commit_sound_stream_info(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ int stream_index = 0;
char *stream_type = NULL;
- int stream_type_len = 0;
_MMCamcorderSubContext *sc = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
+ mmf_return_val_if_fail(handle && value, FALSE);
+
+ stream_type = value->value.s_val;
+ if (!stream_type) {
+ _mmcam_dbg_err("NULL string");
return FALSE;
}
}
mm_camcorder_get_attributes(handle, NULL,
- MMCAM_SOUND_STREAM_TYPE, &stream_type, &stream_type_len,
+ MMCAM_SOUND_STREAM_INDEX, &stream_index,
NULL);
-
- if (stream_type == NULL) {
- _mmcam_dbg_err("stream type is not set");
+ if (stream_index < 0) {
+ _mmcam_dbg_err("invalid stream index %d", stream_index);
return FALSE;
}
- _mmcam_dbg_log("Commit : sound stream info - type %s", stream_type);
+ _mmcam_dbg_log("Commit : sound stream info - type %s, index %d", stream_type, stream_index);
+
+ return _mmcamcorder_set_sound_stream_info(sc->encode_element[_MMCAMCORDER_AUDIOSRC_SRC].gst, stream_type, stream_index);
+}
+
+
+bool _mmcamcorder_commit_tag(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
- return _mmcamcorder_set_sound_stream_info(sc->encode_element[_MMCAMCORDER_AUDIOSRC_SRC].gst, stream_type, value->value.i_val);
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
}