Skip to content

Commit

Permalink
drm/radeon: also init GEM funcs in radeon_gem_prime_import_sg_table
Browse files Browse the repository at this point in the history
commit a25955b upstream.

Otherwise we will run into a NULL ptr deref.

Signed-off-by: Christian König <christian.koenig@amd.com>
Bug: https://bugzilla.kernel.org/show_bug.cgi?id=212137
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Cc: stable@vger.kernel.org # 5.11.x
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
  • Loading branch information
ChristianKoenigAMD authored and gregkh committed Mar 17, 2021
1 parent da27b6b commit 90da35d
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 2 deletions.
2 changes: 2 additions & 0 deletions drivers/gpu/drm/radeon/radeon.h
Expand Up @@ -575,6 +575,8 @@ struct radeon_gem {
struct list_head objects;
};

extern const struct drm_gem_object_funcs radeon_gem_object_funcs;

int radeon_gem_init(struct radeon_device *rdev);
void radeon_gem_fini(struct radeon_device *rdev);
int radeon_gem_object_create(struct radeon_device *rdev, unsigned long size,
Expand Down
4 changes: 2 additions & 2 deletions drivers/gpu/drm/radeon/radeon_gem.c
Expand Up @@ -43,7 +43,7 @@ struct sg_table *radeon_gem_prime_get_sg_table(struct drm_gem_object *obj);
int radeon_gem_prime_pin(struct drm_gem_object *obj);
void radeon_gem_prime_unpin(struct drm_gem_object *obj);

static const struct drm_gem_object_funcs radeon_gem_object_funcs;
const struct drm_gem_object_funcs radeon_gem_object_funcs;

static void radeon_gem_object_free(struct drm_gem_object *gobj)
{
Expand Down Expand Up @@ -227,7 +227,7 @@ static int radeon_gem_handle_lockup(struct radeon_device *rdev, int r)
return r;
}

static const struct drm_gem_object_funcs radeon_gem_object_funcs = {
const struct drm_gem_object_funcs radeon_gem_object_funcs = {
.free = radeon_gem_object_free,
.open = radeon_gem_object_open,
.close = radeon_gem_object_close,
Expand Down
2 changes: 2 additions & 0 deletions drivers/gpu/drm/radeon/radeon_prime.c
Expand Up @@ -56,6 +56,8 @@ struct drm_gem_object *radeon_gem_prime_import_sg_table(struct drm_device *dev,
if (ret)
return ERR_PTR(ret);

bo->tbo.base.funcs = &radeon_gem_object_funcs;

mutex_lock(&rdev->gem.mutex);
list_add_tail(&bo->list, &rdev->gem.objects);
mutex_unlock(&rdev->gem.mutex);
Expand Down

0 comments on commit 90da35d

Please sign in to comment.