diff options
Diffstat (limited to 'drivers/gpu/drm/virtio/virtgpu_ioctl.c')
| -rw-r--r-- | drivers/gpu/drm/virtio/virtgpu_ioctl.c | 13 | 
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/gpu/drm/virtio/virtgpu_ioctl.c b/drivers/gpu/drm/virtio/virtgpu_ioctl.c index 0528edb4a2bf..5720a0d4ac0a 100644 --- a/drivers/gpu/drm/virtio/virtgpu_ioctl.c +++ b/drivers/gpu/drm/virtio/virtgpu_ioctl.c @@ -56,6 +56,7 @@ static int virtio_gpu_map_ioctl(struct drm_device *dev, void *data,  static int virtio_gpu_object_list_validate(struct ww_acquire_ctx *ticket,  					   struct list_head *head)  { +	struct ttm_operation_ctx ctx = { false, false };  	struct ttm_validate_buffer *buf;  	struct ttm_buffer_object *bo;  	struct virtio_gpu_object *qobj; @@ -68,7 +69,7 @@ static int virtio_gpu_object_list_validate(struct ww_acquire_ctx *ticket,  	list_for_each_entry(buf, head, head) {  		bo = buf->bo;  		qobj = container_of(bo, struct virtio_gpu_object, tbo); -		ret = ttm_bo_validate(bo, &qobj->placement, false, false); +		ret = ttm_bo_validate(bo, &qobj->placement, &ctx);  		if (ret) {  			ttm_eu_backoff_reservation(ticket, head);  			return ret; @@ -261,7 +262,7 @@ static int virtio_gpu_resource_create_ioctl(struct drm_device *dev, void *data,  		ret = virtio_gpu_object_attach(vgdev, qobj, res_id, NULL);  	} else {  		/* use a gem reference since unref list undoes them */ -		drm_gem_object_reference(&qobj->gem_base); +		drm_gem_object_get(&qobj->gem_base);  		mainbuf.bo = &qobj->tbo;  		list_add(&mainbuf.head, &validate_list); @@ -352,6 +353,7 @@ static int virtio_gpu_transfer_from_host_ioctl(struct drm_device *dev,  	struct virtio_gpu_device *vgdev = dev->dev_private;  	struct virtio_gpu_fpriv *vfpriv = file->driver_priv;  	struct drm_virtgpu_3d_transfer_from_host *args = data; +	struct ttm_operation_ctx ctx = { true, false };  	struct drm_gem_object *gobj = NULL;  	struct virtio_gpu_object *qobj = NULL;  	struct virtio_gpu_fence *fence; @@ -372,8 +374,7 @@ static int virtio_gpu_transfer_from_host_ioctl(struct drm_device *dev,  	if (ret)  		goto out; -	ret = ttm_bo_validate(&qobj->tbo, &qobj->placement, -			      true, false); +	ret = ttm_bo_validate(&qobj->tbo, &qobj->placement, &ctx);  	if (unlikely(ret))  		goto out_unres; @@ -399,6 +400,7 @@ static int virtio_gpu_transfer_to_host_ioctl(struct drm_device *dev, void *data,  	struct virtio_gpu_device *vgdev = dev->dev_private;  	struct virtio_gpu_fpriv *vfpriv = file->driver_priv;  	struct drm_virtgpu_3d_transfer_to_host *args = data; +	struct ttm_operation_ctx ctx = { true, false };  	struct drm_gem_object *gobj = NULL;  	struct virtio_gpu_object *qobj = NULL;  	struct virtio_gpu_fence *fence; @@ -416,8 +418,7 @@ static int virtio_gpu_transfer_to_host_ioctl(struct drm_device *dev, void *data,  	if (ret)  		goto out; -	ret = ttm_bo_validate(&qobj->tbo, &qobj->placement, -			      true, false); +	ret = ttm_bo_validate(&qobj->tbo, &qobj->placement, &ctx);  	if (unlikely(ret))  		goto out_unres;  |