Use common helper function to get pptable from firmware binary in
SMUv13.
Signed-off-by: Lijo Lazar <[email protected]>
Assisted-by: Claude Sonnet (Cursor AI)
---
drivers/gpu/drm/amd/pm/swsmu/inc/smu_v13_0.h | 4 -
.../gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c | 85 +------------------
2 files changed, 2 insertions(+), 87 deletions(-)
diff --git a/drivers/gpu/drm/amd/pm/swsmu/inc/smu_v13_0.h
b/drivers/gpu/drm/amd/pm/swsmu/inc/smu_v13_0.h
index 89bbda0670ef..68f4de5f800c 100644
--- a/drivers/gpu/drm/amd/pm/swsmu/inc/smu_v13_0.h
+++ b/drivers/gpu/drm/amd/pm/swsmu/inc/smu_v13_0.h
@@ -255,10 +255,6 @@ void smu_v13_0_init_msg_ctl(struct smu_context *smu,
int smu_v13_0_mode1_reset(struct smu_context *smu);
-int smu_v13_0_get_pptable_from_firmware(struct smu_context *smu,
- void **table,
- uint32_t *size,
- uint32_t pptable_id);
int smu_v13_0_update_pcie_parameters(struct smu_context *smu,
uint8_t pcie_gen_cap,
diff --git a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
index d8a1c402a624..d511f03354a6 100644
--- a/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
+++ b/drivers/gpu/drm/amd/pm/swsmu/smu13/smu_v13_0.c
@@ -218,7 +218,7 @@ int smu_v13_0_init_pptable_microcode(struct smu_context
*smu)
if (!pptable_id)
return 0;
- ret = smu_v13_0_get_pptable_from_firmware(smu, &table, &size,
pptable_id);
+ ret = smu_cmn_get_pptable_from_firmware(smu, &table, &size, pptable_id);
if (ret)
return ret;
@@ -258,48 +258,6 @@ int smu_v13_0_check_fw_status(struct smu_context *smu)
return -EIO;
}
-static int smu_v13_0_set_pptable_v2_0(struct smu_context *smu, void **table,
uint32_t *size)
-{
- struct amdgpu_device *adev = smu->adev;
- uint32_t ppt_offset_bytes;
- const struct smc_firmware_header_v2_0 *v2;
-
- v2 = (const struct smc_firmware_header_v2_0 *) adev->pm.fw->data;
-
- ppt_offset_bytes = le32_to_cpu(v2->ppt_offset_bytes);
- *size = le32_to_cpu(v2->ppt_size_bytes);
- *table = (uint8_t *)v2 + ppt_offset_bytes;
-
- return 0;
-}
-
-static int smu_v13_0_set_pptable_v2_1(struct smu_context *smu, void **table,
- uint32_t *size, uint32_t pptable_id)
-{
- struct amdgpu_device *adev = smu->adev;
- const struct smc_firmware_header_v2_1 *v2_1;
- struct smc_soft_pptable_entry *entries;
- uint32_t pptable_count = 0;
- int i = 0;
-
- v2_1 = (const struct smc_firmware_header_v2_1 *) adev->pm.fw->data;
- entries = (struct smc_soft_pptable_entry *)
- ((uint8_t *)v2_1 + le32_to_cpu(v2_1->pptable_entry_offset));
- pptable_count = le32_to_cpu(v2_1->pptable_count);
- for (i = 0; i < pptable_count; i++) {
- if (le32_to_cpu(entries[i].id) == pptable_id) {
- *table = ((uint8_t *)v2_1 +
le32_to_cpu(entries[i].ppt_offset_bytes));
- *size = le32_to_cpu(entries[i].ppt_size_bytes);
- break;
- }
- }
-
- if (i == pptable_count)
- return -EINVAL;
-
- return 0;
-}
-
static int smu_v13_0_get_pptable_from_vbios(struct smu_context *smu, void
**table, uint32_t *size)
{
struct amdgpu_device *adev = smu->adev;
@@ -322,45 +280,6 @@ static int smu_v13_0_get_pptable_from_vbios(struct
smu_context *smu, void **tabl
return 0;
}
-int smu_v13_0_get_pptable_from_firmware(struct smu_context *smu,
- void **table,
- uint32_t *size,
- uint32_t pptable_id)
-{
- const struct smc_firmware_header_v1_0 *hdr;
- struct amdgpu_device *adev = smu->adev;
- uint16_t version_major, version_minor;
- int ret;
-
- hdr = (const struct smc_firmware_header_v1_0 *) adev->pm.fw->data;
- if (!hdr)
- return -EINVAL;
-
- dev_info(adev->dev, "use driver provided pptable %d\n", pptable_id);
-
- version_major = le16_to_cpu(hdr->header.header_version_major);
- version_minor = le16_to_cpu(hdr->header.header_version_minor);
- if (version_major != 2) {
- dev_err(adev->dev, "Unsupported smu firmware version %d.%d\n",
- version_major, version_minor);
- return -EINVAL;
- }
-
- switch (version_minor) {
- case 0:
- ret = smu_v13_0_set_pptable_v2_0(smu, table, size);
- break;
- case 1:
- ret = smu_v13_0_set_pptable_v2_1(smu, table, size, pptable_id);
- break;
- default:
- ret = -EINVAL;
- break;
- }
-
- return ret;
-}
-
int smu_v13_0_setup_pptable(struct smu_context *smu)
{
struct amdgpu_device *adev = smu->adev;
@@ -380,7 +299,7 @@ int smu_v13_0_setup_pptable(struct smu_context *smu)
if ((amdgpu_sriov_vf(adev) || !pptable_id) && (amdgpu_emu_mode != 1))
ret = smu_v13_0_get_pptable_from_vbios(smu, &table, &size);
else
- ret = smu_v13_0_get_pptable_from_firmware(smu, &table, &size,
pptable_id);
+ ret = smu_cmn_get_pptable_from_firmware(smu, &table, &size,
pptable_id);
if (ret)
return ret;
--
2.49.0