AMD-GFX Archive on lore.kernel.org
 help / color / mirror / Atom feed
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) {


  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