提交 2f2eab3a 编写于 作者: O Oak Zeng 提交者: 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: NOak Zeng <Oak.Zeng@amd.com>
Reviewed-by: NAlex Deucher <alexander.deucher@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 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% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册