Skip to content

Commit 246cb7e

Browse files
author
Thomas Zimmermann
committed
drm/amdgpu: 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 amdgpu. The only exception is gem_prime_mmap, which is non-trivial to convert. v3: * remove amdgpu_object.c from patch (Christian) v2: * move object-function instance to amdgpu_gem.c (Christian) * set callbacks in amdgpu_gem_object_create() (Christian) Signed-off-by: Thomas Zimmermann <[email protected]> Reviewed-by: Christian König <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
1 parent a0d078d commit 246cb7e

File tree

3 files changed

+18
-16
lines changed

3 files changed

+18
-16
lines changed

drivers/gpu/drm/amd/amdgpu/amdgpu_drv.c

Lines changed: 0 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1497,19 +1497,13 @@ static struct drm_driver kms_driver = {
14971497
.lastclose = amdgpu_driver_lastclose_kms,
14981498
.irq_handler = amdgpu_irq_handler,
14991499
.ioctls = amdgpu_ioctls_kms,
1500-
.gem_free_object_unlocked = amdgpu_gem_object_free,
1501-
.gem_open_object = amdgpu_gem_object_open,
1502-
.gem_close_object = amdgpu_gem_object_close,
15031500
.dumb_create = amdgpu_mode_dumb_create,
15041501
.dumb_map_offset = amdgpu_mode_dumb_mmap,
15051502
.fops = &amdgpu_driver_kms_fops,
15061503

15071504
.prime_handle_to_fd = drm_gem_prime_handle_to_fd,
15081505
.prime_fd_to_handle = drm_gem_prime_fd_to_handle,
1509-
.gem_prime_export = amdgpu_gem_prime_export,
15101506
.gem_prime_import = amdgpu_gem_prime_import,
1511-
.gem_prime_vmap = amdgpu_gem_prime_vmap,
1512-
.gem_prime_vunmap = amdgpu_gem_prime_vunmap,
15131507
.gem_prime_mmap = amdgpu_gem_prime_mmap,
15141508

15151509
.name = DRIVER_NAME,

drivers/gpu/drm/amd/amdgpu/amdgpu_gem.c

Lines changed: 18 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -36,9 +36,12 @@
3636

3737
#include "amdgpu.h"
3838
#include "amdgpu_display.h"
39+
#include "amdgpu_dma_buf.h"
3940
#include "amdgpu_xgmi.h"
4041

41-
void amdgpu_gem_object_free(struct drm_gem_object *gobj)
42+
static const struct drm_gem_object_funcs amdgpu_gem_object_funcs;
43+
44+
static void amdgpu_gem_object_free(struct drm_gem_object *gobj)
4245
{
4346
struct amdgpu_bo *robj = gem_to_amdgpu_bo(gobj);
4447

@@ -87,6 +90,7 @@ int amdgpu_gem_object_create(struct amdgpu_device *adev, unsigned long size,
8790
return r;
8891
}
8992
*obj = &bo->tbo.base;
93+
(*obj)->funcs = &amdgpu_gem_object_funcs;
9094

9195
return 0;
9296
}
@@ -119,8 +123,8 @@ void amdgpu_gem_force_release(struct amdgpu_device *adev)
119123
* Call from drm_gem_handle_create which appear in both new and open ioctl
120124
* case.
121125
*/
122-
int amdgpu_gem_object_open(struct drm_gem_object *obj,
123-
struct drm_file *file_priv)
126+
static int amdgpu_gem_object_open(struct drm_gem_object *obj,
127+
struct drm_file *file_priv)
124128
{
125129
struct amdgpu_bo *abo = gem_to_amdgpu_bo(obj);
126130
struct amdgpu_device *adev = amdgpu_ttm_adev(abo->tbo.bdev);
@@ -152,8 +156,8 @@ int amdgpu_gem_object_open(struct drm_gem_object *obj,
152156
return 0;
153157
}
154158

155-
void amdgpu_gem_object_close(struct drm_gem_object *obj,
156-
struct drm_file *file_priv)
159+
static void amdgpu_gem_object_close(struct drm_gem_object *obj,
160+
struct drm_file *file_priv)
157161
{
158162
struct amdgpu_bo *bo = gem_to_amdgpu_bo(obj);
159163
struct amdgpu_device *adev = amdgpu_ttm_adev(bo->tbo.bdev);
@@ -211,6 +215,15 @@ void amdgpu_gem_object_close(struct drm_gem_object *obj,
211215
ttm_eu_backoff_reservation(&ticket, &list);
212216
}
213217

218+
static const struct drm_gem_object_funcs amdgpu_gem_object_funcs = {
219+
.free = amdgpu_gem_object_free,
220+
.open = amdgpu_gem_object_open,
221+
.close = amdgpu_gem_object_close,
222+
.export = amdgpu_gem_prime_export,
223+
.vmap = amdgpu_gem_prime_vmap,
224+
.vunmap = amdgpu_gem_prime_vunmap,
225+
};
226+
214227
/*
215228
* GEM ioctls.
216229
*/

drivers/gpu/drm/amd/amdgpu/amdgpu_gem.h

Lines changed: 0 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -33,11 +33,6 @@
3333
#define AMDGPU_GEM_DOMAIN_MAX 0x3
3434
#define gem_to_amdgpu_bo(gobj) container_of((gobj), struct amdgpu_bo, tbo.base)
3535

36-
void amdgpu_gem_object_free(struct drm_gem_object *obj);
37-
int amdgpu_gem_object_open(struct drm_gem_object *obj,
38-
struct drm_file *file_priv);
39-
void amdgpu_gem_object_close(struct drm_gem_object *obj,
40-
struct drm_file *file_priv);
4136
unsigned long amdgpu_gem_timeout(uint64_t timeout_ns);
4237

4338
/*

0 commit comments

Comments
 (0)