From: "Lazar, Lijo" <lijo.lazar@amd.com>
To: will.aitken@amd.com, amd-gfx@lists.freedesktop.org
Cc: victor.skvortsov@amd.com, Will Aitken <wiaitken@amd.com>
Subject: Re: [PATCH 1/3] drm/amdgpu: Refactor sriov xgmi topology filling to common code
Date: Tue, 28 Oct 2025 18:46:28 +0530 [thread overview]
Message-ID: <13375ad8-468d-4995-ab35-7180b36e33e5@amd.com> (raw)
In-Reply-To: <20251008133225.1238028-1-will.aitken@amd.com>
On 10/8/2025 7:02 PM, will.aitken@amd.com wrote:
> From: Will Aitken <wiaitken@amd.com>
>
> amdgpu_xgmi_fill_topology_info and psp_xgmi_reflect_topology_info
> perform the same logic of copying topology info of one node to every
> other node in the hive. Instead of having two functions that purport to
> do the same thing, this refactoring moves the logic of the fill function
> to the reflect function and adds reflecting port number info as well for
> complete functionality.
>
> Signed-off-by: Will Aitken <wiaitken@amd.com>
> ---
> drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c | 19 ++++++++++++-----
> drivers/gpu/drm/amd/amdgpu/amdgpu_xgmi.c | 27 ------------------------
> 2 files changed, 14 insertions(+), 32 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> index 6208a49c9f23..82500ade240d 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_psp.c
> @@ -1539,6 +1539,7 @@ static void psp_xgmi_reflect_topology_info(struct psp_context *psp,
> uint64_t src_node_id = psp->adev->gmc.xgmi.node_id;
> uint64_t dst_node_id = node_info.node_id;
> uint8_t dst_num_hops = node_info.num_hops;
> + uint8_t dst_is_sharing_enabled = node_info.is_sharing_enabled;
> uint8_t dst_num_links = node_info.num_links;
>
> hive = amdgpu_get_xgmi_hive(psp->adev);
> @@ -1558,13 +1559,20 @@ static void psp_xgmi_reflect_topology_info(struct psp_context *psp,
> continue;
>
> mirror_top_info->nodes[j].num_hops = dst_num_hops;
> - /*
> - * prevent 0 num_links value re-reflection since reflection
> + mirror_top_info->nodes[j].is_sharing_enabled = dst_is_sharing_enabled;
> + /* prevent 0 num_links value re-reflection since reflection
> * criteria is based on num_hops (direct or indirect).
> - *
> */
> - if (dst_num_links)
> + if (dst_num_links) {
Patches look fine. One clarification - do you need to fill this
information if sharing is disabled?
Thanks,
Lijo
> mirror_top_info->nodes[j].num_links = dst_num_links;
> + /* swap src and dst due to frame of reference */
> + for (int k = 0; k < dst_num_links; k++) {
> + mirror_top_info->nodes[j].port_num[k].src_xgmi_port_num =
> + node_info.port_num[k].dst_xgmi_port_num;
> + mirror_top_info->nodes[j].port_num[k].dst_xgmi_port_num =
> + node_info.port_num[k].src_xgmi_port_num;
> + }
> + }
>
> break;
> }
> @@ -1639,7 +1647,8 @@ int psp_xgmi_get_topology_info(struct psp_context *psp,
> amdgpu_ip_version(psp->adev, MP0_HWIP, 0) ==
> IP_VERSION(13, 0, 6) ||
> amdgpu_ip_version(psp->adev, MP0_HWIP, 0) ==
> - IP_VERSION(13, 0, 14);
> + IP_VERSION(13, 0, 14) ||
> + amdgpu_sriov_vf(psp->adev);
> bool ta_port_num_support = amdgpu_sriov_vf(psp->adev) ? 0 :
> psp->xgmi_context.xgmi_ta_caps & EXTEND_PEER_LINK_INFO_CMD_FLAG;
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_xgmi.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_xgmi.c
> index 1ede308a7c67..2e70b84a8c3b 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_xgmi.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_xgmi.c
> @@ -958,28 +958,6 @@ static int amdgpu_xgmi_initialize_hive_get_data_partition(struct amdgpu_hive_inf
> return 0;
> }
>
> -static void amdgpu_xgmi_fill_topology_info(struct amdgpu_device *adev,
> - struct amdgpu_device *peer_adev)
> -{
> - struct psp_xgmi_topology_info *top_info = &adev->psp.xgmi_context.top_info;
> - struct psp_xgmi_topology_info *peer_info = &peer_adev->psp.xgmi_context.top_info;
> -
> - for (int i = 0; i < peer_info->num_nodes; i++) {
> - if (peer_info->nodes[i].node_id == adev->gmc.xgmi.node_id) {
> - for (int j = 0; j < top_info->num_nodes; j++) {
> - if (top_info->nodes[j].node_id == peer_adev->gmc.xgmi.node_id) {
> - peer_info->nodes[i].num_hops = top_info->nodes[j].num_hops;
> - peer_info->nodes[i].is_sharing_enabled =
> - top_info->nodes[j].is_sharing_enabled;
> - peer_info->nodes[i].num_links =
> - top_info->nodes[j].num_links;
> - return;
> - }
> - }
> - }
> - }
> -}
> -
> int amdgpu_xgmi_add_device(struct amdgpu_device *adev)
> {
> struct psp_xgmi_topology_info *top_info;
> @@ -1065,11 +1043,6 @@ int amdgpu_xgmi_add_device(struct amdgpu_device *adev)
> /* To do: continue with some node failed or disable the whole hive*/
> goto exit_unlock;
> }
> -
> - /* fill the topology info for peers instead of getting from PSP */
> - list_for_each_entry(tmp_adev, &hive->device_list, gmc.xgmi.head) {
> - amdgpu_xgmi_fill_topology_info(adev, tmp_adev);
> - }
> } else {
> /* get latest topology info for each device from psp */
> list_for_each_entry(tmp_adev, &hive->device_list, gmc.xgmi.head) {
next prev parent reply other threads:[~2025-10-28 13:16 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-08 13:32 [PATCH 1/3] drm/amdgpu: Refactor sriov xgmi topology filling to common code will.aitken
2025-10-08 13:32 ` [PATCH 2/3] drm/amdgpu: Update headers for sriov xgmi ext peer link support feature flag will.aitken
2025-10-08 13:32 ` [PATCH 3/3] drm/amdgpu: Enable xgmi extended peer links for sriov guest will.aitken
2025-10-28 13:16 ` Lazar, Lijo [this message]
[not found] ` <MW4PR12MB71918A5EFF20C239743AC346F1FAA@MW4PR12MB7191.namprd12.prod.outlook.com>
2025-11-03 20:24 ` [PATCH 1/3] drm/amdgpu: Refactor sriov xgmi topology filling to common code Aitken, Will
2025-11-06 16:27 ` Lazar, Lijo
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=13375ad8-468d-4995-ab35-7180b36e33e5@amd.com \
--to=lijo.lazar@amd.com \
--cc=amd-gfx@lists.freedesktop.org \
--cc=victor.skvortsov@amd.com \
--cc=wiaitken@amd.com \
--cc=will.aitken@amd.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox