drm/qxl: use drm_gem_object_funcs callbacks
authorGerd Hoffmann <kraxel@redhat.com>
Wed, 4 Sep 2019 05:47:38 +0000 (07:47 +0200)
committerGerd Hoffmann <kraxel@redhat.com>
Tue, 10 Sep 2019 06:53:08 +0000 (08:53 +0200)
Switch qxl to use drm_gem_object_funcs callbacks
instead of drm_driver callbacks.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Acked-by: Thomas Zimmermann <tzimmermann@suse.de>
Link: http://patchwork.freedesktop.org/patch/msgid/20190904054740.20817-6-kraxel@redhat.com
drivers/gpu/drm/qxl/qxl_drv.c
drivers/gpu/drm/qxl/qxl_object.c

index 2b726a51a30227ed30d6f041e1c0a46a8601518e..996d428fa7e6f3ecde2d146d68e05e8ae6b1932d 100644 (file)
@@ -258,16 +258,8 @@ static struct drm_driver qxl_driver = {
 #endif
        .prime_handle_to_fd = drm_gem_prime_handle_to_fd,
        .prime_fd_to_handle = drm_gem_prime_fd_to_handle,
-       .gem_prime_pin = qxl_gem_prime_pin,
-       .gem_prime_unpin = qxl_gem_prime_unpin,
-       .gem_prime_get_sg_table = qxl_gem_prime_get_sg_table,
        .gem_prime_import_sg_table = qxl_gem_prime_import_sg_table,
-       .gem_prime_vmap = qxl_gem_prime_vmap,
-       .gem_prime_vunmap = qxl_gem_prime_vunmap,
        .gem_prime_mmap = qxl_gem_prime_mmap,
-       .gem_free_object_unlocked = qxl_gem_object_free,
-       .gem_open_object = qxl_gem_object_open,
-       .gem_close_object = qxl_gem_object_close,
        .fops = &qxl_fops,
        .ioctls = qxl_ioctls,
        .irq_handler = qxl_irq_handler,
index 548dfe6f3b2685028054ca576971b78ce0ec929f..29aab7b14513114477ffdf844c786e44b5492777 100644 (file)
@@ -77,6 +77,17 @@ void qxl_ttm_placement_from_domain(struct qxl_bo *qbo, u32 domain, bool pinned)
        }
 }
 
+static const struct drm_gem_object_funcs qxl_object_funcs = {
+       .free = qxl_gem_object_free,
+       .open = qxl_gem_object_open,
+       .close = qxl_gem_object_close,
+       .pin = qxl_gem_prime_pin,
+       .unpin = qxl_gem_prime_unpin,
+       .get_sg_table = qxl_gem_prime_get_sg_table,
+       .vmap = qxl_gem_prime_vmap,
+       .vunmap = qxl_gem_prime_vunmap,
+};
+
 int qxl_bo_create(struct qxl_device *qdev,
                  unsigned long size, bool kernel, bool pinned, u32 domain,
                  struct qxl_surface *surf,
@@ -100,6 +111,7 @@ int qxl_bo_create(struct qxl_device *qdev,
                kfree(bo);
                return r;
        }
+       bo->tbo.base.funcs = &qxl_object_funcs;
        bo->type = domain;
        bo->pin_count = pinned ? 1 : 0;
        bo->surface_id = 0;