return 0;
 }
 
+static int dynamic_bitrate_update(struct venus_inst *inst, u32 bitrate,
+                                 u32 layer_id)
+{
+       int ret = 0;
+
+       mutex_lock(&inst->lock);
+       if (inst->streamon_out && inst->streamon_cap) {
+               u32 ptype = HFI_PROPERTY_CONFIG_VENC_TARGET_BITRATE;
+               struct hfi_bitrate brate = { .bitrate = bitrate, .layer_id = layer_id };
+
+               ret = hfi_session_set_property(inst, ptype, &brate);
+       }
+       mutex_unlock(&inst->lock);
+
+       return ret;
+}
+
 static int venc_op_s_ctrl(struct v4l2_ctrl *ctrl)
 {
        struct venus_inst *inst = ctrl_to_inst(ctrl);
        struct venc_controls *ctr = &inst->controls.enc;
        struct hfi_enable en = { .enable = 1 };
-       struct hfi_bitrate brate;
        struct hfi_ltr_use ltr_use;
        struct hfi_ltr_mark ltr_mark;
        u32 bframes;
                break;
        case V4L2_CID_MPEG_VIDEO_BITRATE:
                ctr->bitrate = ctrl->val;
-               mutex_lock(&inst->lock);
-               if (inst->streamon_out && inst->streamon_cap) {
-                       ptype = HFI_PROPERTY_CONFIG_VENC_TARGET_BITRATE;
-                       brate.bitrate = ctr->bitrate;
-                       brate.layer_id = 0;
-
-                       ret = hfi_session_set_property(inst, ptype, &brate);
-                       if (ret) {
-                               mutex_unlock(&inst->lock);
-                               return ret;
-                       }
-               }
-               mutex_unlock(&inst->lock);
+               ret = dynamic_bitrate_update(inst, ctr->bitrate, 0);
+               if (ret)
+                       return ret;
                break;
        case V4L2_CID_MPEG_VIDEO_BITRATE_PEAK:
                ctr->bitrate_peak = ctrl->val;