diff options
-rw-r--r-- | drivers/misc/thinkpad_acpi.c | 82 |
1 files changed, 42 insertions, 40 deletions
diff --git a/drivers/misc/thinkpad_acpi.c b/drivers/misc/thinkpad_acpi.c index 49d4f4af759e..e7ac1c8a5541 100644 --- a/drivers/misc/thinkpad_acpi.c +++ b/drivers/misc/thinkpad_acpi.c | |||
@@ -852,6 +852,46 @@ static int hotkey_status_set(int status) | |||
852 | return 0; | 852 | return 0; |
853 | } | 853 | } |
854 | 854 | ||
855 | static void tpacpi_input_send_radiosw(void) | ||
856 | { | ||
857 | int wlsw; | ||
858 | |||
859 | mutex_lock(&tpacpi_inputdev_send_mutex); | ||
860 | |||
861 | if (tp_features.hotkey_wlsw && !hotkey_get_wlsw(&wlsw)) { | ||
862 | input_report_switch(tpacpi_inputdev, | ||
863 | SW_RADIO, !!wlsw); | ||
864 | input_sync(tpacpi_inputdev); | ||
865 | } | ||
866 | |||
867 | mutex_unlock(&tpacpi_inputdev_send_mutex); | ||
868 | } | ||
869 | |||
870 | static void tpacpi_input_send_key(unsigned int scancode) | ||
871 | { | ||
872 | unsigned int keycode; | ||
873 | |||
874 | keycode = hotkey_keycode_map[scancode]; | ||
875 | |||
876 | if (keycode != KEY_RESERVED) { | ||
877 | mutex_lock(&tpacpi_inputdev_send_mutex); | ||
878 | |||
879 | input_report_key(tpacpi_inputdev, keycode, 1); | ||
880 | if (keycode == KEY_UNKNOWN) | ||
881 | input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, | ||
882 | scancode); | ||
883 | input_sync(tpacpi_inputdev); | ||
884 | |||
885 | input_report_key(tpacpi_inputdev, keycode, 0); | ||
886 | if (keycode == KEY_UNKNOWN) | ||
887 | input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, | ||
888 | scancode); | ||
889 | input_sync(tpacpi_inputdev); | ||
890 | |||
891 | mutex_unlock(&tpacpi_inputdev_send_mutex); | ||
892 | } | ||
893 | } | ||
894 | |||
855 | /* sysfs hotkey enable ------------------------------------------------- */ | 895 | /* sysfs hotkey enable ------------------------------------------------- */ |
856 | static ssize_t hotkey_enable_show(struct device *dev, | 896 | static ssize_t hotkey_enable_show(struct device *dev, |
857 | struct device_attribute *attr, | 897 | struct device_attribute *attr, |
@@ -1290,47 +1330,10 @@ static void hotkey_exit(void) | |||
1290 | } | 1330 | } |
1291 | } | 1331 | } |
1292 | 1332 | ||
1293 | static void tpacpi_input_send_key(unsigned int scancode, | ||
1294 | unsigned int keycode) | ||
1295 | { | ||
1296 | if (keycode != KEY_RESERVED) { | ||
1297 | mutex_lock(&tpacpi_inputdev_send_mutex); | ||
1298 | |||
1299 | input_report_key(tpacpi_inputdev, keycode, 1); | ||
1300 | if (keycode == KEY_UNKNOWN) | ||
1301 | input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, | ||
1302 | scancode); | ||
1303 | input_sync(tpacpi_inputdev); | ||
1304 | |||
1305 | input_report_key(tpacpi_inputdev, keycode, 0); | ||
1306 | if (keycode == KEY_UNKNOWN) | ||
1307 | input_event(tpacpi_inputdev, EV_MSC, MSC_SCAN, | ||
1308 | scancode); | ||
1309 | input_sync(tpacpi_inputdev); | ||
1310 | |||
1311 | mutex_unlock(&tpacpi_inputdev_send_mutex); | ||
1312 | } | ||
1313 | } | ||
1314 | |||
1315 | static void tpacpi_input_send_radiosw(void) | ||
1316 | { | ||
1317 | int wlsw; | ||
1318 | |||
1319 | mutex_lock(&tpacpi_inputdev_send_mutex); | ||
1320 | |||
1321 | if (tp_features.hotkey_wlsw && !hotkey_get_wlsw(&wlsw)) { | ||
1322 | input_report_switch(tpacpi_inputdev, | ||
1323 | SW_RADIO, !!wlsw); | ||
1324 | input_sync(tpacpi_inputdev); | ||
1325 | } | ||
1326 | |||
1327 | mutex_unlock(&tpacpi_inputdev_send_mutex); | ||
1328 | } | ||
1329 | |||
1330 | static void hotkey_notify(struct ibm_struct *ibm, u32 event) | 1333 | static void hotkey_notify(struct ibm_struct *ibm, u32 event) |
1331 | { | 1334 | { |
1332 | u32 hkey; | 1335 | u32 hkey; |
1333 | unsigned int keycode, scancode; | 1336 | unsigned int scancode; |
1334 | int send_acpi_ev; | 1337 | int send_acpi_ev; |
1335 | int ignore_acpi_ev; | 1338 | int ignore_acpi_ev; |
1336 | 1339 | ||
@@ -1363,8 +1366,7 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event) | |||
1363 | scancode = hkey & 0xfff; | 1366 | scancode = hkey & 0xfff; |
1364 | if (scancode > 0 && scancode < 0x21) { | 1367 | if (scancode > 0 && scancode < 0x21) { |
1365 | scancode--; | 1368 | scancode--; |
1366 | keycode = hotkey_keycode_map[scancode]; | 1369 | tpacpi_input_send_key(scancode); |
1367 | tpacpi_input_send_key(scancode, keycode); | ||
1368 | } else { | 1370 | } else { |
1369 | printk(IBM_ERR | 1371 | printk(IBM_ERR |
1370 | "hotkey 0x%04x out of range for keyboard map\n", | 1372 | "hotkey 0x%04x out of range for keyboard map\n", |