]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/commitdiff
vc4_fkms: Apply firmware overscan offset to hardware cursor
authorpopcornmix <popcornmix@gmail.com>
Tue, 18 Apr 2017 20:43:46 +0000 (21:43 +0100)
committerKhalid Elmously <khalid.elmously@canonical.com>
Fri, 16 Feb 2018 22:11:47 +0000 (17:11 -0500)
drivers/gpu/drm/vc4/vc4_firmware_kms.c

index 185f9bd3c1b2d47d0c1fc5293db4199bd8963023..072f377b7423ee603d73ace2bf6d620f00204862 100644 (file)
@@ -39,6 +39,7 @@ struct vc4_crtc {
        void __iomem *regs;
 
        struct drm_pending_vblank_event *event;
+       u32 overscan[4];
 };
 
 static inline struct vc4_crtc *to_vc4_crtc(struct drm_crtc *crtc)
@@ -180,6 +181,7 @@ static void vc4_cursor_plane_atomic_update(struct drm_plane *plane,
                                           struct drm_plane_state *old_state)
 {
        struct vc4_dev *vc4 = to_vc4_dev(plane->dev);
+       struct vc4_crtc *vc4_crtc = to_vc4_crtc(plane->crtc);
        struct drm_plane_state *state = plane->state;
        struct drm_framebuffer *fb = state->fb;
        struct drm_gem_cma_object *bo = drm_fb_cma_get_gem_obj(fb, 0);
@@ -200,6 +202,12 @@ static void vc4_cursor_plane_atomic_update(struct drm_plane *plane,
                         bo->paddr + fb->offsets[0],
                         fb->pitches[0]);
 
+       /* add on the top/left offsets when overscan is active */
+       if (vc4_crtc) {
+               packet_state[1] += vc4_crtc->overscan[0];
+               packet_state[2] += vc4_crtc->overscan[1];
+       }
+
        ret = rpi_firmware_property(vc4->firmware,
                                    RPI_FIRMWARE_SET_CURSOR_STATE,
                                    &packet_state,
@@ -642,6 +650,15 @@ static int vc4_fkms_bind(struct device *dev, struct device *master, void *data)
        if (ret)
                goto err_destroy_connector;
 
+       ret = rpi_firmware_property(vc4->firmware,
+                                   RPI_FIRMWARE_FRAMEBUFFER_GET_OVERSCAN,
+                                   &vc4_crtc->overscan,
+                                   sizeof(vc4_crtc->overscan));
+       if (ret) {
+               DRM_ERROR("Failed to get overscan state: 0x%08x\n", vc4_crtc->overscan[0]);
+               memset(&vc4_crtc->overscan, 0, sizeof(vc4_crtc->overscan));
+       }
+
        platform_set_drvdata(pdev, vc4_crtc);
 
        return 0;