drm/exynos: crtc: do not wait for the scanout completion
authorInki Dae <inki.dae@samsung.com>
Thu, 24 Dec 2015 08:24:35 +0000 (17:24 +0900)
committerInki Dae <daeinki@gmail.com>
Tue, 12 Jan 2016 15:16:38 +0000 (00:16 +0900)
This patch removes exynos_drm_crtc_complete_scanout function call
which makes sure for overlay data to be updated to real hardware
when drm driver is released.

With atomic modeset support, it doesn't need the funtion anymore
because atomic modeset interface makes sure that.

Signed-off-by: Inki Dae <inki.dae@samsung.com>
drivers/gpu/drm/exynos/exynos_drm_crtc.c
drivers/gpu/drm/exynos/exynos_drm_crtc.h
drivers/gpu/drm/exynos/exynos_drm_fb.c

index 5acaecba450a263984f42650bc185d02289f2c84..cd9498164dc1bd2b3836562acd14bd1bd5191429 100644 (file)
@@ -203,29 +203,6 @@ void exynos_drm_crtc_finish_update(struct exynos_drm_crtc *exynos_crtc,
        spin_unlock_irqrestore(&crtc->dev->event_lock, flags);
 }
 
-void exynos_drm_crtc_complete_scanout(struct drm_framebuffer *fb)
-{
-       struct exynos_drm_crtc *exynos_crtc;
-       struct drm_device *dev = fb->dev;
-       struct drm_crtc *crtc;
-
-       /*
-        * make sure that overlay data are updated to real hardware
-        * for all encoders.
-        */
-       list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
-               exynos_crtc = to_exynos_crtc(crtc);
-
-               /*
-                * wait for vblank interrupt
-                * - this makes sure that overlay data are updated to
-                *      real hardware.
-                */
-               if (exynos_crtc->ops->wait_for_vblank)
-                       exynos_crtc->ops->wait_for_vblank(exynos_crtc);
-       }
-}
-
 int exynos_drm_crtc_get_pipe_from_type(struct drm_device *drm_dev,
                                       enum exynos_drm_output_type out_type)
 {
index f9f365bd025765f998fcbc8c8cd205fcab92e929..6a581a8af4650fcf5f07ea3fa84c6b1dd5e81ad4 100644 (file)
@@ -28,7 +28,6 @@ void exynos_drm_crtc_disable_vblank(struct drm_device *dev, unsigned int pipe);
 void exynos_drm_crtc_wait_pending_update(struct exynos_drm_crtc *exynos_crtc);
 void exynos_drm_crtc_finish_update(struct exynos_drm_crtc *exynos_crtc,
                                   struct exynos_drm_plane *exynos_plane);
-void exynos_drm_crtc_complete_scanout(struct drm_framebuffer *fb);
 
 /* This function gets pipe value to crtc device matched with out_type. */
 int exynos_drm_crtc_get_pipe_from_type(struct drm_device *drm_dev,
index cbbb1a86e70ac2e0ab2dfb5860f4d5ae9bd766db..d614194644c814211ee069054a492fa1032c8fb0 100644 (file)
@@ -71,9 +71,6 @@ static void exynos_drm_fb_destroy(struct drm_framebuffer *fb)
        struct exynos_drm_fb *exynos_fb = to_exynos_fb(fb);
        unsigned int i;
 
-       /* make sure that overlay data are updated before relesing fb. */
-       exynos_drm_crtc_complete_scanout(fb);
-
        drm_framebuffer_cleanup(fb);
 
        for (i = 0; i < ARRAY_SIZE(exynos_fb->exynos_gem); i++) {