diff options
author | Seth Forshee <seth.forshee@canonical.com> | 2011-01-14 15:54:39 -0600 |
---|---|---|
committer | Matthew Garrett <mjg@redhat.com> | 2011-02-21 17:06:20 -0500 |
commit | 5ffba7e696510c90e8327a2041764b2a60e56c6e (patch) | |
tree | a71e777556d1fd899f7ab2cb29830684f99e1589 /drivers/platform/x86/thinkpad_acpi.c | |
parent | bbb706079abe955a9e3f208f541de97d99449236 (diff) | |
download | kernel_samsung_smdk4412-5ffba7e696510c90e8327a2041764b2a60e56c6e.zip kernel_samsung_smdk4412-5ffba7e696510c90e8327a2041764b2a60e56c6e.tar.gz kernel_samsung_smdk4412-5ffba7e696510c90e8327a2041764b2a60e56c6e.tar.bz2 |
thinkpad_acpi: Always report scancodes for hotkeys
Some thinkpad hotkeys report key codes like KEY_FN_F8 when something
like KEY_VOLUMEDOWN is desired. Always provide the scan codes in
addition to the key codes to assist with debugging these issues. Also
send the scan code before the key code to match what other drivers do,
as some userspace utilities expect this ordering.
Signed-off-by: Seth Forshee <seth.forshee@canonical.com>
Signed-off-by: Matthew Garrett <mjg@redhat.com>
Diffstat (limited to 'drivers/platform/x86/thinkpad_acpi.c')
-rw-r--r-- | drivers/platform/x86/thinkpad_acpi.c | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c index dd59958..eb99223 100644 --- a/drivers/platform/x86/thinkpad_acpi.c +++ b/drivers/platform/x86/thinkpad_acpi.c @@ -2275,16 +2275,12 @@ static void tpacpi_input_send_key(const unsigned int scancode) if (keycode != KEY_RESERVED) { mutex_lock(&tpacpi_inputdev_send_mutex); + input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, scancode); input_report_key(tpacpi_inputdev, keycode, 1); - if (keycode == KEY_UNKNOWN) - input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, - scancode); input_sync(tpacpi_inputdev); + input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, scancode); input_report_key(tpacpi_inputdev, keycode, 0); - if (keycode == KEY_UNKNOWN) - input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, - scancode); input_sync(tpacpi_inputdev); mutex_unlock(&tpacpi_inputdev_send_mutex); |