Commit 698e1641 authored by Herton Ronaldo Krzesinski's avatar Herton Ronaldo Krzesinski Committed by Matthew Garrett

classmate-laptop: little optimization for cmpc_rfkill_block

We don't need to call bios/acpi (cmpc_set_rfkill_wlan) if the blocked
state is already set to the same value (little optimization). This can
happen for example if we initialize the module with same initial
hardware state (rfkill core always call cmpc_rfkill_block on
initialization here).

Also GWRI method only accepts 0 or 1 for setting rfkill block, as can be
seen on AML code from acpidump->DSDT from a classmate sample I have, so
should be fine setting state only to 0 or 1 directly.
Signed-off-by: default avatarHerton Ronaldo Krzesinski <herton@mandriva.com.br>
Signed-off-by: default avatarMatthew Garrett <mjg@redhat.com>
Acked-by: default avatarThadeu Lima de Souza Cascardo <cascardo@holoscopio.com>
parent 58f6425e
...@@ -522,18 +522,20 @@ static int cmpc_rfkill_block(void *data, bool blocked) ...@@ -522,18 +522,20 @@ static int cmpc_rfkill_block(void *data, bool blocked)
acpi_status status; acpi_status status;
acpi_handle handle; acpi_handle handle;
unsigned long long state; unsigned long long state;
bool is_blocked;
handle = data; handle = data;
status = cmpc_get_rfkill_wlan(handle, &state); status = cmpc_get_rfkill_wlan(handle, &state);
if (ACPI_FAILURE(status)) if (ACPI_FAILURE(status))
return -ENODEV; return -ENODEV;
if (blocked) /* Check if we really need to call cmpc_set_rfkill_wlan */
state &= ~1; is_blocked = state & 1 ? false : true;
else if (is_blocked != blocked) {
state |= 1; state = blocked ? 0 : 1;
status = cmpc_set_rfkill_wlan(handle, state); status = cmpc_set_rfkill_wlan(handle, state);
if (ACPI_FAILURE(status)) if (ACPI_FAILURE(status))
return -ENODEV; return -ENODEV;
}
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment