<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
</head>
<body>
<p style="font-family:Arial;font-size:10pt;color:#0000FF;margin:5pt;font-style:normal;font-weight:normal;text-decoration:none;" align="Left">
[AMD Official Use Only - General]<br>
</p>
<br>
<div>
<div dir="auto"><ping></div>
<div id="ms-outlook-mobile-signature" dir="auto">
<div><br>
</div>
Thanks,<br>
Lijo</div>
<hr style="display:inline-block;width:98%" tabindex="-1">
<div id="divRplyFwdMsg" dir="ltr"><font face="Calibri, sans-serif" style="font-size:11pt" color="#000000"><b>From:</b> amd-gfx <amd-gfx-bounces@lists.freedesktop.org> on behalf of Lijo Lazar <lijo.lazar@amd.com><br>
<b>Sent:</b> Friday, October 20, 2023 8:44:22 PM<br>
<b>To:</b> amd-gfx@lists.freedesktop.org <amd-gfx@lists.freedesktop.org><br>
<b>Cc:</b> Deucher, Alexander <Alexander.Deucher@amd.com>; Kasiviswanathan, Harish <Harish.Kasiviswanathan@amd.com>; Zhang, Hawking <Hawking.Zhang@amd.com><br>
<b>Subject:</b> [PATCH] drm/amdgpu: Use pcie domain of xcc acpi objects</font>
<div> </div>
</div>
<div class="BodyFragment"><font size="2"><span style="font-size:11pt;">
<div class="PlainText">PCI domain/segment information of xccs is available through ACPI DSM<br>
methods. Consider that also while looking for devices.<br>
<br>
Signed-off-by: Lijo Lazar <lijo.lazar@amd.com><br>
---<br>
 drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c | 40 +++++++++++++-----------<br>
 1 file changed, 22 insertions(+), 18 deletions(-)<br>
<br>
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c<br>
index 2bca37044ad0..d62e49758635 100644<br>
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c<br>
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_acpi.c<br>
@@ -68,7 +68,7 @@ struct amdgpu_acpi_xcc_info {<br>
 struct amdgpu_acpi_dev_info {<br>
         struct list_head list;<br>
         struct list_head xcc_list;<br>
-       uint16_t bdf;<br>
+       uint32_t sbdf;<br>
         uint16_t supp_xcp_mode;<br>
         uint16_t xcp_mode;<br>
         uint16_t mem_mode;<br>
@@ -927,7 +927,7 @@ static acpi_status amdgpu_acpi_get_node_id(acpi_handle handle,<br>
 #endif<br>
 }<br>
 <br>
-static struct amdgpu_acpi_dev_info *amdgpu_acpi_get_dev(u16 bdf)<br>
+static struct amdgpu_acpi_dev_info *amdgpu_acpi_get_dev(u32 sbdf)<br>
 {<br>
         struct amdgpu_acpi_dev_info *acpi_dev;<br>
 <br>
@@ -935,14 +935,14 @@ static struct amdgpu_acpi_dev_info *amdgpu_acpi_get_dev(u16 bdf)<br>
                 return NULL;<br>
 <br>
         list_for_each_entry(acpi_dev, &amdgpu_acpi_dev_list, list)<br>
-               if (acpi_dev->bdf == bdf)<br>
+               if (acpi_dev->sbdf == sbdf)<br>
                         return acpi_dev;<br>
 <br>
         return NULL;<br>
 }<br>
 <br>
 static int amdgpu_acpi_dev_init(struct amdgpu_acpi_dev_info **dev_info,<br>
-                               struct amdgpu_acpi_xcc_info *xcc_info, u16 bdf)<br>
+                               struct amdgpu_acpi_xcc_info *xcc_info, u32 sbdf)<br>
 {<br>
         struct amdgpu_acpi_dev_info *tmp;<br>
         union acpi_object *obj;<br>
@@ -955,7 +955,7 @@ static int amdgpu_acpi_dev_init(struct amdgpu_acpi_dev_info **dev_info,<br>
 <br>
         INIT_LIST_HEAD(&tmp->xcc_list);<br>
         INIT_LIST_HEAD(&tmp->list);<br>
-       tmp->bdf = bdf;<br>
+       tmp->sbdf = sbdf;<br>
 <br>
         obj = acpi_evaluate_dsm_typed(xcc_info->handle, &amd_xcc_dsm_guid, 0,<br>
                                       AMD_XCC_DSM_GET_SUPP_MODE, NULL,<br>
@@ -1007,7 +1007,7 @@ static int amdgpu_acpi_dev_init(struct amdgpu_acpi_dev_info **dev_info,<br>
 <br>
         DRM_DEBUG_DRIVER(<br>
                 "New dev(%x): Supported xcp mode: %x curr xcp_mode : %x mem mode : %x, tmr base: %llx tmr size: %llx  ",<br>
-               tmp->bdf, tmp->supp_xcp_mode, tmp->xcp_mode, tmp->mem_mode,<br>
+               tmp->sbdf, tmp->supp_xcp_mode, tmp->xcp_mode, tmp->mem_mode,<br>
                 tmp->tmr_base, tmp->tmr_size);<br>
         list_add_tail(&tmp->list, &amdgpu_acpi_dev_list);<br>
         *dev_info = tmp;<br>
@@ -1023,7 +1023,7 @@ static int amdgpu_acpi_dev_init(struct amdgpu_acpi_dev_info **dev_info,<br>
 }<br>
 <br>
 static int amdgpu_acpi_get_xcc_info(struct amdgpu_acpi_xcc_info *xcc_info,<br>
-                                   u16 *bdf)<br>
+                                   u32 *sbdf)<br>
 {<br>
         union acpi_object *obj;<br>
         acpi_status status;<br>
@@ -1054,8 +1054,10 @@ static int amdgpu_acpi_get_xcc_info(struct amdgpu_acpi_xcc_info *xcc_info,<br>
         xcc_info->phy_id = (obj->integer.value >> 32) & 0xFF;<br>
         /* xcp node of this xcc [47:40] */<br>
         xcc_info->xcp_node = (obj->integer.value >> 40) & 0xFF;<br>
+       /* PF domain of this xcc [31:16] */<br>
+       *sbdf = (obj->integer.value) & 0xFFFF0000;<br>
         /* PF bus/dev/fn of this xcc [63:48] */<br>
-       *bdf = (obj->integer.value >> 48) & 0xFFFF;<br>
+       *sbdf |= (obj->integer.value >> 48) & 0xFFFF;<br>
         ACPI_FREE(obj);<br>
         obj = NULL;<br>
 <br>
@@ -1079,7 +1081,7 @@ static int amdgpu_acpi_enumerate_xcc(void)<br>
         struct acpi_device *acpi_dev;<br>
         char hid[ACPI_ID_LEN];<br>
         int ret, id;<br>
-       u16 bdf;<br>
+       u32 sbdf;<br>
 <br>
         INIT_LIST_HEAD(&amdgpu_acpi_dev_list);<br>
         xa_init(&numa_info_xa);<br>
@@ -1107,16 +1109,16 @@ static int amdgpu_acpi_enumerate_xcc(void)<br>
                 xcc_info->handle = acpi_device_handle(acpi_dev);<br>
                 acpi_dev_put(acpi_dev);<br>
 <br>
-               ret = amdgpu_acpi_get_xcc_info(xcc_info, &bdf);<br>
+               ret = amdgpu_acpi_get_xcc_info(xcc_info, &sbdf);<br>
                 if (ret) {<br>
                         kfree(xcc_info);<br>
                         continue;<br>
                 }<br>
 <br>
-               dev_info = amdgpu_acpi_get_dev(bdf);<br>
+               dev_info = amdgpu_acpi_get_dev(sbdf);<br>
 <br>
                 if (!dev_info)<br>
-                       ret = amdgpu_acpi_dev_init(&dev_info, xcc_info, bdf);<br>
+                       ret = amdgpu_acpi_dev_init(&dev_info, xcc_info, sbdf);<br>
 <br>
                 if (ret == -ENOMEM)<br>
                         return ret;<br>
@@ -1136,13 +1138,14 @@ int amdgpu_acpi_get_tmr_info(struct amdgpu_device *adev, u64 *tmr_offset,<br>
                              u64 *tmr_size)<br>
 {<br>
         struct amdgpu_acpi_dev_info *dev_info;<br>
-       u16 bdf;<br>
+       u32 sbdf;<br>
 <br>
         if (!tmr_offset || !tmr_size)<br>
                 return -EINVAL;<br>
 <br>
-       bdf = pci_dev_id(adev->pdev);<br>
-       dev_info = amdgpu_acpi_get_dev(bdf);<br>
+       sbdf = (pci_domain_nr(adev->pdev->bus) << 16);<br>
+       sbdf |= pci_dev_id(adev->pdev);<br>
+       dev_info = amdgpu_acpi_get_dev(sbdf);<br>
         if (!dev_info)<br>
                 return -ENOENT;<br>
 <br>
@@ -1157,13 +1160,14 @@ int amdgpu_acpi_get_mem_info(struct amdgpu_device *adev, int xcc_id,<br>
 {<br>
         struct amdgpu_acpi_dev_info *dev_info;<br>
         struct amdgpu_acpi_xcc_info *xcc_info;<br>
-       u16 bdf;<br>
+       u32 sbdf;<br>
 <br>
         if (!numa_info)<br>
                 return -EINVAL;<br>
 <br>
-       bdf = pci_dev_id(adev->pdev);<br>
-       dev_info = amdgpu_acpi_get_dev(bdf);<br>
+       sbdf = (pci_domain_nr(adev->pdev->bus) << 16);<br>
+       sbdf |= pci_dev_id(adev->pdev);<br>
+       dev_info = amdgpu_acpi_get_dev(sbdf);<br>
         if (!dev_info)<br>
                 return -ENOENT;<br>
 <br>
-- <br>
2.25.1<br>
<br>
</div>
</span></font></div>
</div>
</body>
</html>