Skip to content

Commit

Permalink
thinkpad-acpi: remove HKEY disable functionality
Browse files Browse the repository at this point in the history
The HKEY disable functionality basically cripples the entire event
model of the ThinkPad firmware and of the thinkpad-acpi driver.
Remove this functionality from the driver.  HKEY must be enabled at
all times while thinkpad-acpi is loaded, and disabled otherwise.

For sysfs, according to the sysfs ABI and the thinkpad-acpi sysfs
rules of engagement, we will just remove the attributes.  This will be
done in two stages: disable their function now, after two kernel
releases, remove the attributes.

For procfs, we call WARN().  If nothing triggers it, I will simply
remove the enable/disable commands entirely in the future along with
the sysfs attributes.

I don't expect much, if any fallout from this.  There really isn't any
reason to mess with hotkey_enable or with the enable/disable commands
to /proc/acpi/ibm/hotkey, and this has been true for years...

Signed-off-by: Henrique de Moraes Holschuh <hmh@hmh.eng.br>
Signed-off-by: Len Brown <len.brown@intel.com>
  • Loading branch information
Henrique de Moraes Holschuh authored and Len Brown committed Apr 4, 2009
1 parent 73a94d8 commit 2586d56
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 42 deletions.
39 changes: 19 additions & 20 deletions Documentation/laptops/thinkpad-acpi.txt
Original file line number Diff line number Diff line change
Expand Up @@ -179,17 +179,14 @@ system. Enabling the hotkey functionality of thinkpad-acpi signals the
firmware that such a driver is present, and modifies how the ThinkPad
firmware will behave in many situations.

The driver enables the hot key feature automatically when loaded. The
feature can later be disabled and enabled back at runtime. The driver
will also restore the hot key feature to its previous state and mask
when it is unloaded.
The driver enables the HKEY ("hot key") event reporting automatically
when loaded, and disables it when it is removed.

When the hotkey feature is enabled and the hot key mask is set (see
below), the driver will report HKEY events in the following format:
The driver will report HKEY events in the following format:

ibm/hotkey HKEY 00000080 0000xxxx

Some of these events refer to hot key presses, but not all.
Some of these events refer to hot key presses, but not all of them.

The driver will generate events over the input layer for hot keys and
radio switches, and over the ACPI netlink layer for other events. The
Expand Down Expand Up @@ -221,13 +218,17 @@ procfs notes:

The following commands can be written to the /proc/acpi/ibm/hotkey file:

echo enable > /proc/acpi/ibm/hotkey -- enable the hot keys feature
echo disable > /proc/acpi/ibm/hotkey -- disable the hot keys feature
echo 0xffffffff > /proc/acpi/ibm/hotkey -- enable all hot keys
echo 0 > /proc/acpi/ibm/hotkey -- disable all possible hot keys
... any other 8-hex-digit mask ...
echo reset > /proc/acpi/ibm/hotkey -- restore the original mask

The following commands have been deprecated and will cause the kernel
to log a warning:

echo enable > /proc/acpi/ibm/hotkey -- does nothing
echo disable > /proc/acpi/ibm/hotkey -- returns an error

The procfs interface does not support NVRAM polling control. So as to
maintain maximum bug-to-bug compatibility, it does not report any masks,
nor does it allow one to manipulate the hot key mask when the firmware
Expand All @@ -236,26 +237,20 @@ does not support masks at all, even if NVRAM polling is in use.
sysfs notes:

hotkey_bios_enabled:
Returns the status of the hot keys feature when
thinkpad-acpi was loaded. Upon module unload, the hot
key feature status will be restored to this value.
DEPRECATED, WILL BE REMOVED SOON.

0: hot keys were disabled
1: hot keys were enabled (unusual)
Returns 0.

hotkey_bios_mask:
Returns the hot keys mask when thinkpad-acpi was loaded.
Upon module unload, the hot keys mask will be restored
to this value.

hotkey_enable:
Enables/disables the hot keys feature in the ACPI
firmware, and reports current status of the hot keys
feature. Has no effect on the NVRAM hot key polling
functionality.
DEPRECATED, WILL BE REMOVED SOON.

0: disables the hot keys feature / feature disabled
1: enables the hot keys feature / feature enabled
0: returns -EPERM
1: does nothing

hotkey_mask:
bit mask to enable driver-handling (and depending on
Expand Down Expand Up @@ -1535,3 +1530,7 @@ Sysfs interface changelog:

0x020200: Add poll()/select() support to the following attributes:
hotkey_radio_sw, wakeup_hotunplug_complete, wakeup_reason

0x020300: hotkey enable/disable support removed, attributes
hotkey_bios_enabled and hotkey_enable deprecated and
marked for removal.
49 changes: 27 additions & 22 deletions drivers/platform/x86/thinkpad_acpi.c
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
*/

#define TPACPI_VERSION "0.22"
#define TPACPI_SYSFS_VERSION 0x020200
#define TPACPI_SYSFS_VERSION 0x020300

/*
* Changelog:
Expand Down Expand Up @@ -1424,7 +1424,6 @@ static enum { /* Reasons for waking up */

static int hotkey_autosleep_ack;

static int hotkey_orig_status;
static u32 hotkey_orig_mask;
static u32 hotkey_all_mask;
static u32 hotkey_reserved_mask;
Expand Down Expand Up @@ -1571,9 +1570,9 @@ static int hotkey_status_get(int *status)
return 0;
}

static int hotkey_status_set(int status)
static int hotkey_status_set(bool enable)
{
if (!acpi_evalf(hkey_handle, NULL, "MHKC", "vd", status))
if (!acpi_evalf(hkey_handle, NULL, "MHKC", "vd", enable ? 1 : 0))
return -EIO;

return 0;
Expand Down Expand Up @@ -1889,6 +1888,9 @@ static ssize_t hotkey_enable_show(struct device *dev,
{
int res, status;

printk_deprecated_attribute("hotkey_enable",
"Hotkey reporting is always enabled");

res = hotkey_status_get(&status);
if (res)
return res;
Expand All @@ -1901,14 +1903,17 @@ static ssize_t hotkey_enable_store(struct device *dev,
const char *buf, size_t count)
{
unsigned long t;
int res;

printk_deprecated_attribute("hotkey_enable",
"Hotkeys can be disabled through hotkey_mask");

if (parse_strtoul(buf, 1, &t))
return -EINVAL;

res = hotkey_status_set(t);
if (t == 0)
return -EPERM;

return (res) ? res : count;
return count;
}

static struct device_attribute dev_attr_hotkey_enable =
Expand Down Expand Up @@ -1964,7 +1969,7 @@ static ssize_t hotkey_bios_enabled_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{
return snprintf(buf, PAGE_SIZE, "%d\n", hotkey_orig_status);
return sprintf(buf, "0\n");
}

static struct device_attribute dev_attr_hotkey_bios_enabled =
Expand Down Expand Up @@ -2243,7 +2248,7 @@ static void hotkey_exit(void)
"restoring original hot key mask\n");
/* no short-circuit boolean operator below! */
if ((hotkey_mask_set(hotkey_orig_mask) |
hotkey_status_set(hotkey_orig_status)) != 0)
hotkey_status_set(false)) != 0)
printk(TPACPI_ERR
"failed to restore hot key mask "
"to BIOS defaults\n");
Expand Down Expand Up @@ -2438,10 +2443,6 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)

/* hotkey_source_mask *must* be zero for
* the first hotkey_mask_get */
res = hotkey_status_get(&hotkey_orig_status);
if (res)
goto err_exit;

if (tp_features.hotkey_mask) {
res = hotkey_mask_get();
if (res)
Expand Down Expand Up @@ -2581,7 +2582,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)
}

dbg_printk(TPACPI_DBG_INIT, "enabling hot key handling\n");
res = hotkey_status_set(1);
res = hotkey_status_set(true);
if (res) {
hotkey_exit();
return res;
Expand Down Expand Up @@ -2926,9 +2927,17 @@ static int hotkey_read(char *p)
return len;
}

static void hotkey_enabledisable_warn(void)
{
tpacpi_log_usertask("procfs hotkey enable/disable");
WARN(1, TPACPI_WARN
"hotkey enable/disable functionality has been "
"removed from the driver. Hotkeys are always enabled.\n");
}

static int hotkey_write(char *buf)
{
int res, status;
int res;
u32 mask;
char *cmd;

Expand All @@ -2938,17 +2947,16 @@ static int hotkey_write(char *buf)
if (mutex_lock_killable(&hotkey_mutex))
return -ERESTARTSYS;

status = -1;
mask = hotkey_mask;

res = 0;
while ((cmd = next_cmd(&buf))) {
if (strlencmp(cmd, "enable") == 0) {
status = 1;
hotkey_enabledisable_warn();
} else if (strlencmp(cmd, "disable") == 0) {
status = 0;
hotkey_enabledisable_warn();
res = -EPERM;
} else if (strlencmp(cmd, "reset") == 0) {
status = hotkey_orig_status;
mask = hotkey_orig_mask;
} else if (sscanf(cmd, "0x%x", &mask) == 1) {
/* mask set */
Expand All @@ -2959,9 +2967,6 @@ static int hotkey_write(char *buf)
goto errexit;
}
}
if (status != -1)
res = hotkey_status_set(status);

if (!res && mask != hotkey_mask)
res = hotkey_mask_set(mask);

Expand Down

0 comments on commit 2586d56

Please sign in to comment.