[PATCH 1/2] platform/x86/amd: pmc: Add a helper for checking minimum SMU version

From: Mario Limonciello
Date: Wed Mar 01 2023 - 10:08:54 EST


In a few locations there is some boilerplate code for checking
minimum SMU version. Switch this to a helper for this check.

No intended functional changes.

Signed-off-by: Mario Limonciello <mario.limonciello@xxxxxxx>
---
drivers/platform/x86/amd/pmc.c | 49 +++++++++++++++++-----------------
1 file changed, 24 insertions(+), 25 deletions(-)

diff --git a/drivers/platform/x86/amd/pmc.c b/drivers/platform/x86/amd/pmc.c
index 2edaae04a691..c42fa47381c3 100644
--- a/drivers/platform/x86/amd/pmc.c
+++ b/drivers/platform/x86/amd/pmc.c
@@ -418,6 +418,22 @@ static int amd_pmc_get_smu_version(struct amd_pmc_dev *dev)
return 0;
}

+static bool amd_pmc_verify_min_version(struct amd_pmc_dev *pdev, int major, int minor)
+{
+ if (!pdev->major) {
+ int rc = amd_pmc_get_smu_version(pdev);
+
+ if (rc) {
+ dev_warn(pdev->dev, "failed to read SMU version: %d\n", rc);
+ return false;
+ }
+ }
+ if (pdev->major > major)
+ return true;
+
+ return pdev->major == major && pdev->minor >= minor;
+}
+
static ssize_t smu_fw_version_show(struct device *d, struct device_attribute *attr,
char *buf)
{
@@ -526,14 +542,7 @@ static int amd_pmc_idlemask_show(struct seq_file *s, void *unused)
struct amd_pmc_dev *dev = s->private;
int rc;

- /* we haven't yet read SMU version */
- if (!dev->major) {
- rc = amd_pmc_get_smu_version(dev);
- if (rc)
- return rc;
- }
-
- if (dev->major > 56 || (dev->major >= 55 && dev->minor >= 37)) {
+ if (amd_pmc_verify_min_version(dev, 55, 37)) {
rc = amd_pmc_idlemask_read(dev, NULL, s);
if (rc)
return rc;
@@ -686,15 +695,8 @@ static int amd_pmc_get_os_hint(struct amd_pmc_dev *dev)
static int amd_pmc_czn_wa_irq1(struct amd_pmc_dev *pdev)
{
struct device *d;
- int rc;

- if (!pdev->major) {
- rc = amd_pmc_get_smu_version(pdev);
- if (rc)
- return rc;
- }
-
- if (pdev->major > 64 || (pdev->major == 64 && pdev->minor > 65))
+ if (amd_pmc_verify_min_version(pdev, 64, 66))
return 0;

d = bus_find_device_by_name(&serio_bus, NULL, "serio0");
@@ -718,14 +720,10 @@ static int amd_pmc_verify_czn_rtc(struct amd_pmc_dev *pdev, u32 *arg)
struct rtc_time tm;
int rc;

- /* we haven't yet read SMU version */
- if (!pdev->major) {
- rc = amd_pmc_get_smu_version(pdev);
- if (rc)
- return rc;
- }
+ if (disable_workarounds)
+ return 0;

- if (pdev->major < 64 || (pdev->major == 64 && pdev->minor < 53))
+ if (!amd_pmc_verify_min_version(pdev, 64, 53))
return 0;

rtc_device = rtc_class_open("rtc0");
@@ -772,13 +770,14 @@ static void amd_pmc_s2idle_prepare(void)
/* Reset and Start SMU logging - to monitor the s0i3 stats */
amd_pmc_setup_smu_logging(pdev);

- /* Activate CZN specific platform bug workarounds */
- if (pdev->cpu_id == AMD_CPU_ID_CZN && !disable_workarounds) {
+ switch (pdev->cpu_id) {
+ case AMD_CPU_ID_CZN:
rc = amd_pmc_verify_czn_rtc(pdev, &arg);
if (rc) {
dev_err(pdev->dev, "failed to set RTC: %d\n", rc);
return;
}
+ break;
}

msg = amd_pmc_get_os_hint(pdev);
--
2.34.1