platform/x86: intel_scu_wdt: Get rid of custom x86 model comparison
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Mon, 2 Jul 2018 17:45:36 +0000 (20:45 +0300)
committerAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Mon, 25 Jan 2021 18:05:32 +0000 (20:05 +0200)
Switch the platform code to use x86_id_table and accompanying API
instead of custom comparison against x86 CPU model.

This is one of the last users of custom API for that and following
changes will remove it for the good.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
drivers/platform/x86/intel_scu_wdt.c

index 19f7686a3c192e7342eada3b0e1407376ed84f31..85ee85ca2215ac7f6a6b035b85a33b5705759e76 100644 (file)
@@ -11,6 +11,8 @@
 #include <linux/platform_device.h>
 #include <linux/platform_data/intel-mid_wdt.h>
 
+#include <asm/cpu_device_id.h>
+#include <asm/intel-family.h>
 #include <asm/intel-mid.h>
 #include <asm/io_apic.h>
 #include <asm/hw_irq.h>
@@ -48,12 +50,20 @@ static struct intel_mid_wdt_pdata tangier_pdata = {
        .probe = tangier_probe,
 };
 
+static const struct x86_cpu_id intel_mid_cpu_ids[] = {
+       X86_MATCH_INTEL_FAM6_MODEL(ATOM_SILVERMONT_MID, &tangier_pdata),
+       {}
+};
+
 static int __init register_mid_wdt(void)
 {
-       if (intel_mid_identify_cpu() != INTEL_MID_CPU_CHIP_TANGIER)
+       const struct x86_cpu_id *id;
+
+       id = x86_match_cpu(intel_mid_cpu_ids);
+       if (!id)
                return -ENODEV;
 
-       wdt_dev.dev.platform_data = &tangier_pdata;
+       wdt_dev.dev.platform_data = (const struct intel_mid_wdt_pdata *)id->driver_data;
        return platform_device_register(&wdt_dev);
 }
 arch_initcall(register_mid_wdt);