提交 7b184b00 编写于 作者: W wentalou 提交者: Alex Deucher

drm/amdgpu: kfd_pre_reset outside req_full_gpu cause sriov hang

XGMI hive put kfd_pre_reset into amdgpu_device_lock_adev,
but outside req_full_gpu of sriov.
It would make sriov hang during reset.
Signed-off-by: NWentao Lou <Wentao.Lou@amd.com>
Reviewed-by: NShaoyun Liu <Shaoyun.Liu@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 2a3c83f5
...@@ -3476,14 +3476,16 @@ static void amdgpu_device_lock_adev(struct amdgpu_device *adev) ...@@ -3476,14 +3476,16 @@ static void amdgpu_device_lock_adev(struct amdgpu_device *adev)
mutex_lock(&adev->lock_reset); mutex_lock(&adev->lock_reset);
atomic_inc(&adev->gpu_reset_counter); atomic_inc(&adev->gpu_reset_counter);
adev->in_gpu_reset = 1; adev->in_gpu_reset = 1;
/* Block kfd */ /* Block kfd: SRIOV would do it separately */
amdgpu_amdkfd_pre_reset(adev); if (!amdgpu_sriov_vf(adev))
amdgpu_amdkfd_pre_reset(adev);
} }
static void amdgpu_device_unlock_adev(struct amdgpu_device *adev) static void amdgpu_device_unlock_adev(struct amdgpu_device *adev)
{ {
/*unlock kfd */ /*unlock kfd: SRIOV would do it separately */
amdgpu_amdkfd_post_reset(adev); if (!amdgpu_sriov_vf(adev))
amdgpu_amdkfd_post_reset(adev);
amdgpu_vf_error_trans_all(adev); amdgpu_vf_error_trans_all(adev);
adev->in_gpu_reset = 0; adev->in_gpu_reset = 0;
mutex_unlock(&adev->lock_reset); mutex_unlock(&adev->lock_reset);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册