r = amdgpu_irq_get(adev, &adev->gfx.cp_ecc_error_irq, 0);
if (r)
goto late_fini;
- } else
- kfree(adev->gfx.ras_if);
+ } else {
+ r = 0;
+ goto free;
+ }
return 0;
late_fini:
amdgpu_ras_late_fini(adev, adev->gfx.ras_if, &ih_info);
free:
kfree(adev->gfx.ras_if);
+ adev->gfx.ras_if = NULL;
return r;
}
r = amdgpu_irq_get(adev, &adev->gmc.ecc_irq, 0);
if (r)
goto umc_late_fini;
- } else
- kfree(adev->gmc.umc_ras_if);
+ } else {
+ /* free umc ras_if if umc ras is not supported */
+ r = 0;
+ goto free;
+ }
if (adev->mmhub_funcs && adev->mmhub_funcs->ras_late_init) {
r = adev->mmhub_funcs->ras_late_init(adev);
amdgpu_ras_late_fini(adev, adev->gmc.umc_ras_if, &umc_ih_info);
free:
kfree(adev->gmc.umc_ras_if);
+ adev->gmc.umc_ras_if = NULL;
return r;
}
mmhub_ih_info.head = mmhub_fs_info.head = *adev->gmc.mmhub_ras_if;
r = amdgpu_ras_late_init(adev, adev->gmc.mmhub_ras_if,
&mmhub_fs_info, &mmhub_ih_info);
- if (r || !amdgpu_ras_is_supported(adev, adev->gmc.mmhub_ras_if->block))
+ if (r || !amdgpu_ras_is_supported(adev, adev->gmc.mmhub_ras_if->block)) {
kfree(adev->gmc.mmhub_ras_if);
+ adev->gmc.mmhub_ras_if = NULL;
+ }
return r;
}
r = amdgpu_irq_get(adev, &adev->nbio.ras_err_event_athub_irq, 0);
if (r)
goto late_fini;
+ } else {
+ r = 0;
+ goto free;
}
return 0;
amdgpu_ras_late_fini(adev, adev->nbio.ras_if, &ih_info);
free:
kfree(adev->nbio.ras_if);
+ adev->nbio.ras_if = NULL;
return r;
}
if (r)
goto late_fini;
}
- } else
- kfree(adev->sdma.ras_if);
+ } else {
+ /* free sdma ras_if if sdma ras is not supported */
+ r = 0;
+ goto free;
+ }
return 0;
late_fini:
amdgpu_ras_late_fini(adev, adev->sdma.ras_if, &ih_info);
free:
kfree(adev->sdma.ras_if);
+ adev->sdma.ras_if = NULL;
return r;
}