diff options
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | 15 | 
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c index 4e4094f842e7..2e53feed40e2 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c @@ -402,7 +402,7 @@ static int amdgpu_cs_bo_validate(struct amdgpu_cs_parser *p,  	struct ttm_operation_ctx ctx = {  		.interruptible = true,  		.no_wait_gpu = false, -		.resv = bo->tbo.resv, +		.resv = bo->tbo.base.resv,  		.flags = 0  	};  	uint32_t domain; @@ -730,7 +730,7 @@ static int amdgpu_cs_sync_rings(struct amdgpu_cs_parser *p)  	list_for_each_entry(e, &p->validated, tv.head) {  		struct amdgpu_bo *bo = ttm_to_amdgpu_bo(e->tv.bo); -		struct reservation_object *resv = bo->tbo.resv; +		struct dma_resv *resv = bo->tbo.base.resv;  		r = amdgpu_sync_resv(p->adev, &p->job->sync, resv, p->filp,  				     amdgpu_bo_explicit_sync(bo)); @@ -1143,6 +1143,9 @@ static int amdgpu_cs_process_syncobj_out_dep(struct amdgpu_cs_parser *p,  	num_deps = chunk->length_dw * 4 /  		sizeof(struct drm_amdgpu_cs_chunk_sem); +	if (p->post_deps) +		return -EINVAL; +  	p->post_deps = kmalloc_array(num_deps, sizeof(*p->post_deps),  				     GFP_KERNEL);  	p->num_post_deps = 0; @@ -1166,8 +1169,7 @@ static int amdgpu_cs_process_syncobj_out_dep(struct amdgpu_cs_parser *p,  static int amdgpu_cs_process_syncobj_timeline_out_dep(struct amdgpu_cs_parser *p, -						      struct amdgpu_cs_chunk -						      *chunk) +						      struct amdgpu_cs_chunk *chunk)  {  	struct drm_amdgpu_cs_chunk_syncobj *syncobj_deps;  	unsigned num_deps; @@ -1177,6 +1179,9 @@ static int amdgpu_cs_process_syncobj_timeline_out_dep(struct amdgpu_cs_parser *p  	num_deps = chunk->length_dw * 4 /  		sizeof(struct drm_amdgpu_cs_chunk_syncobj); +	if (p->post_deps) +		return -EINVAL; +  	p->post_deps = kmalloc_array(num_deps, sizeof(*p->post_deps),  				     GFP_KERNEL);  	p->num_post_deps = 0; @@ -1727,7 +1732,7 @@ int amdgpu_cs_find_mapping(struct amdgpu_cs_parser *parser,  	*map = mapping;  	/* Double check that the BO is reserved by this CS */ -	if (READ_ONCE((*bo)->tbo.resv->lock.ctx) != &parser->ticket) +	if (dma_resv_locking_ctx((*bo)->tbo.base.resv) != &parser->ticket)  		return -EINVAL;  	if (!((*bo)->flags & AMDGPU_GEM_CREATE_VRAM_CONTIGUOUS)) {  |