+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;
+}
+
+