drm/qxl: use shadow bo directly
Pass the shadow bo to qxl_io_create_primary() instead of expecting qxl_io_create_primary to check bo->shadow. Set is_primary flag on the shadow bo. Move the is_primary tracking into qxl_io_create_primary() and qxl_io_destroy_primary() functions. That simplifies primary surface tracking and the workflow in qxl_primary_atomic_update(). Signed-off-by: Gerd Hoffmann <kraxel@redhat.com> Acked-by: Noralf Trønnes <noralf@tronnes.org> Link: http://patchwork.freedesktop.org/patch/msgid/20190118122020.27596-14-kraxel@redhat.com qxl_io_create/destroy_primary: primary_bo tracking [fixup]
This commit is contained in:
parent
166205444b
commit
4979904c62
|
@ -374,6 +374,8 @@ void qxl_io_flush_surfaces(struct qxl_device *qdev)
|
||||||
void qxl_io_destroy_primary(struct qxl_device *qdev)
|
void qxl_io_destroy_primary(struct qxl_device *qdev)
|
||||||
{
|
{
|
||||||
wait_for_io_cmd(qdev, 0, QXL_IO_DESTROY_PRIMARY_ASYNC);
|
wait_for_io_cmd(qdev, 0, QXL_IO_DESTROY_PRIMARY_ASYNC);
|
||||||
|
qdev->primary_bo->is_primary = false;
|
||||||
|
drm_gem_object_put_unlocked(&qdev->primary_bo->gem_base);
|
||||||
qdev->primary_bo = NULL;
|
qdev->primary_bo = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -390,11 +392,7 @@ void qxl_io_create_primary(struct qxl_device *qdev, struct qxl_bo *bo)
|
||||||
create->width = bo->surf.width;
|
create->width = bo->surf.width;
|
||||||
create->height = bo->surf.height;
|
create->height = bo->surf.height;
|
||||||
create->stride = bo->surf.stride;
|
create->stride = bo->surf.stride;
|
||||||
if (bo->shadow) {
|
create->mem = qxl_bo_physical_address(qdev, bo, 0);
|
||||||
create->mem = qxl_bo_physical_address(qdev, bo->shadow, 0);
|
|
||||||
} else {
|
|
||||||
create->mem = qxl_bo_physical_address(qdev, bo, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
DRM_DEBUG_DRIVER("mem = %llx, from %p\n", create->mem, bo->kptr);
|
DRM_DEBUG_DRIVER("mem = %llx, from %p\n", create->mem, bo->kptr);
|
||||||
|
|
||||||
|
@ -403,6 +401,8 @@ void qxl_io_create_primary(struct qxl_device *qdev, struct qxl_bo *bo)
|
||||||
|
|
||||||
wait_for_io_cmd(qdev, 0, QXL_IO_CREATE_PRIMARY_ASYNC);
|
wait_for_io_cmd(qdev, 0, QXL_IO_CREATE_PRIMARY_ASYNC);
|
||||||
qdev->primary_bo = bo;
|
qdev->primary_bo = bo;
|
||||||
|
qdev->primary_bo->is_primary = true;
|
||||||
|
drm_gem_object_get(&qdev->primary_bo->gem_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
void qxl_io_memslot_add(struct qxl_device *qdev, uint8_t id)
|
void qxl_io_memslot_add(struct qxl_device *qdev, uint8_t id)
|
||||||
|
|
|
@ -401,13 +401,15 @@ static int qxl_framebuffer_surface_dirty(struct drm_framebuffer *fb,
|
||||||
struct qxl_device *qdev = fb->dev->dev_private;
|
struct qxl_device *qdev = fb->dev->dev_private;
|
||||||
struct drm_clip_rect norect;
|
struct drm_clip_rect norect;
|
||||||
struct qxl_bo *qobj;
|
struct qxl_bo *qobj;
|
||||||
|
bool is_primary;
|
||||||
int inc = 1;
|
int inc = 1;
|
||||||
|
|
||||||
drm_modeset_lock_all(fb->dev);
|
drm_modeset_lock_all(fb->dev);
|
||||||
|
|
||||||
qobj = gem_to_qxl_bo(fb->obj[0]);
|
qobj = gem_to_qxl_bo(fb->obj[0]);
|
||||||
/* if we aren't primary surface ignore this */
|
/* if we aren't primary surface ignore this */
|
||||||
if (!qobj->is_primary) {
|
is_primary = qobj->shadow ? qobj->shadow->is_primary : qobj->is_primary;
|
||||||
|
if (!is_primary) {
|
||||||
drm_modeset_unlock_all(fb->dev);
|
drm_modeset_unlock_all(fb->dev);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -526,14 +528,13 @@ static void qxl_primary_atomic_update(struct drm_plane *plane,
|
||||||
{
|
{
|
||||||
struct qxl_device *qdev = plane->dev->dev_private;
|
struct qxl_device *qdev = plane->dev->dev_private;
|
||||||
struct qxl_bo *bo = gem_to_qxl_bo(plane->state->fb->obj[0]);
|
struct qxl_bo *bo = gem_to_qxl_bo(plane->state->fb->obj[0]);
|
||||||
struct qxl_bo *bo_old;
|
struct qxl_bo *bo_old, *primary;
|
||||||
struct drm_clip_rect norect = {
|
struct drm_clip_rect norect = {
|
||||||
.x1 = 0,
|
.x1 = 0,
|
||||||
.y1 = 0,
|
.y1 = 0,
|
||||||
.x2 = plane->state->fb->width,
|
.x2 = plane->state->fb->width,
|
||||||
.y2 = plane->state->fb->height
|
.y2 = plane->state->fb->height
|
||||||
};
|
};
|
||||||
bool same_shadow = false;
|
|
||||||
|
|
||||||
if (old_state->fb) {
|
if (old_state->fb) {
|
||||||
bo_old = gem_to_qxl_bo(old_state->fb->obj[0]);
|
bo_old = gem_to_qxl_bo(old_state->fb->obj[0]);
|
||||||
|
@ -541,26 +542,13 @@ static void qxl_primary_atomic_update(struct drm_plane *plane,
|
||||||
bo_old = NULL;
|
bo_old = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bo == bo_old)
|
primary = bo->shadow ? bo->shadow : bo;
|
||||||
return;
|
|
||||||
|
|
||||||
if (bo_old && bo_old->shadow && bo->shadow &&
|
if (!primary->is_primary) {
|
||||||
bo_old->shadow == bo->shadow) {
|
if (qdev->primary_bo)
|
||||||
same_shadow = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bo_old && bo_old->is_primary) {
|
|
||||||
if (!same_shadow)
|
|
||||||
qxl_io_destroy_primary(qdev);
|
qxl_io_destroy_primary(qdev);
|
||||||
bo_old->is_primary = false;
|
qxl_io_create_primary(qdev, primary);
|
||||||
}
|
qxl_primary_apply_cursor(plane);
|
||||||
|
|
||||||
if (!bo->is_primary) {
|
|
||||||
if (!same_shadow) {
|
|
||||||
qxl_io_create_primary(qdev, bo);
|
|
||||||
qxl_primary_apply_cursor(plane);
|
|
||||||
}
|
|
||||||
bo->is_primary = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
qxl_draw_dirty_fb(qdev, plane->state->fb, bo, 0, 0, &norect, 1, 1);
|
qxl_draw_dirty_fb(qdev, plane->state->fb, bo, 0, 0, &norect, 1, 1);
|
||||||
|
@ -756,6 +744,7 @@ static int qxl_plane_prepare_fb(struct drm_plane *plane,
|
||||||
qxl_bo_create(qdev, user_bo->gem_base.size,
|
qxl_bo_create(qdev, user_bo->gem_base.size,
|
||||||
true, true, QXL_GEM_DOMAIN_SURFACE, NULL,
|
true, true, QXL_GEM_DOMAIN_SURFACE, NULL,
|
||||||
&user_bo->shadow);
|
&user_bo->shadow);
|
||||||
|
user_bo->shadow->surf = user_bo->surf;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -784,7 +773,7 @@ static void qxl_plane_cleanup_fb(struct drm_plane *plane,
|
||||||
user_bo = gem_to_qxl_bo(obj);
|
user_bo = gem_to_qxl_bo(obj);
|
||||||
qxl_bo_unpin(user_bo);
|
qxl_bo_unpin(user_bo);
|
||||||
|
|
||||||
if (user_bo->shadow && !user_bo->is_primary) {
|
if (user_bo->shadow && !user_bo->shadow->is_primary) {
|
||||||
drm_gem_object_put_unlocked(&user_bo->shadow->gem_base);
|
drm_gem_object_put_unlocked(&user_bo->shadow->gem_base);
|
||||||
user_bo->shadow = NULL;
|
user_bo->shadow = NULL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue