drm/virtio: skip set_scanout if framebuffer didn't change

v2: also check src rect (Chia-I Wu).

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Reviewed-by: Chia-I Wu <olvaffe@gmail.com>
Link: http://patchwork.freedesktop.org/patch/msgid/20191212125346.8334-2-kraxel@redhat.com
This commit is contained in:
Gerd Hoffmann 2019-12-12 13:53:44 +01:00
parent 4ad7056a40
commit 3954ff10e0

View file

@ -151,6 +151,11 @@ static void virtio_gpu_primary_plane_update(struct drm_plane *plane,
if (bo->dumb) if (bo->dumb)
virtio_gpu_update_dumb_bo(vgdev, bo, plane->state); virtio_gpu_update_dumb_bo(vgdev, bo, plane->state);
if (plane->state->fb != old_state->fb ||
plane->state->src_w != old_state->src_w ||
plane->state->src_h != old_state->src_h ||
plane->state->src_x != old_state->src_x ||
plane->state->src_y != old_state->src_y) {
DRM_DEBUG("handle 0x%x, crtc %dx%d+%d+%d, src %dx%d+%d+%d\n", DRM_DEBUG("handle 0x%x, crtc %dx%d+%d+%d, src %dx%d+%d+%d\n",
bo->hw_res_handle, bo->hw_res_handle,
plane->state->crtc_w, plane->state->crtc_h, plane->state->crtc_w, plane->state->crtc_h,
@ -165,6 +170,8 @@ static void virtio_gpu_primary_plane_update(struct drm_plane *plane,
plane->state->src_h >> 16, plane->state->src_h >> 16,
plane->state->src_x >> 16, plane->state->src_x >> 16,
plane->state->src_y >> 16); plane->state->src_y >> 16);
}
virtio_gpu_cmd_resource_flush(vgdev, bo->hw_res_handle, virtio_gpu_cmd_resource_flush(vgdev, bo->hw_res_handle,
plane->state->src_x >> 16, plane->state->src_x >> 16,
plane->state->src_y >> 16, plane->state->src_y >> 16,