drm/amdgpu: move iommu_resume before ip init/resume
commit f02abeb0779700c308e661a412451b38962b8a0b upstream. Separate iommu_resume from kfd_resume, and move it before other amdgpu ip init/resume. Bug: https://bugzilla.kernel.org/show_bug.cgi?id=211277 Signed-off-by: James Zhu <James.Zhu@amd.com> Reviewed-by: Felix Kuehling <Felix.Kuehling@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com> Cc: stable@vger.kernel.org Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
fe9dca7dda
commit
ac9db04ee3
@@ -2220,6 +2220,10 @@ static int amdgpu_device_ip_init(struct amdgpu_device *adev)
|
|||||||
if (r)
|
if (r)
|
||||||
goto init_failed;
|
goto init_failed;
|
||||||
|
|
||||||
|
r = amdgpu_amdkfd_resume_iommu(adev);
|
||||||
|
if (r)
|
||||||
|
goto init_failed;
|
||||||
|
|
||||||
r = amdgpu_device_ip_hw_init_phase1(adev);
|
r = amdgpu_device_ip_hw_init_phase1(adev);
|
||||||
if (r)
|
if (r)
|
||||||
goto init_failed;
|
goto init_failed;
|
||||||
@@ -2913,6 +2917,10 @@ static int amdgpu_device_ip_resume(struct amdgpu_device *adev)
|
|||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
|
r = amdgpu_amdkfd_resume_iommu(adev);
|
||||||
|
if (r)
|
||||||
|
return r;
|
||||||
|
|
||||||
r = amdgpu_device_ip_resume_phase1(adev);
|
r = amdgpu_device_ip_resume_phase1(adev);
|
||||||
if (r)
|
if (r)
|
||||||
return r;
|
return r;
|
||||||
@@ -4296,6 +4304,10 @@ static int amdgpu_do_asic_reset(struct amdgpu_hive_info *hive,
|
|||||||
|
|
||||||
if (!r) {
|
if (!r) {
|
||||||
dev_info(tmp_adev->dev, "GPU reset succeeded, trying to resume\n");
|
dev_info(tmp_adev->dev, "GPU reset succeeded, trying to resume\n");
|
||||||
|
r = amdgpu_amdkfd_resume_iommu(tmp_adev);
|
||||||
|
if (r)
|
||||||
|
goto out;
|
||||||
|
|
||||||
r = amdgpu_device_ip_resume_phase1(tmp_adev);
|
r = amdgpu_device_ip_resume_phase1(tmp_adev);
|
||||||
if (r)
|
if (r)
|
||||||
goto out;
|
goto out;
|
||||||
|
Reference in New Issue
Block a user