drm/amdgpu: move kfd post_reset out of reset_sriov function
Fixes: 9f4f2c1a35 ("drm/amd/amdgpu: fix the kfd pre_reset sequence in sriov")
For sriov XGMI  configuration, the host driver will handle the hive reset,
so in guest side, the reset_sriov only be called once on one device. This will
make kfd post_reset unblanced with kfd pre_reset since kfd pre_reset already
been moved out of reset_sriov function. Move kfd post_reset out of reset_sriov
function to make them balance .
Signed-off-by: shaoyunl <shaoyun.liu@amd.com>
Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
			
			
This commit is contained in:
		
							parent
							
								
									2da8f0beec
								
							
						
					
					
						commit
						271fd38ce5
					
				| @ -4316,7 +4316,6 @@ static int amdgpu_device_reset_sriov(struct amdgpu_device *adev, | ||||
| 
 | ||||
| 	amdgpu_irq_gpu_reset_resume_helper(adev); | ||||
| 	r = amdgpu_ib_ring_tests(adev); | ||||
| 	amdgpu_amdkfd_post_reset(adev); | ||||
| 
 | ||||
| error: | ||||
| 	if (!r && adev->virt.gim_feature & AMDGIM_FEATURE_GIM_FLR_VRAMLOST) { | ||||
| @ -5089,7 +5088,7 @@ retry:	/* Rest of adevs pre asic reset from XGMI hive. */ | ||||
| 
 | ||||
| 	tmp_vram_lost_counter = atomic_read(&((adev)->vram_lost_counter)); | ||||
| 	/* Actual ASIC resets if needed.*/ | ||||
| 	/* TODO Implement XGMI hive reset logic for SRIOV */ | ||||
| 	/* Host driver will handle XGMI hive reset for SRIOV */ | ||||
| 	if (amdgpu_sriov_vf(adev)) { | ||||
| 		r = amdgpu_device_reset_sriov(adev, job ? false : true); | ||||
| 		if (r) | ||||
| @ -5149,8 +5148,8 @@ skip_hw_reset: | ||||
| 
 | ||||
| skip_sched_resume: | ||||
| 	list_for_each_entry(tmp_adev, device_list_handle, reset_list) { | ||||
| 		/* unlock kfd: SRIOV would do it separately */ | ||||
| 		if (!need_emergency_restart && !amdgpu_sriov_vf(tmp_adev)) | ||||
| 		/* unlock kfd */ | ||||
| 		if (!need_emergency_restart) | ||||
| 	                amdgpu_amdkfd_post_reset(tmp_adev); | ||||
| 
 | ||||
| 		/* kfd_post_reset will do nothing if kfd device is not initialized,
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user