intel_pstate: convert to use acpi_match_platform_list()
authorToshi Kani <toshi.kani@hpe.com>
Wed, 23 Aug 2017 22:54:44 +0000 (16:54 -0600)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Mon, 28 Aug 2017 23:42:49 +0000 (01:42 +0200)
Convert to use acpi_match_platform_list() for the platform check.
There is no change in functionality.

Signed-off-by: Toshi Kani <toshi.kani@hpe.com>
Acked-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Reviewed-by: Borislav Petkov <bp@suse.de>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/cpufreq/intel_pstate.c

index 65ee4fcace1f260632cf53c150c3260cc27240ad..ad713cd6b364215ad48b2920d775d54b3a32340a 100644 (file)
@@ -2466,39 +2466,31 @@ enum {
        PPC,
 };
 
-struct hw_vendor_info {
-       u16  valid;
-       char oem_id[ACPI_OEM_ID_SIZE];
-       char oem_table_id[ACPI_OEM_TABLE_ID_SIZE];
-       int  oem_pwr_table;
-};
-
 /* Hardware vendor-specific info that has its own power management modes */
-static struct hw_vendor_info vendor_info[] __initdata = {
-       {1, "HP    ", "ProLiant", PSS},
-       {1, "ORACLE", "X4-2    ", PPC},
-       {1, "ORACLE", "X4-2L   ", PPC},
-       {1, "ORACLE", "X4-2B   ", PPC},
-       {1, "ORACLE", "X3-2    ", PPC},
-       {1, "ORACLE", "X3-2L   ", PPC},
-       {1, "ORACLE", "X3-2B   ", PPC},
-       {1, "ORACLE", "X4470M2 ", PPC},
-       {1, "ORACLE", "X4270M3 ", PPC},
-       {1, "ORACLE", "X4270M2 ", PPC},
-       {1, "ORACLE", "X4170M2 ", PPC},
-       {1, "ORACLE", "X4170 M3", PPC},
-       {1, "ORACLE", "X4275 M3", PPC},
-       {1, "ORACLE", "X6-2    ", PPC},
-       {1, "ORACLE", "Sudbury ", PPC},
-       {0, "", ""},
+static struct acpi_platform_list plat_info[] __initdata = {
+       {"HP    ", "ProLiant", 0, ACPI_SIG_FADT, all_versions, 0, PSS},
+       {"ORACLE", "X4-2    ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4-2L   ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4-2B   ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X3-2    ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X3-2L   ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X3-2B   ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4470M2 ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4270M3 ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4270M2 ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4170M2 ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4170 M3", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X4275 M3", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "X6-2    ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       {"ORACLE", "Sudbury ", 0, ACPI_SIG_FADT, all_versions, 0, PPC},
+       { } /* End */
 };
 
 static bool __init intel_pstate_platform_pwr_mgmt_exists(void)
 {
-       struct acpi_table_header hdr;
-       struct hw_vendor_info *v_info;
        const struct x86_cpu_id *id;
        u64 misc_pwr;
+       int idx;
 
        id = x86_match_cpu(intel_pstate_cpu_oob_ids);
        if (id) {
@@ -2507,21 +2499,15 @@ static bool __init intel_pstate_platform_pwr_mgmt_exists(void)
                        return true;
        }
 
-       if (acpi_disabled ||
-           ACPI_FAILURE(acpi_get_table_header(ACPI_SIG_FADT, 0, &hdr)))
+       idx = acpi_match_platform_list(plat_info);
+       if (idx < 0)
                return false;
 
-       for (v_info = vendor_info; v_info->valid; v_info++) {
-               if (!strncmp(hdr.oem_id, v_info->oem_id, ACPI_OEM_ID_SIZE) &&
-                       !strncmp(hdr.oem_table_id, v_info->oem_table_id,
-                                               ACPI_OEM_TABLE_ID_SIZE))
-                       switch (v_info->oem_pwr_table) {
-                       case PSS:
-                               return intel_pstate_no_acpi_pss();
-                       case PPC:
-                               return intel_pstate_has_acpi_ppc() &&
-                                       (!force_load);
-                       }
+       switch (plat_info[idx].data) {
+       case PSS:
+               return intel_pstate_no_acpi_pss();
+       case PPC:
+               return intel_pstate_has_acpi_ppc() && !force_load;
        }
 
        return false;