Skip to content

Commit b76b85b

Browse files
author
Thomas Zimmermann
committed
drm/vkms: Introduce GEM object functions
GEM object functions deprecate several similar callback interfaces in struct drm_driver. This patch replaces the per-driver callbacks with per-instance callbacks in vkms. Signed-off-by: Thomas Zimmermann <[email protected]> Reviewed-by: Melissa Wen <[email protected]> Acked-by: Christian König <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
1 parent c6069a0 commit b76b85b

File tree

2 files changed

+13
-8
lines changed

2 files changed

+13
-8
lines changed

drivers/gpu/drm/vkms/vkms_drv.c

Lines changed: 0 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -51,12 +51,6 @@ static const struct file_operations vkms_driver_fops = {
5151
.release = drm_release,
5252
};
5353

54-
static const struct vm_operations_struct vkms_gem_vm_ops = {
55-
.fault = vkms_gem_fault,
56-
.open = drm_gem_vm_open,
57-
.close = drm_gem_vm_close,
58-
};
59-
6054
static void vkms_release(struct drm_device *dev)
6155
{
6256
struct vkms_device *vkms = container_of(dev, struct vkms_device, drm);
@@ -98,8 +92,6 @@ static struct drm_driver vkms_driver = {
9892
.release = vkms_release,
9993
.fops = &vkms_driver_fops,
10094
.dumb_create = vkms_dumb_create,
101-
.gem_vm_ops = &vkms_gem_vm_ops,
102-
.gem_free_object_unlocked = vkms_gem_free_object,
10395
.prime_fd_to_handle = drm_gem_prime_fd_to_handle,
10496
.gem_prime_import_sg_table = vkms_prime_import_sg_table,
10597

drivers/gpu/drm/vkms/vkms_gem.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,17 @@
77

88
#include "vkms_drv.h"
99

10+
static const struct vm_operations_struct vkms_gem_vm_ops = {
11+
.fault = vkms_gem_fault,
12+
.open = drm_gem_vm_open,
13+
.close = drm_gem_vm_close,
14+
};
15+
16+
static const struct drm_gem_object_funcs vkms_gem_object_funcs = {
17+
.free = vkms_gem_free_object,
18+
.vm_ops = &vkms_gem_vm_ops,
19+
};
20+
1021
static struct vkms_gem_object *__vkms_gem_create(struct drm_device *dev,
1122
u64 size)
1223
{
@@ -17,6 +28,8 @@ static struct vkms_gem_object *__vkms_gem_create(struct drm_device *dev,
1728
if (!obj)
1829
return ERR_PTR(-ENOMEM);
1930

31+
obj->gem.funcs = &vkms_gem_object_funcs;
32+
2033
size = roundup(size, PAGE_SIZE);
2134
ret = drm_gem_object_init(dev, &obj->gem, size);
2235
if (ret) {

0 commit comments

Comments
 (0)