<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;" align="Left">
[AMD Official Use Only]<br>
</p>
<br>
<div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
Yes, that check looks good.</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
<br>
</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
A couple of other things - </div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
<br>
</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
PMFW ticket as a comment is not needed.</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
I remember Satish updating the same struct for smartshift related data. Some additional fields added towards the end. Not sure if Sienna struct also carries those fields. Regardless, you may check if that affects the placement of serial number fields (whether
 before or after those fields).</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
<br>
</div>
<div style="color: rgb(33, 33, 33); background-color: rgb(255, 255, 255);" dir="auto">
<br>
</div>
<div id="ms-outlook-mobile-signature" dir="auto">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> Russell, Kent <Kent.Russell@amd.com><br>
<b>Sent:</b> Monday, March 28, 2022 9:23:36 PM<br>
<b>To:</b> Lazar, Lijo <Lijo.Lazar@amd.com>; amd-gfx@lists.freedesktop.org <amd-gfx@lists.freedesktop.org><br>
<b>Cc:</b> Deucher, Alexander <Alexander.Deucher@amd.com><br>
<b>Subject:</b> RE: [PATCH 2/2] drm/amdgpu: Add unique_id support for sienna cichlid</font>
<div> </div>
</div>
<div class="BodyFragment"><font face="Times New Roman" size="3"><span style="font-size:12pt;"><a name="BM_BEGIN"></a>
<div><font size="2"><span style="font-size:11pt;">[AMD Official Use Only]<br>
<br>
> -----Original Message-----<br>
> From: Lazar, Lijo <Lijo.Lazar@amd.com><br>
> Sent: Monday, March 28, 2022 11:48 AM<br>
> To: Russell, Kent <Kent.Russell@amd.com>; amd-gfx@lists.freedesktop.org<br>
> Cc: Deucher, Alexander <Alexander.Deucher@amd.com><br>
> Subject: Re: [PATCH 2/2] drm/amdgpu: Add unique_id support for sienna cichlid<br>
><br>
><br>
><br>
> On 3/28/2022 9:12 PM, Russell, Kent wrote:<br>
> > [AMD Official Use Only]<br>
> ><br>
> > Responses inline<br>
> ><br>
> >> -----Original Message-----<br>
> >> From: Lazar, Lijo <Lijo.Lazar@amd.com><br>
> >> Sent: Monday, March 28, 2022 11:18 AM<br>
> >> To: Russell, Kent <Kent.Russell@amd.com>; amd-gfx@lists.freedesktop.org<br>
> >> Cc: Deucher, Alexander <Alexander.Deucher@amd.com><br>
> >> Subject: Re: [PATCH 2/2] drm/amdgpu: Add unique_id support for sienna cichlid<br>
> >><br>
> >><br>
> >><br>
> >> On 3/28/2022 8:05 PM, Kent Russell wrote:<br>
> >>> This is being added to SMU Metrics, so add the required tie-ins in the<br>
> >>> kernel. Also create the corresponding unique_id sysfs file.<br>
> >>><br>
> >>> v2: Add FW version check, remove SMU mutex<br>
> >>> v3: Fix style warning<br>
> >>><br>
> >>> Signed-off-by: Kent Russell <kent.russell@amd.com><br>
> >>> Reviewed-by: Alex Deucher <alexander.deucher@amd.com><br>
> >>> ---<br>
> >>>    drivers/gpu/drm/amd/pm/amdgpu_pm.c            |  1 +<br>
> >>>    .../pmfw_if/smu11_driver_if_sienna_cichlid.h  | 12 +++++--<br>
> >>>    .../amd/pm/swsmu/smu11/sienna_cichlid_ppt.c   | 36 +++++++++++++++++++<br>
> >>>    3 files changed, 47 insertions(+), 2 deletions(-)<br>
> >>><br>
> >>> diff --git a/drivers/gpu/drm/amd/pm/amdgpu_pm.c<br>
> >> b/drivers/gpu/drm/amd/pm/amdgpu_pm.c<br>
> >>> index 4151db2678fb..4a9aabc16fbc 100644<br>
> >>> --- a/drivers/gpu/drm/amd/pm/amdgpu_pm.c<br>
> >>> +++ b/drivers/gpu/drm/amd/pm/amdgpu_pm.c<br>
> >>> @@ -1993,6 +1993,7 @@ static int default_attr_update(struct amdgpu_device *adev,<br>
> >> struct amdgpu_device_<br>
> >>>              case IP_VERSION(9, 4, 0):<br>
> >>>              case IP_VERSION(9, 4, 1):<br>
> >>>              case IP_VERSION(9, 4, 2):<br>
> >>> +           case IP_VERSION(10, 3, 0):<br>
> >>>                      *states = ATTR_STATE_SUPPORTED;<br>
> >>>                      break;<br>
> >>>              default:<br>
> >>> diff --git<br>
> >> a/drivers/gpu/drm/amd/pm/swsmu/inc/pmfw_if/smu11_driver_if_sienna_cichlid.h<br>
> >> b/drivers/gpu/drm/amd/pm/swsmu/inc/pmfw_if/smu11_driver_if_sienna_cichlid.h<br>
> >>> index 3e4a314ef925..58f977320d06 100644<br>
> >>> --- a/drivers/gpu/drm/amd/pm/swsmu/inc/pmfw_if/smu11_driver_if_sienna_cichlid.h<br>
> >>> +++<br>
> b/drivers/gpu/drm/amd/pm/swsmu/inc/pmfw_if/smu11_driver_if_sienna_cichlid.h<br>
> >>> @@ -1419,8 +1419,12 @@ typedef struct {<br>
> >>>      uint8_t  PcieRate               ;<br>
> >>>      uint8_t  PcieWidth              ;<br>
> >>>      uint16_t AverageGfxclkFrequencyTarget;<br>
> >>> -  uint16_t Padding16_2;<br>
> >>><br>
> >>> +  //PMFW-8711<br>
> >>> +  uint32_t PublicSerialNumLower32;<br>
> >>> +  uint32_t PublicSerialNumUpper32;<br>
> >>> +<br>
> >>> +  uint16_t Padding16_2;<br>
> >>>    } SmuMetrics_t;<br>
> >>><br>
> >>>    typedef struct {<br>
> >>> @@ -1476,8 +1480,12 @@ typedef struct {<br>
> >>>      uint8_t  PcieRate               ;<br>
> >>>      uint8_t  PcieWidth              ;<br>
> >>>      uint16_t AverageGfxclkFrequencyTarget;<br>
> >>> -  uint16_t Padding16_2;<br>
> >>><br>
> >>> +  //PMFW-8711<br>
> >>> +  uint32_t PublicSerialNumLower32;<br>
> >>> +  uint32_t PublicSerialNumUpper32;<br>
> >>> +<br>
> >><br>
> >> Is this the case for other ASICs also which share the metrics data with<br>
> >> Sienna?<br>
> ><br>
> > No, only for Sienna Cichlid. The PMFW guys didn't implement it for Navy Flounder or<br>
> Dimgrey Cavefish.<br>
> ><br>
> >><br>
> >>> +  uint16_t Padding16_2;<br>
> >>>    } SmuMetrics_V2_t;<br>
> >>><br>
> >>>    typedef struct {<br>
> >>> diff --git a/drivers/gpu/drm/amd/pm/swsmu/smu11/sienna_cichlid_ppt.c<br>
> >> b/drivers/gpu/drm/amd/pm/swsmu/smu11/sienna_cichlid_ppt.c<br>
> >>> index 38f04836c82f..550458f6246a 100644<br>
> >>> --- a/drivers/gpu/drm/amd/pm/swsmu/smu11/sienna_cichlid_ppt.c<br>
> >>> +++ b/drivers/gpu/drm/amd/pm/swsmu/smu11/sienna_cichlid_ppt.c<br>
> >>> @@ -481,6 +481,41 @@ static int sienna_cichlid_setup_pptable(struct smu_context<br>
> >> *smu)<br>
> >>>      return sienna_cichlid_patch_pptable_quirk(smu);<br>
> >>>    }<br>
> >>><br>
> >>> +static void sienna_cichlid_get_unique_id(struct smu_context *smu)<br>
> >>> +{<br>
> >>> +   struct amdgpu_device *adev = smu->adev;<br>
> >>> +   struct smu_table_context *smu_table = &smu->smu_table;<br>
> >>> +   SmuMetrics_t *metrics =<br>
> >>> +           &(((SmuMetricsExternal_t *)(smu_table->metrics_table))->SmuMetrics);<br>
> >>> +   SmuMetrics_V2_t *metrics_v2 =<br>
> >>> +           &(((SmuMetricsExternal_t *)(smu_table->metrics_table))->SmuMetrics_V2);<br>
> >>> +   uint32_t upper32 = 0, lower32 = 0;<br>
> >>> +   bool use_metrics_v2;<br>
> >>> +   int ret;<br>
> >>> +<br>
> >>> +   /* Only supported as of version 0.58.83.0 */<br>
> >>> +   if (smu->smc_fw_version < 0x3A5300)<br>
> >>> +           return;<br>
> >>> +<br>
> >><br>
> >> Since this is shared with other ASICs, I guess this check itself may not<br>
> >> be enough. This function may be skipped if it's not MP1 11.0.7 or GC 10.3.0?<br>
> >><br>
> ><br>
> > Since the sysfs file is only supported on Sienna Cichlid (10.3.0), is it a concern since the tie-<br>
> in won't exist on the other SMU11-based ASICs? And this function is only referenced by<br>
> sienna_cichlid, unless I misunderstood something (and someone else uses<br>
> sienna_cichlid_tables_init).<br>
> ><br>
><br>
> This function also gets called as part of common init sequence -<br>
> smu_get_unique_id.<br>
> If PMFW version of Navi Flounder/Dimgrey ASIC is greater than Sienna,<br>
> then it may go to the path which is not intended to be executed on that<br>
> ASIC.<br>
<br>
Would it be sufficient to just confirm the IP_VERSION here too then?<br>
 e.g.<br>
/* Only supported as of version 0.58.83.0 and only on Sienna Cichlid (GC 10.3.0)*/<br>
if (smu->smc_fw_version < 0x3A5300 || adev->ip_versions[GC_HWIP][0] != IP_VERSION(10, 3, 0))<br>
          return;<br>
<br>
Thus the FW has to be that version, and the IP_VERSION has to be 10.3 ? Or is there a better method to use? Thanks!<br>
<br>
 Kent<br>
<br>
><br>
> Thanks,<br>
> Lijo<br>
><br>
> >   Kent<br>
> ><br>
> >> Thanks,<br>
> >> Lijo<br>
> >><br>
> >>> +   ret = smu_cmn_get_metrics_table(smu, NULL, false);<br>
> >>> +   if (ret)<br>
> >>> +           goto out_unlock;<br>
> >>> +<br>
> >>> +   use_metrics_v2 = ((smu->adev->ip_versions[MP1_HWIP][0] == IP_VERSION(11, 0,<br>
> >> 7)) &&<br>
> >>> +           (smu->smc_fw_version >= 0x3A4300)) ? true : false;<br>
> >>> +<br>
> >>> +   upper32 = use_metrics_v2 ? metrics_v2->PublicSerialNumUpper32 :<br>
> >>> +                              metrics->PublicSerialNumUpper32;<br>
> >>> +   lower32 = use_metrics_v2 ? metrics_v2->PublicSerialNumLower32 :<br>
> >>> +                              metrics->PublicSerialNumLower32;<br>
> >>> +<br>
> >>> +out_unlock:<br>
> >>> +<br>
> >>> +   adev->unique_id = ((uint64_t)upper32 << 32) | lower32;<br>
> >>> +   if (adev->serial[0] == '\0')<br>
> >>> +           sprintf(adev->serial, "%016llx", adev->unique_id);<br>
> >>> +}<br>
> >>> +<br>
> >>>    static int sienna_cichlid_tables_init(struct smu_context *smu)<br>
> >>>    {<br>
> >>>      struct smu_table_context *smu_table = &smu->smu_table;<br>
> >>> @@ -4182,6 +4217,7 @@ static const struct pptable_funcs sienna_cichlid_ppt_funcs = {<br>
> >>>      .get_ecc_info = sienna_cichlid_get_ecc_info,<br>
> >>>      .get_default_config_table_settings =<br>
> >> sienna_cichlid_get_default_config_table_settings,<br>
> >>>      .set_config_table = sienna_cichlid_set_config_table,<br>
> >>> +   .get_unique_id = sienna_cichlid_get_unique_id,<br>
> >>>    };<br>
> >>><br>
> >>>    void sienna_cichlid_set_ppt_funcs(struct smu_context *smu)<br>
> >>><br>
</span></font></div>
</span></font></div>
</div>
</body>
</html>