]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
platform/x86: wmi: Add an interface for subdrivers to access sibling devices
authorAndy Lutomirski <luto@kernel.org>
Wed, 30 Dec 2015 06:53:51 +0000 (22:53 -0800)
committerDarren Hart (VMware) <dvhart@infradead.org>
Tue, 6 Jun 2017 17:15:19 +0000 (10:15 -0700)
Some subdrivers need to access sibling devices. This gives them a
clean way to do so.

Signed-off-by: Andy Lutomirski <luto@kernel.org>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Mario Limonciello <mario_limonciello@dell.com>
Cc: Pali Rohár <pali.rohar@gmail.com>
Cc: linux-kernel@vger.kernel.org
Cc: platform-driver-x86@vger.kernel.org
Cc: linux-acpi@vger.kernel.org
Acked-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Darren Hart (VMware) <dvhart@infradead.org>
drivers/platform/x86/wmi.c
include/linux/wmi.h

index 52452ec5099bc518cbf93fe8af444d28968bd137..250d7b2398b4c043df96f15bb7525494f7b88850 100644 (file)
@@ -344,6 +344,23 @@ union acpi_object *wmidev_block_query(struct wmi_device *wdev, u8 instance)
 }
 EXPORT_SYMBOL_GPL(wmidev_block_query);
 
+struct wmi_device *wmidev_get_other_guid(struct wmi_device *wdev,
+                                        const char *guid_string)
+{
+       struct wmi_block *this_wb = container_of(wdev, struct wmi_block, dev);
+       struct wmi_block *other_wb;
+
+       if (!find_guid(guid_string, &other_wb))
+               return NULL;
+
+       if (other_wb->acpi_device != this_wb->acpi_device)
+               return NULL;
+
+       get_device(&other_wb->dev.dev);
+       return &other_wb->dev;
+}
+EXPORT_SYMBOL_GPL(wmidev_get_other_guid);
+
 /**
  * wmi_set_block - Write to a WMI block
  * @guid_string: 36 char string of the form fa50ff2b-f2e8-45de-83fa-65417f2f49ba
index 0ab25401948820d73830ac88ab1e02c86948d5c1..a283768afb7ea50345e9e5ce8b30bacc495ea0ab 100644 (file)
@@ -33,6 +33,10 @@ struct wmi_device {
 extern union acpi_object *wmidev_block_query(struct wmi_device *wdev,
                                             u8 instance);
 
+/* Gets another device on the same bus.  Caller must put_device the result. */
+extern struct wmi_device *wmidev_get_other_guid(struct wmi_device *wdev,
+                                               const char *guid_string);
+
 struct wmi_device_id {
        const char *guid_string;
 };