Commit 74941a69 authored by Henrique de Moraes Holschuh's avatar Henrique de Moraes Holschuh Committed by Len Brown

ACPI: thinkpad-acpi: export to sysfs the state of the radio slider switch

Some ThinkPad models, notably the T60 and X60, have a slider switch to
enable and disable the radios.  The switch has the capability of
force-disabling the radios in hardware on most models, and it is supposed
to affect all radios (WLAN, WWAN, BlueTooth).

Export the switch state as a sysfs attribute, on ThinkPads where it is
available.

Thanks to Henning Schild for asking for this feature, and for tracking down
the EC register that holds the radio switch state.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Cc: Henning Schild <henning@wh9.tu-dresden.de>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 9b010de5
...@@ -227,6 +227,12 @@ sysfs notes: ...@@ -227,6 +227,12 @@ sysfs notes:
supported hot keys, except those which are handled by supported hot keys, except those which are handled by
the firmware. Echo it to hotkey_mask above, to use. the firmware. Echo it to hotkey_mask above, to use.
hotkey_radio_sw:
if the ThinkPad has a hardware radio switch, this
attribute will read 0 if the switch is in the "radios
disabled" postition, and 1 if the switch is in the
"radios enabled" position.
Bluetooth Bluetooth
--------- ---------
......
...@@ -733,6 +733,13 @@ static u32 hotkey_reserved_mask = 0x00778000; ...@@ -733,6 +733,13 @@ static u32 hotkey_reserved_mask = 0x00778000;
static struct attribute_set *hotkey_dev_attributes; static struct attribute_set *hotkey_dev_attributes;
static int hotkey_get_wlsw(int *status)
{
if (!acpi_evalf(hkey_handle, status, "WLSW", "d"))
return -EIO;
return 0;
}
/* sysfs hotkey enable ------------------------------------------------- */ /* sysfs hotkey enable ------------------------------------------------- */
static ssize_t hotkey_enable_show(struct device *dev, static ssize_t hotkey_enable_show(struct device *dev,
struct device_attribute *attr, struct device_attribute *attr,
...@@ -853,6 +860,22 @@ static struct device_attribute dev_attr_hotkey_recommended_mask = ...@@ -853,6 +860,22 @@ static struct device_attribute dev_attr_hotkey_recommended_mask =
__ATTR(hotkey_recommended_mask, S_IRUGO, __ATTR(hotkey_recommended_mask, S_IRUGO,
hotkey_recommended_mask_show, NULL); hotkey_recommended_mask_show, NULL);
/* sysfs hotkey radio_sw ----------------------------------------------- */
static ssize_t hotkey_radio_sw_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{
int res, s;
res = hotkey_get_wlsw(&s);
if (res < 0)
return res;
return snprintf(buf, PAGE_SIZE, "%d\n", !!s);
}
static struct device_attribute dev_attr_hotkey_radio_sw =
__ATTR(hotkey_radio_sw, S_IRUGO, hotkey_radio_sw_show, NULL);
/* --------------------------------------------------------------------- */ /* --------------------------------------------------------------------- */
static struct attribute *hotkey_mask_attributes[] = { static struct attribute *hotkey_mask_attributes[] = {
...@@ -866,6 +889,7 @@ static struct attribute *hotkey_mask_attributes[] = { ...@@ -866,6 +889,7 @@ static struct attribute *hotkey_mask_attributes[] = {
static int __init hotkey_init(struct ibm_init_struct *iibm) static int __init hotkey_init(struct ibm_init_struct *iibm)
{ {
int res; int res;
int status;
vdbg_printk(TPACPI_DBG_INIT, "initializing hotkey subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing hotkey subdriver\n");
...@@ -879,7 +903,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm) ...@@ -879,7 +903,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)
str_supported(tp_features.hotkey)); str_supported(tp_features.hotkey));
if (tp_features.hotkey) { if (tp_features.hotkey) {
hotkey_dev_attributes = create_attr_set(6, NULL); hotkey_dev_attributes = create_attr_set(7, NULL);
if (!hotkey_dev_attributes) if (!hotkey_dev_attributes)
return -ENOMEM; return -ENOMEM;
res = add_to_attr_set(hotkey_dev_attributes, res = add_to_attr_set(hotkey_dev_attributes,
...@@ -908,11 +932,21 @@ static int __init hotkey_init(struct ibm_init_struct *iibm) ...@@ -908,11 +932,21 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)
hotkey_mask_attributes, hotkey_mask_attributes,
ARRAY_SIZE(hotkey_mask_attributes)); ARRAY_SIZE(hotkey_mask_attributes));
} }
/* Not all thinkpads have a hardware radio switch */
if (!res && acpi_evalf(hkey_handle, &status, "WLSW", "qd")) {
tp_features.hotkey_wlsw = 1;
printk(IBM_INFO
"radio switch found; radios are %s\n",
enabled(status, 0));
res = add_to_attr_set(hotkey_dev_attributes,
&dev_attr_hotkey_radio_sw.attr);
}
if (!res) if (!res)
res = register_attr_set_with_sysfs( res = register_attr_set_with_sysfs(
hotkey_dev_attributes, hotkey_dev_attributes,
&tpacpi_pdev->dev.kobj); &tpacpi_pdev->dev.kobj);
if (res) if (res)
return res; return res;
} }
......
...@@ -228,6 +228,7 @@ static struct { ...@@ -228,6 +228,7 @@ static struct {
u16 bluetooth:1; u16 bluetooth:1;
u16 hotkey:1; u16 hotkey:1;
u16 hotkey_mask:1; u16 hotkey_mask:1;
u16 hotkey_wlsw:1;
u16 light:1; u16 light:1;
u16 light_status:1; u16 light_status:1;
u16 wan:1; u16 wan:1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment