]> git.hungrycats.org Git - linux/commitdiff
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)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 3 Apr 2024 13:11:45 +0000 (15:11 +0200)
commit ac9538f6007e1c80f1b8a62db7ecc391b4d78ae5 upstream.

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>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/mfd/intel-lpss-pci.c
drivers/mfd/intel-lpss.c
drivers/mfd/intel-lpss.h

index ae5759200622c463214cad7553396a2ca9888bf1..eb3b0195db2e8a3e87f1603a2234689f77427e85 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,
+       },
        { }
 };
 
 static int intel_lpss_pci_probe(struct pci_dev *pdev,
                                const struct pci_device_id *id)
 {
+       const struct pci_device_id *quirk_pci_info;
        struct intel_lpss_platform_info *info;
        int ret;
 
@@ -45,8 +51,9 @@ static int intel_lpss_pci_probe(struct pci_dev *pdev,
        info->mem = &pdev->resource[0];
        info->irq = pdev->irq;
 
-       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 00e7b578bb3e83a25194c93015439a1ad4c67dad..7af0a1fab062e31cb43d28e71a829b3ce999eb1e 100644 (file)
@@ -401,7 +401,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 062ce95b68b9ade80331f5b0cbb8b977e6ba79fa..f636059cbc71d4e5095892b4894bccc4225d989b 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;