Commit 6dcba097 authored by Christian König's avatar Christian König Committed by Alex Deucher

drm/amdgpu: use GEM references instead of TTMs v2

Instead of a TTM reference grab a GEM reference whenever necessary.

v2: fix typo in amdgpu_bo_unref pointed out by Vitaly,
    initialize the GEM funcs for kernel allocations as well.
Signed-off-by: default avatarChristian König <christian.koenig@amd.com>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch> (v1)
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 87d749a6
...@@ -43,8 +43,6 @@ ...@@ -43,8 +43,6 @@
#include "amdgpu_hmm.h" #include "amdgpu_hmm.h"
#include "amdgpu_xgmi.h" #include "amdgpu_xgmi.h"
static const struct drm_gem_object_funcs amdgpu_gem_object_funcs;
static vm_fault_t amdgpu_gem_fault(struct vm_fault *vmf) static vm_fault_t amdgpu_gem_fault(struct vm_fault *vmf)
{ {
struct ttm_buffer_object *bo = vmf->vma->vm_private_data; struct ttm_buffer_object *bo = vmf->vma->vm_private_data;
...@@ -87,11 +85,11 @@ static const struct vm_operations_struct amdgpu_gem_vm_ops = { ...@@ -87,11 +85,11 @@ static const struct vm_operations_struct amdgpu_gem_vm_ops = {
static void amdgpu_gem_object_free(struct drm_gem_object *gobj) static void amdgpu_gem_object_free(struct drm_gem_object *gobj)
{ {
struct amdgpu_bo *robj = gem_to_amdgpu_bo(gobj); struct amdgpu_bo *aobj = gem_to_amdgpu_bo(gobj);
if (robj) { if (aobj) {
amdgpu_hmm_unregister(robj); amdgpu_hmm_unregister(aobj);
amdgpu_bo_unref(&robj); ttm_bo_put(&aobj->tbo);
} }
} }
...@@ -126,7 +124,6 @@ int amdgpu_gem_object_create(struct amdgpu_device *adev, unsigned long size, ...@@ -126,7 +124,6 @@ int amdgpu_gem_object_create(struct amdgpu_device *adev, unsigned long size,
bo = &ubo->bo; bo = &ubo->bo;
*obj = &bo->tbo.base; *obj = &bo->tbo.base;
(*obj)->funcs = &amdgpu_gem_object_funcs;
return 0; return 0;
} }
...@@ -295,7 +292,7 @@ static int amdgpu_gem_object_mmap(struct drm_gem_object *obj, struct vm_area_str ...@@ -295,7 +292,7 @@ static int amdgpu_gem_object_mmap(struct drm_gem_object *obj, struct vm_area_str
return drm_gem_ttm_mmap(obj, vma); return drm_gem_ttm_mmap(obj, vma);
} }
static const struct drm_gem_object_funcs amdgpu_gem_object_funcs = { const struct drm_gem_object_funcs amdgpu_gem_object_funcs = {
.free = amdgpu_gem_object_free, .free = amdgpu_gem_object_free,
.open = amdgpu_gem_object_open, .open = amdgpu_gem_object_open,
.close = amdgpu_gem_object_close, .close = amdgpu_gem_object_close,
......
...@@ -33,6 +33,8 @@ ...@@ -33,6 +33,8 @@
#define AMDGPU_GEM_DOMAIN_MAX 0x3 #define AMDGPU_GEM_DOMAIN_MAX 0x3
#define gem_to_amdgpu_bo(gobj) container_of((gobj), struct amdgpu_bo, tbo.base) #define gem_to_amdgpu_bo(gobj) container_of((gobj), struct amdgpu_bo, tbo.base)
extern const struct drm_gem_object_funcs amdgpu_gem_object_funcs;
unsigned long amdgpu_gem_timeout(uint64_t timeout_ns); unsigned long amdgpu_gem_timeout(uint64_t timeout_ns);
/* /*
......
...@@ -564,6 +564,7 @@ int amdgpu_bo_create(struct amdgpu_device *adev, ...@@ -564,6 +564,7 @@ int amdgpu_bo_create(struct amdgpu_device *adev,
if (bo == NULL) if (bo == NULL)
return -ENOMEM; return -ENOMEM;
drm_gem_private_object_init(adev_to_drm(adev), &bo->tbo.base, size); drm_gem_private_object_init(adev_to_drm(adev), &bo->tbo.base, size);
bo->tbo.base.funcs = &amdgpu_gem_object_funcs;
bo->vm_bo = NULL; bo->vm_bo = NULL;
bo->preferred_domains = bp->preferred_domain ? bp->preferred_domain : bo->preferred_domains = bp->preferred_domain ? bp->preferred_domain :
bp->domain; bp->domain;
...@@ -786,7 +787,7 @@ struct amdgpu_bo *amdgpu_bo_ref(struct amdgpu_bo *bo) ...@@ -786,7 +787,7 @@ struct amdgpu_bo *amdgpu_bo_ref(struct amdgpu_bo *bo)
if (bo == NULL) if (bo == NULL)
return NULL; return NULL;
ttm_bo_get(&bo->tbo); drm_gem_object_get(&bo->tbo.base);
return bo; return bo;
} }
...@@ -798,13 +799,10 @@ struct amdgpu_bo *amdgpu_bo_ref(struct amdgpu_bo *bo) ...@@ -798,13 +799,10 @@ struct amdgpu_bo *amdgpu_bo_ref(struct amdgpu_bo *bo)
*/ */
void amdgpu_bo_unref(struct amdgpu_bo **bo) void amdgpu_bo_unref(struct amdgpu_bo **bo)
{ {
struct ttm_buffer_object *tbo;
if ((*bo) == NULL) if ((*bo) == NULL)
return; return;
tbo = &((*bo)->tbo); drm_gem_object_put(&(*bo)->tbo.base);
ttm_bo_put(tbo);
*bo = NULL; *bo = NULL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment