diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2022-10-10 08:30:23 +0300 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2022-10-10 08:30:23 +0300 | 
| commit | 5f8f8574c7f5585b09a9623f0f13462e4eb67b4d (patch) | |
| tree | 8f1d5e88bf9604a9e39fbcce0e37b3d8cee451bb /drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | |
| parent | e62563db857f81d75c5726a35bc0180bed6d1540 (diff) | |
| parent | fe5b6aaef72a0f7daa06e7960e0bee45c2984e41 (diff) | |
| download | linux-5f8f8574c7f5585b09a9623f0f13462e4eb67b4d.tar.xz | |
Merge branch 'next' into for-linus
Prepare input updates for 6.1 merge window.
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | 16 | 
1 files changed, 13 insertions, 3 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c index b28af04b0c3e..d8f1335bc68f 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c @@ -519,6 +519,8 @@ static int amdgpu_cs_parser_bos(struct amdgpu_cs_parser *p,  			return r;  	} +	mutex_lock(&p->bo_list->bo_list_mutex); +  	/* One for TTM and one for the CS job */  	amdgpu_bo_list_for_each_entry(e, p->bo_list)  		e->tv.num_shared = 2; @@ -651,6 +653,7 @@ out_free_user_pages:  			kvfree(e->user_pages);  			e->user_pages = NULL;  		} +		mutex_unlock(&p->bo_list->bo_list_mutex);  	}  	return r;  } @@ -690,9 +693,11 @@ static void amdgpu_cs_parser_fini(struct amdgpu_cs_parser *parser, int error,  {  	unsigned i; -	if (error && backoff) +	if (error && backoff) {  		ttm_eu_backoff_reservation(&parser->ticket,  					   &parser->validated); +		mutex_unlock(&parser->bo_list->bo_list_mutex); +	}  	for (i = 0; i < parser->num_post_deps; i++) {  		drm_syncobj_put(parser->post_deps[i].syncobj); @@ -832,12 +837,16 @@ static int amdgpu_cs_vm_handling(struct amdgpu_cs_parser *p)  			continue;  		r = amdgpu_vm_bo_update(adev, bo_va, false); -		if (r) +		if (r) { +			mutex_unlock(&p->bo_list->bo_list_mutex);  			return r; +		}  		r = amdgpu_sync_fence(&p->job->sync, bo_va->last_pt_update); -		if (r) +		if (r) { +			mutex_unlock(&p->bo_list->bo_list_mutex);  			return r; +		}  	}  	r = amdgpu_vm_handle_moved(adev, vm); @@ -1278,6 +1287,7 @@ static int amdgpu_cs_submit(struct amdgpu_cs_parser *p,  	ttm_eu_fence_buffer_objects(&p->ticket, &p->validated, p->fence);  	mutex_unlock(&p->adev->notifier_lock); +	mutex_unlock(&p->bo_list->bo_list_mutex);  	return 0;  | 
