platform/x86: wmi: Add a new interface to read block data
authorAndy Lutomirski <luto@kernel.org>
Thu, 26 Nov 2015 02:19:26 +0000 (18:19 -0800)
committerDarren Hart (VMware) <dvhart@infradead.org>
Tue, 6 Jun 2017 17:15:19 +0000 (10:15 -0700)
wmi_query_block is unnecessarily indirect. Add a straightforward
method for wmi bus drivers to use to read block data.

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 4395d83ba9cc31526f6b62f811b14692832aa306..f8fdd48b78c40bf816f4dc9c236259b2231fff46 100644 (file)
@@ -244,19 +244,10 @@ u32 method_id, const struct acpi_buffer *in, struct acpi_buffer *out)
 }
 EXPORT_SYMBOL_GPL(wmi_evaluate_method);
 
-/**
- * wmi_query_block - Return contents of a WMI block
- * @guid_string: 36 char string of the form fa50ff2b-f2e8-45de-83fa-65417f2f49ba
- * @instance: Instance index
- * &out: Empty buffer to return the contents of the data block to
- *
- * Return the contents of an ACPI-WMI data block to a buffer
- */
-acpi_status wmi_query_block(const char *guid_string, u8 instance,
-struct acpi_buffer *out)
+static acpi_status __query_block(struct wmi_block *wblock, u8 instance,
+                                struct acpi_buffer *out)
 {
        struct guid_block *block = NULL;
-       struct wmi_block *wblock = NULL;
        acpi_handle handle;
        acpi_status status, wc_status = AE_ERROR;
        struct acpi_object_list input;
@@ -264,12 +255,9 @@ struct acpi_buffer *out)
        char method[5];
        char wc_method[5] = "WC";
 
-       if (!guid_string || !out)
+       if (!out)
                return AE_BAD_PARAMETER;
 
-       if (!find_guid(guid_string, &wblock))
-               return AE_ERROR;
-
        block = &wblock->gblock;
        handle = wblock->acpi_device->handle;
 
@@ -320,8 +308,42 @@ struct acpi_buffer *out)
 
        return status;
 }
+
+/**
+ * wmi_query_block - Return contents of a WMI block (deprecated)
+ * @guid_string: 36 char string of the form fa50ff2b-f2e8-45de-83fa-65417f2f49ba
+ * @instance: Instance index
+ * &out: Empty buffer to return the contents of the data block to
+ *
+ * Return the contents of an ACPI-WMI data block to a buffer
+ */
+acpi_status wmi_query_block(const char *guid_string, u8 instance,
+                           struct acpi_buffer *out)
+{
+       struct wmi_block *wblock;
+
+       if (!guid_string)
+               return AE_BAD_PARAMETER;
+
+       if (!find_guid(guid_string, &wblock))
+               return AE_ERROR;
+
+       return __query_block(wblock, instance, out);
+}
 EXPORT_SYMBOL_GPL(wmi_query_block);
 
+union acpi_object *wmidev_block_query(struct wmi_device *wdev, u8 instance)
+{
+       struct acpi_buffer out = { ACPI_ALLOCATE_BUFFER, NULL };
+       struct wmi_block *wblock = container_of(wdev, struct wmi_block, dev);
+
+       if (ACPI_FAILURE(__query_block(wblock, instance, &out)))
+               return NULL;
+
+       return (union acpi_object *)out.pointer;
+}
+EXPORT_SYMBOL_GPL(wmidev_block_query);
+
 /**
  * wmi_set_block - Write to a WMI block
  * @guid_string: 36 char string of the form fa50ff2b-f2e8-45de-83fa-65417f2f49ba
@@ -331,7 +353,7 @@ EXPORT_SYMBOL_GPL(wmi_query_block);
  * Write the contents of the input buffer to an ACPI-WMI data block
  */
 acpi_status wmi_set_block(const char *guid_string, u8 instance,
-const struct acpi_buffer *in)
+                         const struct acpi_buffer *in)
 {
        struct guid_block *block = NULL;
        struct wmi_block *wblock = NULL;
index c6eedfd94e7d45756ac31ef91b50403ce0435701..0ab25401948820d73830ac88ab1e02c86948d5c1 100644 (file)
@@ -29,6 +29,10 @@ struct wmi_device {
        bool readable, writeable;
 };
 
+/* Caller must kfree the result. */
+extern union acpi_object *wmidev_block_query(struct wmi_device *wdev,
+                                            u8 instance);
+
 struct wmi_device_id {
        const char *guid_string;
 };