aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/platform/x86/thinkpad_acpi.c92
1 files changed, 69 insertions, 23 deletions
diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c
index ffd584c35808..3910f2f3eada 100644
--- a/drivers/platform/x86/thinkpad_acpi.c
+++ b/drivers/platform/x86/thinkpad_acpi.c
@@ -145,6 +145,51 @@ enum {
145 TP_ACPI_WGSV_STATE_UWBPWR = 0x0020, /* UWB radio enabled */ 145 TP_ACPI_WGSV_STATE_UWBPWR = 0x0020, /* UWB radio enabled */
146}; 146};
147 147
148/* HKEY events */
149enum tpacpi_hkey_event_t {
150 /* Hotkey-related */
151 TP_HKEY_EV_HOTKEY_BASE = 0x1001, /* first hotkey (FN+F1) */
152 TP_HKEY_EV_BRGHT_UP = 0x1010, /* Brightness up */
153 TP_HKEY_EV_BRGHT_DOWN = 0x1011, /* Brightness down */
154 TP_HKEY_EV_VOL_UP = 0x1015, /* Volume up or unmute */
155 TP_HKEY_EV_VOL_DOWN = 0x1016, /* Volume down or unmute */
156 TP_HKEY_EV_VOL_MUTE = 0x1017, /* Mixer output mute */
157
158 /* Reasons for waking up from S3/S4 */
159 TP_HKEY_EV_WKUP_S3_UNDOCK = 0x2304, /* undock requested, S3 */
160 TP_HKEY_EV_WKUP_S4_UNDOCK = 0x2404, /* undock requested, S4 */
161 TP_HKEY_EV_WKUP_S3_BAYEJ = 0x2305, /* bay ejection req, S3 */
162 TP_HKEY_EV_WKUP_S4_BAYEJ = 0x2405, /* bay ejection req, S4 */
163 TP_HKEY_EV_WKUP_S3_BATLOW = 0x2313, /* battery empty, S3 */
164 TP_HKEY_EV_WKUP_S4_BATLOW = 0x2413, /* battery empty, S4 */
165
166 /* Auto-sleep after eject request */
167 TP_HKEY_EV_BAYEJ_ACK = 0x3003, /* bay ejection complete */
168 TP_HKEY_EV_UNDOCK_ACK = 0x4003, /* undock complete */
169
170 /* Misc bay events */
171 TP_HKEY_EV_OPTDRV_EJ = 0x3006, /* opt. drive tray ejected */
172
173 /* User-interface events */
174 TP_HKEY_EV_LID_CLOSE = 0x5001, /* laptop lid closed */
175 TP_HKEY_EV_LID_OPEN = 0x5002, /* laptop lid opened */
176 TP_HKEY_EV_TABLET_TABLET = 0x5009, /* tablet swivel up */
177 TP_HKEY_EV_TABLET_NOTEBOOK = 0x500a, /* tablet swivel down */
178 TP_HKEY_EV_PEN_INSERTED = 0x500b, /* tablet pen inserted */
179 TP_HKEY_EV_PEN_REMOVED = 0x500c, /* tablet pen removed */
180 TP_HKEY_EV_BRGHT_CHANGED = 0x5010, /* backlight control event */
181
182 /* Thermal events */
183 TP_HKEY_EV_ALARM_BAT_HOT = 0x6011, /* battery too hot */
184 TP_HKEY_EV_ALARM_BAT_XHOT = 0x6012, /* battery critically hot */
185 TP_HKEY_EV_ALARM_SENSOR_HOT = 0x6021, /* sensor too hot */
186 TP_HKEY_EV_ALARM_SENSOR_XHOT = 0x6022, /* sensor critically hot */
187 TP_HKEY_EV_THM_TABLE_CHANGED = 0x6030, /* thermal table changed */
188
189 /* Misc */
190 TP_HKEY_EV_RFKILL_CHANGED = 0x7000, /* rfkill switch changed */
191};
192
148/**************************************************************************** 193/****************************************************************************
149 * Main driver 194 * Main driver
150 */ 195 */
@@ -2273,7 +2318,7 @@ static void tpacpi_hotkey_send_key(unsigned int scancode)
2273 tpacpi_input_send_key_masked(scancode); 2318 tpacpi_input_send_key_masked(scancode);
2274 if (hotkey_report_mode < 2) { 2319 if (hotkey_report_mode < 2) {
2275 acpi_bus_generate_proc_event(ibm_hotkey_acpidriver.device, 2320 acpi_bus_generate_proc_event(ibm_hotkey_acpidriver.device,
2276 0x80, 0x1001 + scancode); 2321 0x80, TP_HKEY_EV_HOTKEY_BASE + scancode);
2277 } 2322 }
2278} 2323}
2279 2324
@@ -3420,20 +3465,20 @@ static bool hotkey_notify_wakeup(const u32 hkey,
3420 *ignore_acpi_ev = false; 3465 *ignore_acpi_ev = false;
3421 3466
3422 switch (hkey) { 3467 switch (hkey) {
3423 case 0x2304: /* suspend, undock */ 3468 case TP_HKEY_EV_WKUP_S3_UNDOCK: /* suspend, undock */
3424 case 0x2404: /* hibernation, undock */ 3469 case TP_HKEY_EV_WKUP_S4_UNDOCK: /* hibernation, undock */
3425 hotkey_wakeup_reason = TP_ACPI_WAKEUP_UNDOCK; 3470 hotkey_wakeup_reason = TP_ACPI_WAKEUP_UNDOCK;
3426 *ignore_acpi_ev = true; 3471 *ignore_acpi_ev = true;
3427 break; 3472 break;
3428 3473
3429 case 0x2305: /* suspend, bay eject */ 3474 case TP_HKEY_EV_WKUP_S3_BAYEJ: /* suspend, bay eject */
3430 case 0x2405: /* hibernation, bay eject */ 3475 case TP_HKEY_EV_WKUP_S4_BAYEJ: /* hibernation, bay eject */
3431 hotkey_wakeup_reason = TP_ACPI_WAKEUP_BAYEJ; 3476 hotkey_wakeup_reason = TP_ACPI_WAKEUP_BAYEJ;
3432 *ignore_acpi_ev = true; 3477 *ignore_acpi_ev = true;
3433 break; 3478 break;
3434 3479
3435 case 0x2313: /* Battery on critical low level (S3) */ 3480 case TP_HKEY_EV_WKUP_S3_BATLOW: /* Battery on critical low level/S3 */
3436 case 0x2413: /* Battery on critical low level (S4) */ 3481 case TP_HKEY_EV_WKUP_S4_BATLOW: /* Battery on critical low level/S4 */
3437 printk(TPACPI_ALERT 3482 printk(TPACPI_ALERT
3438 "EMERGENCY WAKEUP: battery almost empty\n"); 3483 "EMERGENCY WAKEUP: battery almost empty\n");
3439 /* how to auto-heal: */ 3484 /* how to auto-heal: */
@@ -3463,20 +3508,20 @@ static bool hotkey_notify_usrevent(const u32 hkey,
3463 *ignore_acpi_ev = false; 3508 *ignore_acpi_ev = false;
3464 3509
3465 switch (hkey) { 3510 switch (hkey) {
3466 case 0x500b: /* X61t: tablet pen inserted into bay */ 3511 case TP_HKEY_EV_PEN_INSERTED: /* X61t: tablet pen inserted into bay */
3467 case 0x500c: /* X61t: tablet pen removed from bay */ 3512 case TP_HKEY_EV_PEN_REMOVED: /* X61t: tablet pen removed from bay */
3468 return true; 3513 return true;
3469 3514
3470 case 0x5009: /* X41t-X61t: swivel up (tablet mode) */ 3515 case TP_HKEY_EV_TABLET_TABLET: /* X41t-X61t: tablet mode */
3471 case 0x500a: /* X41t-X61t: swivel down (normal mode) */ 3516 case TP_HKEY_EV_TABLET_NOTEBOOK: /* X41t-X61t: normal mode */
3472 tpacpi_input_send_tabletsw(); 3517 tpacpi_input_send_tabletsw();
3473 hotkey_tablet_mode_notify_change(); 3518 hotkey_tablet_mode_notify_change();
3474 *send_acpi_ev = false; 3519 *send_acpi_ev = false;
3475 return true; 3520 return true;
3476 3521
3477 case 0x5001: /* Lid close */ 3522 case TP_HKEY_EV_LID_CLOSE: /* Lid closed */
3478 case 0x5002: /* Lid open */ 3523 case TP_HKEY_EV_LID_OPEN: /* Lid opened */
3479 case 0x5010: /* brightness control */ 3524 case TP_HKEY_EV_BRGHT_CHANGED: /* brightness changed */
3480 /* do not propagate these events */ 3525 /* do not propagate these events */
3481 *ignore_acpi_ev = true; 3526 *ignore_acpi_ev = true;
3482 return true; 3527 return true;
@@ -3495,30 +3540,30 @@ static bool hotkey_notify_thermal(const u32 hkey,
3495 *ignore_acpi_ev = false; 3540 *ignore_acpi_ev = false;
3496 3541
3497 switch (hkey) { 3542 switch (hkey) {
3498 case 0x6011: 3543 case TP_HKEY_EV_ALARM_BAT_HOT:
3499 printk(TPACPI_CRIT 3544 printk(TPACPI_CRIT
3500 "THERMAL ALARM: battery is too hot!\n"); 3545 "THERMAL ALARM: battery is too hot!\n");
3501 /* recommended action: warn user through gui */ 3546 /* recommended action: warn user through gui */
3502 return true; 3547 return true;
3503 case 0x6012: 3548 case TP_HKEY_EV_ALARM_BAT_XHOT:
3504 printk(TPACPI_ALERT 3549 printk(TPACPI_ALERT
3505 "THERMAL EMERGENCY: battery is extremely hot!\n"); 3550 "THERMAL EMERGENCY: battery is extremely hot!\n");
3506 /* recommended action: immediate sleep/hibernate */ 3551 /* recommended action: immediate sleep/hibernate */
3507 return true; 3552 return true;
3508 case 0x6021: 3553 case TP_HKEY_EV_ALARM_SENSOR_HOT:
3509 printk(TPACPI_CRIT 3554 printk(TPACPI_CRIT
3510 "THERMAL ALARM: " 3555 "THERMAL ALARM: "
3511 "a sensor reports something is too hot!\n"); 3556 "a sensor reports something is too hot!\n");
3512 /* recommended action: warn user through gui, that */ 3557 /* recommended action: warn user through gui, that */
3513 /* some internal component is too hot */ 3558 /* some internal component is too hot */
3514 return true; 3559 return true;
3515 case 0x6022: 3560 case TP_HKEY_EV_ALARM_SENSOR_XHOT:
3516 printk(TPACPI_ALERT 3561 printk(TPACPI_ALERT
3517 "THERMAL EMERGENCY: " 3562 "THERMAL EMERGENCY: "
3518 "a sensor reports something is extremely hot!\n"); 3563 "a sensor reports something is extremely hot!\n");
3519 /* recommended action: immediate sleep/hibernate */ 3564 /* recommended action: immediate sleep/hibernate */
3520 return true; 3565 return true;
3521 case 0x6030: 3566 case TP_HKEY_EV_THM_TABLE_CHANGED:
3522 printk(TPACPI_INFO 3567 printk(TPACPI_INFO
3523 "EC reports that Thermal Table has changed\n"); 3568 "EC reports that Thermal Table has changed\n");
3524 /* recommended action: do nothing, we don't have 3569 /* recommended action: do nothing, we don't have
@@ -3576,7 +3621,7 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event)
3576 break; 3621 break;
3577 case 3: 3622 case 3:
3578 /* 0x3000-0x3FFF: bay-related wakeups */ 3623 /* 0x3000-0x3FFF: bay-related wakeups */
3579 if (hkey == 0x3003) { 3624 if (hkey == TP_HKEY_EV_BAYEJ_ACK) {
3580 hotkey_autosleep_ack = 1; 3625 hotkey_autosleep_ack = 1;
3581 printk(TPACPI_INFO 3626 printk(TPACPI_INFO
3582 "bay ejected\n"); 3627 "bay ejected\n");
@@ -3588,7 +3633,7 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event)
3588 break; 3633 break;
3589 case 4: 3634 case 4:
3590 /* 0x4000-0x4FFF: dock-related wakeups */ 3635 /* 0x4000-0x4FFF: dock-related wakeups */
3591 if (hkey == 0x4003) { 3636 if (hkey == TP_HKEY_EV_UNDOCK_ACK) {
3592 hotkey_autosleep_ack = 1; 3637 hotkey_autosleep_ack = 1;
3593 printk(TPACPI_INFO 3638 printk(TPACPI_INFO
3594 "undocked\n"); 3639 "undocked\n");
@@ -3610,7 +3655,8 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event)
3610 break; 3655 break;
3611 case 7: 3656 case 7:
3612 /* 0x7000-0x7FFF: misc */ 3657 /* 0x7000-0x7FFF: misc */
3613 if (tp_features.hotkey_wlsw && hkey == 0x7000) { 3658 if (tp_features.hotkey_wlsw &&
3659 hkey == TP_HKEY_EV_RFKILL_CHANGED) {
3614 tpacpi_send_radiosw_update(); 3660 tpacpi_send_radiosw_update();
3615 send_acpi_ev = 0; 3661 send_acpi_ev = 0;
3616 known_ev = true; 3662 known_ev = true;
@@ -7670,7 +7716,7 @@ static void tpacpi_driver_event(const unsigned int hkey_event)
7670 7716
7671static void hotkey_driver_event(const unsigned int scancode) 7717static void hotkey_driver_event(const unsigned int scancode)
7672{ 7718{
7673 tpacpi_driver_event(0x1001 + scancode); 7719 tpacpi_driver_event(TP_HKEY_EV_HOTKEY_BASE + scancode);
7674} 7720}
7675 7721
7676/* sysfs name ---------------------------------------------------------- */ 7722/* sysfs name ---------------------------------------------------------- */