]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
drm: rcar-du: Track dma-buf fences
authorEmre Ucan <eucan@de.adit-jv.com>
Mon, 30 Apr 2018 12:02:04 +0000 (14:02 +0200)
committerLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Sat, 5 May 2018 14:12:46 +0000 (17:12 +0300)
We have to check dma-buf reservation objects of our framebuffers before
we use them. Otherwise, another driver might be writing on the same
buffer which we are using. This would cause visible tearing effects
on display.

We can use existing atomic helper functions to solve this problem.

Signed-off-by: Emre Ucan <eucan@de.adit-jv.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Reviewed-by: Daniel Vetter <daniel@ffwll.ch>
Signed-off-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
drivers/gpu/drm/rcar-du/rcar_du_vsp.c

index 4a01a99a46745c149b4d6a527e61b7c4ad9b1ec5..3badf02ab24aee33655584d61675b56b7934756b 100644 (file)
@@ -17,6 +17,7 @@
 #include <drm/drm_crtc_helper.h>
 #include <drm/drm_fb_cma_helper.h>
 #include <drm/drm_gem_cma_helper.h>
+#include <drm/drm_gem_framebuffer_helper.h>
 #include <drm/drm_plane_helper.h>
 
 #include <linux/bitops.h>
@@ -237,6 +238,10 @@ static int rcar_du_vsp_plane_prepare_fb(struct drm_plane *plane,
                }
        }
 
+       ret = drm_gem_fb_prepare_fb(plane, state);
+       if (ret)
+               goto fail;
+
        return 0;
 
 fail: