Skip to content

Commit 1aeded2

Browse files
Wer-Wolfij-intel
authored andcommitted
platform/wmi: Extend wmidev_query_block() to reject undersized data
WMI drivers using the buffer-based WMI API are expected to reject undersized query results. Extend wmidev_query_block() to enable the WMI driver core to perform this size check internally. Signed-off-by: Armin Wolf <W_Armin@gmx.de> Link: https://patch.msgid.link/20260406203237.2970-6-W_Armin@gmx.de Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com> Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
1 parent 96b1b05 commit 1aeded2

4 files changed

Lines changed: 10 additions & 12 deletions

File tree

drivers/platform/wmi/core.c

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -565,13 +565,15 @@ EXPORT_SYMBOL_GPL(wmidev_block_query);
565565
* @wdev: A wmi bus device from a driver
566566
* @instance: Instance index
567567
* @out: WMI buffer to fill
568+
* @min_size: Minimum size of the result data in bytes
568569
*
569-
* Query a WMI data block, the caller must free the resulting data inside @out.
570-
* Said data is guaranteed to be aligned on a 8-byte boundary.
570+
* Query a WMI data block, the caller must free the resulting data inside @out
571+
* using kfree(). Said data is guaranteed to be aligned on a 8-byte boundary.
571572
*
572573
* Return: 0 on success or a negative error code on failure.
573574
*/
574-
int wmidev_query_block(struct wmi_device *wdev, u8 instance, struct wmi_buffer *out)
575+
int wmidev_query_block(struct wmi_device *wdev, u8 instance, struct wmi_buffer *out,
576+
size_t min_size)
575577
{
576578
union acpi_object *obj;
577579
int ret;
@@ -580,7 +582,7 @@ int wmidev_query_block(struct wmi_device *wdev, u8 instance, struct wmi_buffer *
580582
if (!obj)
581583
return -EIO;
582584

583-
ret = wmi_unmarshal_acpi_object(obj, out, 0);
585+
ret = wmi_unmarshal_acpi_object(obj, out, min_size);
584586
kfree(obj);
585587

586588
return ret;

drivers/platform/x86/intel/wmi/sbl-fw-update.c

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -28,15 +28,10 @@ static int get_fwu_request(struct device *dev, u32 *out)
2828
__le32 *result;
2929
int ret;
3030

31-
ret = wmidev_query_block(to_wmi_device(dev), 0, &buffer);
31+
ret = wmidev_query_block(to_wmi_device(dev), 0, &buffer, sizeof(*result));
3232
if (ret < 0)
3333
return ret;
3434

35-
if (buffer.length < sizeof(*result)) {
36-
kfree(buffer.data);
37-
return -ENODATA;
38-
}
39-
4035
result = buffer.data;
4136
*out = le32_to_cpu(*result);
4237
kfree(result);

drivers/platform/x86/wmi-bmof.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ static int wmi_bmof_probe(struct wmi_device *wdev, const void *context)
6262
if (!buffer)
6363
return -ENOMEM;
6464

65-
ret = wmidev_query_block(wdev, 0, buffer);
65+
ret = wmidev_query_block(wdev, 0, buffer, 0);
6666
if (ret < 0)
6767
return ret;
6868

include/linux/wmi.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -73,7 +73,8 @@ int wmidev_invoke_method(struct wmi_device *wdev, u8 instance, u32 method_id,
7373
int wmidev_invoke_procedure(struct wmi_device *wdev, u8 instance, u32 method_id,
7474
const struct wmi_buffer *in);
7575

76-
int wmidev_query_block(struct wmi_device *wdev, u8 instance, struct wmi_buffer *out);
76+
int wmidev_query_block(struct wmi_device *wdev, u8 instance, struct wmi_buffer *out,
77+
size_t min_size);
7778

7879
int wmidev_set_block(struct wmi_device *wdev, u8 instance, const struct wmi_buffer *in);
7980

0 commit comments

Comments
 (0)