mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	asus-wmi: record wlan status while controlled by userapp
If the user bit is set, that mean BIOS can't set and record the wlan status, it will report the value read from id ASUS_WMI_DEVID_WLAN_LED (0x00010012) while we query the wlan status by id ASUS_WMI_DEVID_WLAN (0x00010011) through WMI. So, we have to record wlan status in id ASUS_WMI_DEVID_WLAN_LED (0x00010012) while setting the wlan status through WMI. This is also the behavior that windows app will do. Quote from ASUS application engineer === When you call WMIMethod(DSTS, 0x00010011) to get WLAN status, it may return (1) 0x00050001 (On) (2) 0x00050000 (Off) (3) 0x00030001 (On) (4) 0x00030000 (Off) (5) 0x00000002 (Unknown) (1), (2) means that the model has hardware GPIO for WLAN, you can call WMIMethod(DEVS, 0x00010011, 1 or 0) to turn WLAN on/off. (3), (4) means that the model doesn’t have hardware GPIO, you need to use API or driver library to turn WLAN on/off, and call WMIMethod(DEVS, 0x00010012, 1 or 0) to set WLAN LED status. After you set WLAN LED status, you can see the WLAN status is changed with WMIMethod(DSTS, 0x00010011). Because the status is recorded lastly (ex: Windows), you can use it for synchronization. (5) means that the model doesn’t have WLAN device. WLAN is the ONLY special case with upper rule. For other device, like Bluetooth, you just need use WMIMethod(DSTS, 0x00010013) to get, and WMIMethod(DEVS, 0x00010013, 1 or 0) to set. === Signed-off-by: AceLan Kao <acelan.kao@canonical.com> Signed-off-by: Matthew Garrett <mjg@redhat.com>
This commit is contained in:
		
							parent
							
								
									9f6f955ae4
								
							
						
					
					
						commit
						a50bd128f2
					
				| @ -101,6 +101,7 @@ MODULE_LICENSE("GPL"); | |||||||
| #define ASUS_WMI_DEVID_WIRELESS_LED	0x00010002 | #define ASUS_WMI_DEVID_WIRELESS_LED	0x00010002 | ||||||
| #define ASUS_WMI_DEVID_CWAP		0x00010003 | #define ASUS_WMI_DEVID_CWAP		0x00010003 | ||||||
| #define ASUS_WMI_DEVID_WLAN		0x00010011 | #define ASUS_WMI_DEVID_WLAN		0x00010011 | ||||||
|  | #define ASUS_WMI_DEVID_WLAN_LED		0x00010012 | ||||||
| #define ASUS_WMI_DEVID_BLUETOOTH	0x00010013 | #define ASUS_WMI_DEVID_BLUETOOTH	0x00010013 | ||||||
| #define ASUS_WMI_DEVID_GPS		0x00010015 | #define ASUS_WMI_DEVID_GPS		0x00010015 | ||||||
| #define ASUS_WMI_DEVID_WIMAX		0x00010017 | #define ASUS_WMI_DEVID_WIMAX		0x00010017 | ||||||
| @ -731,8 +732,21 @@ static int asus_rfkill_set(void *data, bool blocked) | |||||||
| { | { | ||||||
| 	struct asus_rfkill *priv = data; | 	struct asus_rfkill *priv = data; | ||||||
| 	u32 ctrl_param = !blocked; | 	u32 ctrl_param = !blocked; | ||||||
|  | 	u32 dev_id = priv->dev_id; | ||||||
| 
 | 
 | ||||||
| 	return asus_wmi_set_devstate(priv->dev_id, ctrl_param, NULL); | 	/*
 | ||||||
|  | 	 * If the user bit is set, BIOS can't set and record the wlan status, | ||||||
|  | 	 * it will report the value read from id ASUS_WMI_DEVID_WLAN_LED | ||||||
|  | 	 * while we query the wlan status through WMI(ASUS_WMI_DEVID_WLAN). | ||||||
|  | 	 * So, we have to record wlan status in id ASUS_WMI_DEVID_WLAN_LED | ||||||
|  | 	 * while setting the wlan status through WMI. | ||||||
|  | 	 * This is also the behavior that windows app will do. | ||||||
|  | 	 */ | ||||||
|  | 	if ((dev_id == ASUS_WMI_DEVID_WLAN) && | ||||||
|  | 	     priv->asus->driver->wlan_ctrl_by_user) | ||||||
|  | 		dev_id = ASUS_WMI_DEVID_WLAN_LED; | ||||||
|  | 
 | ||||||
|  | 	return asus_wmi_set_devstate(dev_id, ctrl_param, NULL); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void asus_rfkill_query(struct rfkill *rfkill, void *data) | static void asus_rfkill_query(struct rfkill *rfkill, void *data) | ||||||
| @ -1653,6 +1667,7 @@ static int asus_wmi_add(struct platform_device *pdev) | |||||||
| 	struct asus_wmi *asus; | 	struct asus_wmi *asus; | ||||||
| 	acpi_status status; | 	acpi_status status; | ||||||
| 	int err; | 	int err; | ||||||
|  | 	u32 result; | ||||||
| 
 | 
 | ||||||
| 	asus = kzalloc(sizeof(struct asus_wmi), GFP_KERNEL); | 	asus = kzalloc(sizeof(struct asus_wmi), GFP_KERNEL); | ||||||
| 	if (!asus) | 	if (!asus) | ||||||
| @ -1711,6 +1726,10 @@ static int asus_wmi_add(struct platform_device *pdev) | |||||||
| 	if (err) | 	if (err) | ||||||
| 		goto fail_debugfs; | 		goto fail_debugfs; | ||||||
| 
 | 
 | ||||||
|  | 	asus_wmi_get_devstate(asus, ASUS_WMI_DEVID_WLAN, &result); | ||||||
|  | 	if (result & (ASUS_WMI_DSTS_PRESENCE_BIT | ASUS_WMI_DSTS_USER_BIT)) | ||||||
|  | 		asus->driver->wlan_ctrl_by_user = 1; | ||||||
|  | 
 | ||||||
| 	return 0; | 	return 0; | ||||||
| 
 | 
 | ||||||
| fail_debugfs: | fail_debugfs: | ||||||
|  | |||||||
| @ -46,6 +46,7 @@ struct quirk_entry { | |||||||
| struct asus_wmi_driver { | struct asus_wmi_driver { | ||||||
| 	int			brightness; | 	int			brightness; | ||||||
| 	int			panel_power; | 	int			panel_power; | ||||||
|  | 	int			wlan_ctrl_by_user; | ||||||
| 
 | 
 | ||||||
| 	const char		*name; | 	const char		*name; | ||||||
| 	struct module		*owner; | 	struct module		*owner; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 AceLan Kao
						AceLan Kao