mfd: intel-lpss: Switch to generalized quirk table
authorAleksandrs Vinarskis <alex.vinarskis@gmail.com>
Thu, 21 Dec 2023 18:51:41 +0000 (19:51 +0100)
committerLee Jones <lee@kernel.org>
Fri, 23 Feb 2024 14:58:00 +0000 (14:58 +0000)
Introduce generic quirk table, and port existing walkaround for select
Microsoft devices to it. This is a preparation for
QUIRK_CLOCK_DIVIDER_UNITY.

Signed-off-by: Aleksandrs Vinarskis <alex.vinarskis@gmail.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20231221185142.9224-2-alex.vinarskis@gmail.com
Signed-off-by: Lee Jones <lee@kernel.org>
drivers/mfd/intel-lpss-pci.c
drivers/mfd/intel-lpss.c
drivers/mfd/intel-lpss.h

index 4621d3950b8f9fab4c3ccc2ad650f14cf07c2749..07713a2f694f3243bf4eb35e217af542462f1af5 100644 (file)
 
 #include "intel-lpss.h"
 
-/* Some DSDTs have an unused GEXP ACPI device conflicting with I2C4 resources */
-static const struct pci_device_id ignore_resource_conflicts_ids[] = {
-       /* Microsoft Surface Go (version 1) I2C4 */
-       { PCI_DEVICE_SUB(PCI_VENDOR_ID_INTEL, 0x9d64, 0x152d, 0x1182), },
-       /* Microsoft Surface Go 2 I2C4 */
-       { PCI_DEVICE_SUB(PCI_VENDOR_ID_INTEL, 0x9d64, 0x152d, 0x1237), },
+static const struct pci_device_id quirk_ids[] = {
+       {
+               /* Microsoft Surface Go (version 1) I2C4 */
+               PCI_DEVICE_SUB(PCI_VENDOR_ID_INTEL, 0x9d64, 0x152d, 0x1182),
+               .driver_data = QUIRK_IGNORE_RESOURCE_CONFLICTS,
+       },
+       {
+               /* Microsoft Surface Go 2 I2C4 */
+               PCI_DEVICE_SUB(PCI_VENDOR_ID_INTEL, 0x9d64, 0x152d, 0x1237),
+               .driver_data = QUIRK_IGNORE_RESOURCE_CONFLICTS,
+       },
        { }
 };
 
@@ -36,6 +41,7 @@ static int intel_lpss_pci_probe(struct pci_dev *pdev,
                                const struct pci_device_id *id)
 {
        const struct intel_lpss_platform_info *data = (void *)id->driver_data;
+       const struct pci_device_id *quirk_pci_info;
        struct intel_lpss_platform_info *info;
        int ret;
 
@@ -55,8 +61,9 @@ static int intel_lpss_pci_probe(struct pci_dev *pdev,
        info->mem = pci_resource_n(pdev, 0);
        info->irq = pci_irq_vector(pdev, 0);
 
-       if (pci_match_id(ignore_resource_conflicts_ids, pdev))
-               info->ignore_resource_conflicts = true;
+       quirk_pci_info = pci_match_id(quirk_ids, pdev);
+       if (quirk_pci_info)
+               info->quirks = quirk_pci_info->driver_data;
 
        pdev->d3cold_delay = 0;
 
index eff423f7dd28475052fd7efdad8014a87b806983..aafa0da5f8dbfdeea229b8b4349dae8f174aecb8 100644 (file)
@@ -412,7 +412,7 @@ int intel_lpss_probe(struct device *dev,
                return ret;
 
        lpss->cell->swnode = info->swnode;
-       lpss->cell->ignore_resource_conflicts = info->ignore_resource_conflicts;
+       lpss->cell->ignore_resource_conflicts = info->quirks & QUIRK_IGNORE_RESOURCE_CONFLICTS;
 
        intel_lpss_init_dev(lpss);
 
index c1d72b117ed5e6e27faae391de1f604cf5f4b139..2fa9ef9162580e21db4b99f53a8a50909b0556bb 100644 (file)
 #ifndef __MFD_INTEL_LPSS_H
 #define __MFD_INTEL_LPSS_H
 
+#include <linux/bits.h>
 #include <linux/pm.h>
 
+/*
+ * Some DSDTs have an unused GEXP ACPI device conflicting with I2C4 resources.
+ * Set to ignore resource conflicts with ACPI declared SystemMemory regions.
+ */
+#define QUIRK_IGNORE_RESOURCE_CONFLICTS BIT(0)
+
 struct device;
 struct resource;
 struct software_node;
 
 struct intel_lpss_platform_info {
        struct resource *mem;
-       bool ignore_resource_conflicts;
        int irq;
+       unsigned int quirks;
        unsigned long clk_rate;
        const char *clk_con_id;
        const struct software_node *swnode;