dbg("pid: %d, state: 0x%lx", task_pid_nr(current), fimc->state);
 
-       fimc_md_graph_lock(ve);
        mutex_lock(&fimc->lock);
 
        if (fimc_m2m_active(fimc))
        }
 
        if (v4l2_fh_is_singular_file(file)) {
+               fimc_md_graph_lock(ve);
+
                ret = fimc_pipeline_call(fimc, open, &fimc->pipeline,
                                         &fimc->vid_cap.ve.vdev.entity, true);
                if (ret == 0)
                        if (ret == 0)
                                vc->inh_sensor_ctrls = false;
                }
+               if (ret == 0)
+                       ve->vdev.entity.use_count++;
+
+               fimc_md_graph_unlock(ve);
 
                if (ret < 0) {
                        clear_bit(ST_CAPT_BUSY, &fimc->state);
                        pm_runtime_put_sync(&fimc->pdev->dev);
                        v4l2_fh_release(file);
-               } else {
-                       fimc->vid_cap.refcnt++;
                }
        }
 unlock:
        mutex_unlock(&fimc->lock);
-       fimc_md_graph_unlock(ve);
        return ret;
 }
 
 {
        struct fimc_dev *fimc = video_drvdata(file);
        struct fimc_vid_cap *vc = &fimc->vid_cap;
+       bool close = v4l2_fh_is_singular_file(file);
        int ret;
 
        dbg("pid: %d, state: 0x%lx", task_pid_nr(current), fimc->state);
 
        mutex_lock(&fimc->lock);
 
-       if (v4l2_fh_is_singular_file(file)) {
-               if (vc->streaming) {
-                       media_entity_pipeline_stop(&vc->ve.vdev.entity);
-                       vc->streaming = false;
-               }
+       if (close && vc->streaming) {
+               media_entity_pipeline_stop(&vc->ve.vdev.entity);
+               vc->streaming = false;
+       }
+
+       ret = vb2_fop_release(file);
+
+       if (close) {
                clear_bit(ST_CAPT_BUSY, &fimc->state);
                fimc_stop_capture(fimc, false);
                fimc_pipeline_call(fimc, close, &fimc->pipeline);
                clear_bit(ST_CAPT_SUSPENDED, &fimc->state);
-               fimc->vid_cap.refcnt--;
+
+               fimc_md_graph_lock(&vc->ve);
+               vc->ve.vdev.entity.use_count--;
+               fimc_md_graph_unlock(&vc->ve);
        }
 
        pm_runtime_put(&fimc->pdev->dev);
-       ret = vb2_fop_release(file);
        mutex_unlock(&fimc->lock);
 
        return ret;
        struct fimc_fmt *ffmt = NULL;
        int ret = 0;
 
-       fimc_md_graph_lock(ve);
-       mutex_lock(&fimc->lock);
-
        if (fimc_jpeg_fourcc(pix->pixelformat)) {
                fimc_capture_try_format(ctx, &pix->width, &pix->height,
                                        NULL, &pix->pixelformat,
        ffmt = fimc_capture_try_format(ctx, &pix->width, &pix->height,
                                       NULL, &pix->pixelformat,
                                       FIMC_SD_PAD_SOURCE);
-       if (!ffmt) {
-               ret = -EINVAL;
-               goto unlock;
-       }
+       if (!ffmt)
+               return -EINVAL;
 
        if (!fimc->vid_cap.user_subdev_api) {
                mf.width = pix->width;
                mf.height = pix->height;
                mf.code = ffmt->mbus_code;
+
+               fimc_md_graph_lock(ve);
                fimc_pipeline_try_format(ctx, &mf, &ffmt, false);
+               fimc_md_graph_unlock(ve);
+
                pix->width = mf.width;
                pix->height = mf.height;
                if (ffmt)
        if (ffmt->flags & FMT_FLAGS_COMPRESSED)
                fimc_get_sensor_frame_desc(fimc->pipeline.subdevs[IDX_SENSOR],
                                        pix->plane_fmt, ffmt->memplanes, true);
-unlock:
-       mutex_unlock(&fimc->lock);
-       fimc_md_graph_unlock(ve);
 
        return ret;
 }
        int ret;
 
        fimc_md_graph_lock(&fimc->vid_cap.ve);
-       mutex_lock(&fimc->lock);
        /*
         * The graph is walked within __fimc_capture_set_format() to set
         * the format at subdevs thus the graph mutex needs to be held at
-        * this point and acquired before the video mutex, to avoid  AB-BA
-        * deadlock when fimc_md_link_notify() is called by other thread.
-        * Ideally the graph walking and setting format at the whole pipeline
-        * should be removed from this driver and handled in userspace only.
+        * this point.
         */
        ret = __fimc_capture_set_format(fimc, f);
 
        fimc_md_graph_unlock(&fimc->vid_cap.ve);
-       mutex_unlock(&fimc->lock);
        return ret;
 }
 
        ret = fimc_ctrls_create(ctx);
        if (ret)
                goto err_me_cleanup;
-       /*
-        * For proper order of acquiring/releasing the video
-        * and the graph mutex.
-        */
-       v4l2_disable_ioctl_locking(vfd, VIDIOC_TRY_FMT);
-       v4l2_disable_ioctl_locking(vfd, VIDIOC_S_FMT);
 
        ret = video_register_device(vfd, VFL_TYPE_GRABBER, -1);
        if (ret)
 
        struct media_entity *me = &fimc->ve.vdev.entity;
        int ret;
 
-       mutex_lock(&me->parent->graph_mutex);
-
        mutex_lock(&fimc->lock);
        if (atomic_read(&fimc->out_path) != FIMC_IO_DMA) {
                ret = -EBUSY;
            atomic_read(&fimc->out_path) != FIMC_IO_DMA)
                goto unlock;
 
+       mutex_lock(&me->parent->graph_mutex);
+
        ret = fimc_pipeline_call(fimc, open, &fimc->pipeline,
                                                me, true);
+
+       /* Mark video pipeline ending at this video node as in use. */
+       if (ret == 0)
+               me->use_count++;
+
+       mutex_unlock(&me->parent->graph_mutex);
+
        if (!ret) {
                fimc_lite_clear_event_counters(fimc);
-               fimc->ref_count++;
                goto unlock;
        }
 
        clear_bit(ST_FLITE_IN_USE, &fimc->state);
 unlock:
        mutex_unlock(&fimc->lock);
-       mutex_unlock(&me->parent->graph_mutex);
        return ret;
 }
 
 static int fimc_lite_release(struct file *file)
 {
        struct fimc_lite *fimc = video_drvdata(file);
+       struct media_entity *entity = &fimc->ve.vdev.entity;
 
        mutex_lock(&fimc->lock);
 
        if (v4l2_fh_is_singular_file(file) &&
            atomic_read(&fimc->out_path) == FIMC_IO_DMA) {
                if (fimc->streaming) {
-                       media_entity_pipeline_stop(&fimc->ve.vdev.entity);
+                       media_entity_pipeline_stop(entity);
                        fimc->streaming = false;
                }
                clear_bit(ST_FLITE_IN_USE, &fimc->state);
                fimc_lite_stop_capture(fimc, false);
                fimc_pipeline_call(fimc, close, &fimc->pipeline);
-               fimc->ref_count--;
+               mutex_lock(&entity->parent->graph_mutex);
+               entity->use_count--;
+               mutex_unlock(&entity->parent->graph_mutex);
        }
 
        vb2_fop_release(file);
                 __func__, remote->entity->name, local->entity->name,
                 flags, fimc->source_subdev_grp_id);
 
-       mutex_lock(&fimc->lock);
-
        switch (local->index) {
        case FLITE_SD_PAD_SINK:
                if (remote_ent_type != MEDIA_ENT_T_V4L2_SUBDEV) {
        }
        mb();
 
-       mutex_unlock(&fimc->lock);
        return ret;
 }
 
 
        struct fimc_dev *fimc = NULL;
        struct fimc_pipeline *pipeline;
        struct v4l2_subdev *sd;
-       struct mutex *lock;
        int i, ret = 0;
-       int ref_count;
 
        if (media_entity_type(sink->entity) != MEDIA_ENT_T_V4L2_SUBDEV)
                return 0;
                if (WARN_ON(fimc_lite == NULL))
                        return 0;
                pipeline = &fimc_lite->pipeline;
-               lock = &fimc_lite->lock;
                break;
        case GRP_ID_FIMC:
                fimc = v4l2_get_subdevdata(sd);
                if (WARN_ON(fimc == NULL))
                        return 0;
                pipeline = &fimc->pipeline;
-               lock = &fimc->lock;
                break;
        default:
                return 0;
        }
 
-       mutex_lock(lock);
-       ref_count = fimc ? fimc->vid_cap.refcnt : fimc_lite->ref_count;
-
        if (!(flags & MEDIA_LNK_FL_ENABLED)) {
-               if (ref_count > 0) {
+               if (sink->entity->use_count > 0) {
                        ret = __fimc_pipeline_close(pipeline);
                }
                for (i = 0; i < IDX_MAX; i++)
                        pipeline->subdevs[i] = NULL;
-       } else if (ref_count > 0) {
+       } else if (sink->entity->use_count > 0) {
                /*
                 * Link activation. Enable power of pipeline elements only if
                 * the pipeline is already in use, i.e. its video node is open.
                                           source->entity, true);
        }
 
-       mutex_unlock(lock);
        return ret ? -EPIPE : ret;
 }