On Tue, 09 May 2017, Andy Shevchenko wrote: > The commit 4be73005e4dc > > ("thinkpad-acpi: remove uneeded tp_features.hotkey tests in hotkey_exit") > > adds a complex logic behind hotkey status check in a way > it started mixing logical operations with bitwise ones. > > Refactor the code to make it straight and slightly clearer. Eh, I find this actually less clear, given the comment that was in the old code, which you deleted. Please keep the important part of the comment at the very least. > Signed-off-by: Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx> > --- > drivers/platform/x86/thinkpad_acpi.c | 9 ++++----- > 1 file changed, 4 insertions(+), 5 deletions(-) > > diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c > index 7b6cb0c69b02..7740b5e1b998 100644 > --- a/drivers/platform/x86/thinkpad_acpi.c > +++ b/drivers/platform/x86/thinkpad_acpi.c > @@ -3090,6 +3090,8 @@ static void tpacpi_send_radiosw_update(void) > > static void hotkey_exit(void) > { > + int res; > + > #ifdef CONFIG_THINKPAD_ACPI_HOTKEY_POLL > mutex_lock(&hotkey_mutex); > hotkey_poll_stop_sync(); > @@ -3101,11 +3103,8 @@ static void hotkey_exit(void) > > dbg_printk(TPACPI_DBG_EXIT | TPACPI_DBG_HKEY, > "restoring original HKEY status and mask\n"); > - /* yes, there is a bitwise or below, we want the > - * functions to be called even if one of them fail */ > - if (((tp_features.hotkey_mask && > - hotkey_mask_set(hotkey_orig_mask)) | > - hotkey_status_set(false)) != 0) > + res = tp_features.hotkey_mask ? hotkey_mask_set(hotkey_orig_mask) : 0; > + if (hotkey_status_set(false) || res) > pr_err("failed to restore hot key mask " > "to BIOS defaults\n"); > } -- Henrique Holschuh