void omap3isp_ccdc_unregister_entities(struct isp_ccdc_device *ccdc)
 {
-       media_entity_cleanup(&ccdc->subdev.entity);
-
        v4l2_device_unregister_subdev(&ccdc->subdev);
        omap3isp_video_unregister(&ccdc->video_out);
 }
 {
        struct isp_ccdc_device *ccdc = &isp->isp_ccdc;
 
+       omap3isp_video_cleanup(&ccdc->video_out);
+       media_entity_cleanup(&ccdc->subdev.entity);
+
        /* Free LSC requests. As the CCDC is stopped there's no active request,
         * so only the pending request and the free queue need to be handled.
         */
 
  */
 void omap3isp_ccp2_unregister_entities(struct isp_ccp2_device *ccp2)
 {
-       media_entity_cleanup(&ccp2->subdev.entity);
-
        v4l2_device_unregister_subdev(&ccp2->subdev);
        omap3isp_video_unregister(&ccp2->video_in);
 }
 {
        struct isp_ccp2_device *ccp2 = &isp->isp_ccp2;
 
+       omap3isp_video_cleanup(&ccp2->video_in);
+       media_entity_cleanup(&ccp2->subdev.entity);
+
        regulator_put(ccp2->vdds_csib);
 }
 
 
 
 void omap3isp_csi2_unregister_entities(struct isp_csi2_device *csi2)
 {
-       media_entity_cleanup(&csi2->subdev.entity);
-
        v4l2_device_unregister_subdev(&csi2->subdev);
        omap3isp_video_unregister(&csi2->video_out);
 }
  */
 void omap3isp_csi2_cleanup(struct isp_device *isp)
 {
+       struct isp_csi2_device *csi2a = &isp->isp_csi2a;
+
+       omap3isp_video_cleanup(&csi2a->video_out);
+       media_entity_cleanup(&csi2a->subdev.entity);
 }
 
 /*
 
 {
        kfree(isp->isp_aewb.priv);
        kfree(isp->isp_aewb.recover_priv);
-       omap3isp_stat_free(&isp->isp_aewb);
+       omap3isp_stat_cleanup(&isp->isp_aewb);
 }
 
 {
        kfree(isp->isp_af.priv);
        kfree(isp->isp_af.recover_priv);
-       omap3isp_stat_free(&isp->isp_af);
+       omap3isp_stat_cleanup(&isp->isp_af);
 }
 
        if (HIST_USING_DMA(&isp->isp_hist))
                omap_free_dma(isp->isp_hist.dma_ch);
        kfree(isp->isp_hist.priv);
-       omap3isp_stat_free(&isp->isp_hist);
+       omap3isp_stat_cleanup(&isp->isp_hist);
 }
 
 
 void omap3isp_preview_unregister_entities(struct isp_prev_device *prev)
 {
-       media_entity_cleanup(&prev->subdev.entity);
-
        v4l2_device_unregister_subdev(&prev->subdev);
-       v4l2_ctrl_handler_free(&prev->ctrls);
        omap3isp_video_unregister(&prev->video_in);
        omap3isp_video_unregister(&prev->video_out);
 }
 
 void omap3isp_preview_cleanup(struct isp_device *isp)
 {
+       struct isp_prev_device *prev = &isp->isp_prev;
+
+       v4l2_ctrl_handler_free(&prev->ctrls);
+       omap3isp_video_cleanup(&prev->video_in);
+       omap3isp_video_cleanup(&prev->video_out);
+       media_entity_cleanup(&prev->subdev.entity);
 }
 
 /*
 
 
 void omap3isp_resizer_unregister_entities(struct isp_res_device *res)
 {
-       media_entity_cleanup(&res->subdev.entity);
-
        v4l2_device_unregister_subdev(&res->subdev);
        omap3isp_video_unregister(&res->video_in);
        omap3isp_video_unregister(&res->video_out);
 
 void omap3isp_resizer_cleanup(struct isp_device *isp)
 {
+       struct isp_res_device *res = &isp->isp_res;
+
+       omap3isp_video_cleanup(&res->video_in);
+       omap3isp_video_cleanup(&res->video_out);
+       media_entity_cleanup(&res->subdev.entity);
 }
 
 /*
 
 
 void omap3isp_stat_unregister_entities(struct ispstat *stat)
 {
-       media_entity_cleanup(&stat->subdev.entity);
        v4l2_device_unregister_subdev(&stat->subdev);
 }
 
        return isp_stat_init_entities(stat, name, sd_ops);
 }
 
-void omap3isp_stat_free(struct ispstat *stat)
+void omap3isp_stat_cleanup(struct ispstat *stat)
 {
+       media_entity_cleanup(&stat->subdev.entity);
        isp_stat_bufs_free(stat);
        kfree(stat->buf);
 }
 
                                     struct omap3isp_stat_data *data);
 int omap3isp_stat_init(struct ispstat *stat, const char *name,
                       const struct v4l2_subdev_ops *sd_ops);
-void omap3isp_stat_free(struct ispstat *stat);
+void omap3isp_stat_cleanup(struct ispstat *stat);
 int omap3isp_stat_subscribe_event(struct v4l2_subdev *subdev,
                                  struct v4l2_fh *fh,
                                  struct v4l2_event_subscription *sub);
 
        return 0;
 }
 
+void omap3isp_video_cleanup(struct isp_video *video)
+{
+       media_entity_cleanup(&video->video.entity);
+}
+
 int omap3isp_video_register(struct isp_video *video, struct v4l2_device *vdev)
 {
        int ret;
 
 void omap3isp_video_unregister(struct isp_video *video)
 {
-       if (video_is_registered(&video->video)) {
-               media_entity_cleanup(&video->video.entity);
+       if (video_is_registered(&video->video))
                video_unregister_device(&video->video);
-       }
 }
 
                                container_of(q, struct isp_video_fh, queue)
 
 int omap3isp_video_init(struct isp_video *video, const char *name);
+void omap3isp_video_cleanup(struct isp_video *video);
 int omap3isp_video_register(struct isp_video *video,
                            struct v4l2_device *vdev);
 void omap3isp_video_unregister(struct isp_video *video);