Commit 2f2eab3a authored by Oak Zeng's avatar Oak Zeng Committed by Alex Deucher

drm/amdgpu: Hack xgmi topology info when there is no psp fw

This is only needed on emulation platform where psp fw might
not be available, to hack xgmi topology info such as hive id and
node id.

v2: Add offset to hacked hive/node id
v3: Don't use introduce new module parameter.
Signed-off-by: default avatarOak Zeng <Oak.Zeng@amd.com>
Reviewed-by: default avatarAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 0ad8c5e2
...@@ -301,18 +301,23 @@ int amdgpu_xgmi_add_device(struct amdgpu_device *adev) ...@@ -301,18 +301,23 @@ int amdgpu_xgmi_add_device(struct amdgpu_device *adev)
if (!adev->gmc.xgmi.supported) if (!adev->gmc.xgmi.supported)
return 0; return 0;
ret = psp_xgmi_get_node_id(&adev->psp, &adev->gmc.xgmi.node_id); if (amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_PSP)) {
if (ret) { ret = psp_xgmi_get_hive_id(&adev->psp, &adev->gmc.xgmi.hive_id);
dev_err(adev->dev, if (ret) {
"XGMI: Failed to get node id\n"); dev_err(adev->dev,
return ret; "XGMI: Failed to get hive id\n");
} return ret;
}
ret = psp_xgmi_get_hive_id(&adev->psp, &adev->gmc.xgmi.hive_id); ret = psp_xgmi_get_node_id(&adev->psp, &adev->gmc.xgmi.node_id);
if (ret) { if (ret) {
dev_err(adev->dev, dev_err(adev->dev,
"XGMI: Failed to get hive id\n"); "XGMI: Failed to get node id\n");
return ret; return ret;
}
} else {
adev->gmc.xgmi.hive_id = 16;
adev->gmc.xgmi.node_id = adev->gmc.xgmi.physical_node_id + 16;
} }
hive = amdgpu_get_xgmi_hive(adev, 1); hive = amdgpu_get_xgmi_hive(adev, 1);
......
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