]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
usb: typec: intel_pmc_mux: Add new ACPI ID for Meteor Lake IOM device
authorUtkarsh Patel <utkarsh.h.patel@intel.com>
Tue, 16 Aug 2022 10:16:24 +0000 (13:16 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 18 Aug 2022 19:10:19 +0000 (21:10 +0200)
This adds the necessary ACPI ID for Intel Meteor Lake
IOM devices.

The callback function is_memory() is modified so that it
also checks if the resource descriptor passed to it is a
memory type "Address Space Resource Descriptor".

On Intel Meteor Lake the ACPI memory resource is not
described using the "32-bit Memory Range Descriptor" because
the memory is outside of the 32-bit address space. The
memory resource is described using the "Address Space
Resource Descriptor" instead.

Intel Meteor Lake is the first platform to describe the
memory resource for this device with Address Space Resource
Descriptor, but it most likely will not be the last.
Therefore the change to the is_memory() callback function
is made generic.

Signed-off-by: Utkarsh Patel <utkarsh.h.patel@intel.com>
Cc: stable@vger.kernel.org
[ heikki: Rewrote the commit message. ]
Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Link: https://lore.kernel.org/r/20220816101629.69054-2-heikki.krogerus@linux.intel.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/mux/intel_pmc_mux.c

index 47b733f78fb0dbe86fb0066a254278e343c46762..a8e273fe204ab182192f1174359950f6603be511 100644 (file)
@@ -571,9 +571,11 @@ err_unregister_switch:
 
 static int is_memory(struct acpi_resource *res, void *data)
 {
-       struct resource r;
+       struct resource_win win = {};
+       struct resource *r = &win.res;
 
-       return !acpi_dev_resource_memory(res, &r);
+       return !(acpi_dev_resource_memory(res, r) ||
+                acpi_dev_resource_address_space(res, &win));
 }
 
 /* IOM ACPI IDs and IOM_PORT_STATUS_OFFSET */
@@ -583,6 +585,9 @@ static const struct acpi_device_id iom_acpi_ids[] = {
 
        /* AlderLake */
        { "INTC1079", 0x160, },
+
+       /* Meteor Lake */
+       { "INTC107A", 0x160, },
        {}
 };