Commit 46c67660 authored by shaoyunl's avatar shaoyunl Committed by Alex Deucher

drm/amdgpu: Use per device reset_domain for XGMI on sriov configuration

For SRIOV configuration, host driver control the reset method(either FLR or
heavier chain reset). The host will notify the guest individually with FLR
message if individual GPU within the hive need to be reset. So for guest
side, no need to use hive->reset_domain to replace the original per
device reset_domain
Signed-off-by: default avatarshaoyunl <shaoyun.liu@amd.com>
Reviewed-by: default avatarHawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 1ed1f6be
...@@ -2453,17 +2453,19 @@ static int amdgpu_device_ip_init(struct amdgpu_device *adev) ...@@ -2453,17 +2453,19 @@ static int amdgpu_device_ip_init(struct amdgpu_device *adev)
if (amdgpu_xgmi_add_device(adev) == 0) { if (amdgpu_xgmi_add_device(adev) == 0) {
struct amdgpu_hive_info *hive = amdgpu_get_xgmi_hive(adev); struct amdgpu_hive_info *hive = amdgpu_get_xgmi_hive(adev);
if (!hive->reset_domain || if (!amdgpu_sriov_vf(adev)) {
!amdgpu_reset_get_reset_domain(hive->reset_domain)) { if (!hive->reset_domain ||
r = -ENOENT; !amdgpu_reset_get_reset_domain(hive->reset_domain)) {
r = -ENOENT;
amdgpu_put_xgmi_hive(hive);
goto init_failed;
}
/* Drop the early temporary reset domain we created for device */
amdgpu_reset_put_reset_domain(adev->reset_domain);
adev->reset_domain = hive->reset_domain;
amdgpu_put_xgmi_hive(hive); amdgpu_put_xgmi_hive(hive);
goto init_failed;
} }
/* Drop the early temporary reset domain we created for device */
amdgpu_reset_put_reset_domain(adev->reset_domain);
adev->reset_domain = hive->reset_domain;
amdgpu_put_xgmi_hive(hive);
} }
} }
......
...@@ -391,24 +391,33 @@ struct amdgpu_hive_info *amdgpu_get_xgmi_hive(struct amdgpu_device *adev) ...@@ -391,24 +391,33 @@ struct amdgpu_hive_info *amdgpu_get_xgmi_hive(struct amdgpu_device *adev)
goto pro_end; goto pro_end;
} }
/**
* Only init hive->reset_domain for none SRIOV configuration. For SRIOV,
* Host driver decide how to reset the GPU either through FLR or chain reset.
* Guest side will get individual notifications from the host for the FLR
* if necessary.
*/
if (!amdgpu_sriov_vf(adev)) {
/** /**
* Avoid recreating reset domain when hive is reconstructed for the case * Avoid recreating reset domain when hive is reconstructed for the case
* of reset the devices in the XGMI hive during probe for SRIOV * of reset the devices in the XGMI hive during probe for passthrough GPU
* See https://www.spinics.net/lists/amd-gfx/msg58836.html * See https://www.spinics.net/lists/amd-gfx/msg58836.html
*/ */
if (adev->reset_domain->type != XGMI_HIVE) { if (adev->reset_domain->type != XGMI_HIVE) {
hive->reset_domain = amdgpu_reset_create_reset_domain(XGMI_HIVE, "amdgpu-reset-hive"); hive->reset_domain =
if (!hive->reset_domain) { amdgpu_reset_create_reset_domain(XGMI_HIVE, "amdgpu-reset-hive");
dev_err(adev->dev, "XGMI: failed initializing reset domain for xgmi hive\n"); if (!hive->reset_domain) {
ret = -ENOMEM; dev_err(adev->dev, "XGMI: failed initializing reset domain for xgmi hive\n");
kobject_put(&hive->kobj); ret = -ENOMEM;
kfree(hive); kobject_put(&hive->kobj);
hive = NULL; kfree(hive);
goto pro_end; hive = NULL;
} goto pro_end;
} else { }
amdgpu_reset_get_reset_domain(adev->reset_domain); } else {
hive->reset_domain = adev->reset_domain; amdgpu_reset_get_reset_domain(adev->reset_domain);
hive->reset_domain = adev->reset_domain;
}
} }
hive->hive_id = adev->gmc.xgmi.hive_id; hive->hive_id = adev->gmc.xgmi.hive_id;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment