diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c | 18 | 
1 files changed, 16 insertions, 2 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c index 821f9491565b..6415d0d039e1 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vkms.c @@ -3,6 +3,7 @@  #include <drm/drm_atomic_helper.h>  #include <drm/drm_edid.h>  #include <drm/drm_simple_kms_helper.h> +#include <drm/drm_gem_framebuffer_helper.h>  #include <drm/drm_vblank.h>  #include "amdgpu.h" @@ -310,7 +311,13 @@ static int amdgpu_vkms_prepare_fb(struct drm_plane *plane,  		return 0;  	}  	afb = to_amdgpu_framebuffer(new_state->fb); -	obj = new_state->fb->obj[0]; + +	obj = drm_gem_fb_get_obj(new_state->fb, 0); +	if (!obj) { +		DRM_ERROR("Failed to get obj from framebuffer\n"); +		return -EINVAL; +	} +  	rbo = gem_to_amdgpu_bo(obj);  	adev = amdgpu_ttm_adev(rbo->tbo.bdev); @@ -364,12 +371,19 @@ static void amdgpu_vkms_cleanup_fb(struct drm_plane *plane,  				   struct drm_plane_state *old_state)  {  	struct amdgpu_bo *rbo; +	struct drm_gem_object *obj;  	int r;  	if (!old_state->fb)  		return; -	rbo = gem_to_amdgpu_bo(old_state->fb->obj[0]); +	obj = drm_gem_fb_get_obj(old_state->fb, 0); +	if (!obj) { +		DRM_ERROR("Failed to get obj from framebuffer\n"); +		return; +	} + +	rbo = gem_to_amdgpu_bo(obj);  	r = amdgpu_bo_reserve(rbo, false);  	if (unlikely(r)) {  		DRM_ERROR("failed to reserve rbo before unpin\n"); |