Re: [PATCH] WMI: fix the incorrect wmi device may be chosen from BIOS's notification if multiple wmi devices exist in a system.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jul 19, 2012 at 09:43:21AM +0800, Alex Hung wrote:

> +static struct acpi_device *wmi_device;

If a machine exports multiple WMI interfaces then having a static 
acpi_device doesn't make sense here. Instead we probably need the API to 
take some sort of token (maybe just the wmi_device itself as an opaque 
blob) back to the calling driver and then have it use that whenever it 
makes a wmi call. There'd be some fixing up involved, but it should be 
mostly mechanical.

>  /*
>   * GUID parsing functions
>   */
> @@ -652,8 +654,9 @@ acpi_status wmi_get_event_data(u32 event, struct acpi_buffer *out)
>  
>  	list_for_each(p, &wmi_block_list) {
>  		wblock = list_entry(p, struct wmi_block, list);
> +		if (wmi_device != NULL && wmi_device->handle != wblock->handle)
> +			continue;
>  		gblock = &wblock->gblock;
> -
>  		if ((gblock->flags & ACPI_WMI_EVENT) &&
>  			(gblock->notify_id == event))
>  			return acpi_evaluate_object(wblock->handle, "_WED",
> @@ -900,6 +903,10 @@ static void acpi_wmi_notify(struct acpi_device *device, u32 event)
>  		wblock = list_entry(p, struct wmi_block, list);
>  		block = &wblock->gblock;
>  
> +		if (device->handle != wblock->handle)
> +			continue;
> +		wmi_device = device;
> +
>  		if ((block->flags & ACPI_WMI_EVENT) &&
>  			(block->notify_id == event)) {
>  			if (wblock->handler)
> -- 
> 1.7.9.5
> 
> --
> To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
-- 
Matthew Garrett | mjg59@xxxxxxxxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux