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

ACPI: thinkpad-acpi: cleanup bluetooth and wan for sysfs conversion

Prepare bluetooth and wan driver code to be more easily hooked into sysfs
helpers, by separating the procfs logic from the device attribute handling.

These changes also remove the entries from procfs on notebooks without the
bluetooth/wan hardware installed.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent b86c4722
...@@ -681,6 +681,8 @@ static struct ibm_struct hotkey_driver_data = { ...@@ -681,6 +681,8 @@ static struct ibm_struct hotkey_driver_data = {
static int __init bluetooth_init(struct ibm_init_struct *iibm) static int __init bluetooth_init(struct ibm_init_struct *iibm)
{ {
int status = 0;
vdbg_printk(TPACPI_DBG_INIT, "initializing bluetooth subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing bluetooth subdriver\n");
IBM_ACPIHANDLE_INIT(hkey); IBM_ACPIHANDLE_INIT(hkey);
...@@ -688,36 +690,65 @@ static int __init bluetooth_init(struct ibm_init_struct *iibm) ...@@ -688,36 +690,65 @@ static int __init bluetooth_init(struct ibm_init_struct *iibm)
/* bluetooth not supported on 570, 600e/x, 770e, 770x, A21e, A2xm/p, /* bluetooth not supported on 570, 600e/x, 770e, 770x, A21e, A2xm/p,
G4x, R30, R31, R40e, R50e, T20-22, X20-21 */ G4x, R30, R31, R40e, R50e, T20-22, X20-21 */
tp_features.bluetooth = hkey_handle && tp_features.bluetooth = hkey_handle &&
acpi_evalf(hkey_handle, NULL, "GBDC", "qv"); acpi_evalf(hkey_handle, &status, "GBDC", "qd");
vdbg_printk(TPACPI_DBG_INIT, "bluetooth is %s\n", vdbg_printk(TPACPI_DBG_INIT, "bluetooth is %s, status 0x%02x\n",
str_supported(tp_features.bluetooth)); str_supported(tp_features.bluetooth),
status);
if (tp_features.bluetooth &&
!(status & TP_ACPI_BLUETOOTH_HWPRESENT)) {
/* no bluetooth hardware present in system */
tp_features.bluetooth = 0;
dbg_printk(TPACPI_DBG_INIT,
"bluetooth hardware not installed\n");
}
return (tp_features.bluetooth)? 0 : 1; return (tp_features.bluetooth)? 0 : 1;
} }
static int bluetooth_status(void) static int bluetooth_get_radiosw(void)
{ {
int status; int status;
if (!tp_features.bluetooth || if (!tp_features.bluetooth)
!acpi_evalf(hkey_handle, &status, "GBDC", "d")) return -ENODEV;
status = 0;
return status; if (!acpi_evalf(hkey_handle, &status, "GBDC", "d"))
return -EIO;
return ((status & TP_ACPI_BLUETOOTH_RADIOSSW) != 0);
}
static int bluetooth_set_radiosw(int radio_on)
{
int status;
if (!tp_features.bluetooth)
return -ENODEV;
if (!acpi_evalf(hkey_handle, &status, "GBDC", "d"))
return -EIO;
if (radio_on)
status |= TP_ACPI_BLUETOOTH_RADIOSSW;
else
status &= ~TP_ACPI_BLUETOOTH_RADIOSSW;
if (!acpi_evalf(hkey_handle, NULL, "SBDC", "vd", status))
return -EIO;
return 0;
} }
static int bluetooth_read(char *p) static int bluetooth_read(char *p)
{ {
int len = 0; int len = 0;
int status = bluetooth_status(); int status = bluetooth_get_radiosw();
if (!tp_features.bluetooth) if (!tp_features.bluetooth)
len += sprintf(p + len, "status:\t\tnot supported\n"); len += sprintf(p + len, "status:\t\tnot supported\n");
else if (!(status & 1))
len += sprintf(p + len, "status:\t\tnot installed\n");
else { else {
len += sprintf(p + len, "status:\t\t%s\n", enabled(status, 1)); len += sprintf(p + len, "status:\t\t%s\n",
(status)? "enabled" : "disabled");
len += sprintf(p + len, "commands:\tenable, disable\n"); len += sprintf(p + len, "commands:\tenable, disable\n");
} }
...@@ -726,26 +757,20 @@ static int bluetooth_read(char *p) ...@@ -726,26 +757,20 @@ static int bluetooth_read(char *p)
static int bluetooth_write(char *buf) static int bluetooth_write(char *buf)
{ {
int status = bluetooth_status();
char *cmd; char *cmd;
int do_cmd = 0;
if (!tp_features.bluetooth) if (!tp_features.bluetooth)
return -ENODEV; return -ENODEV;
while ((cmd = next_cmd(&buf))) { while ((cmd = next_cmd(&buf))) {
if (strlencmp(cmd, "enable") == 0) { if (strlencmp(cmd, "enable") == 0) {
status |= 2; bluetooth_set_radiosw(1);
} else if (strlencmp(cmd, "disable") == 0) { } else if (strlencmp(cmd, "disable") == 0) {
status &= ~2; bluetooth_set_radiosw(0);
} else } else
return -EINVAL; return -EINVAL;
do_cmd = 1;
} }
if (do_cmd && !acpi_evalf(hkey_handle, NULL, "SBDC", "vd", status))
return -EIO;
return 0; return 0;
} }
...@@ -761,41 +786,72 @@ static struct ibm_struct bluetooth_driver_data = { ...@@ -761,41 +786,72 @@ static struct ibm_struct bluetooth_driver_data = {
static int __init wan_init(struct ibm_init_struct *iibm) static int __init wan_init(struct ibm_init_struct *iibm)
{ {
int status = 0;
vdbg_printk(TPACPI_DBG_INIT, "initializing wan subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing wan subdriver\n");
IBM_ACPIHANDLE_INIT(hkey); IBM_ACPIHANDLE_INIT(hkey);
tp_features.wan = hkey_handle && tp_features.wan = hkey_handle &&
acpi_evalf(hkey_handle, NULL, "GWAN", "qv"); acpi_evalf(hkey_handle, &status, "GWAN", "qd");
vdbg_printk(TPACPI_DBG_INIT, "wan is %s\n", vdbg_printk(TPACPI_DBG_INIT, "wan is %s, status 0x%02x\n",
str_supported(tp_features.wan)); str_supported(tp_features.wan),
status);
if (tp_features.wan &&
!(status & TP_ACPI_WANCARD_HWPRESENT)) {
/* no wan hardware present in system */
tp_features.wan = 0;
dbg_printk(TPACPI_DBG_INIT,
"wan hardware not installed\n");
}
return (tp_features.wan)? 0 : 1; return (tp_features.wan)? 0 : 1;
} }
static int wan_status(void) static int wan_get_radiosw(void)
{ {
int status; int status;
if (!tp_features.wan || if (!tp_features.wan)
!acpi_evalf(hkey_handle, &status, "GWAN", "d")) return -ENODEV;
status = 0;
return status; if (!acpi_evalf(hkey_handle, &status, "GWAN", "d"))
return -EIO;
return ((status & TP_ACPI_WANCARD_RADIOSSW) != 0);
}
static int wan_set_radiosw(int radio_on)
{
int status;
if (!tp_features.wan)
return -ENODEV;
if (!acpi_evalf(hkey_handle, &status, "GWAN", "d"))
return -EIO;
if (radio_on)
status |= TP_ACPI_WANCARD_RADIOSSW;
else
status &= ~TP_ACPI_WANCARD_RADIOSSW;
if (!acpi_evalf(hkey_handle, NULL, "SWAN", "vd", status))
return -EIO;
return 0;
} }
static int wan_read(char *p) static int wan_read(char *p)
{ {
int len = 0; int len = 0;
int status = wan_status(); int status = wan_get_radiosw();
if (!tp_features.wan) if (!tp_features.wan)
len += sprintf(p + len, "status:\t\tnot supported\n"); len += sprintf(p + len, "status:\t\tnot supported\n");
else if (!(status & 1))
len += sprintf(p + len, "status:\t\tnot installed\n");
else { else {
len += sprintf(p + len, "status:\t\t%s\n", enabled(status, 1)); len += sprintf(p + len, "status:\t\t%s\n",
(status)? "enabled" : "disabled");
len += sprintf(p + len, "commands:\tenable, disable\n"); len += sprintf(p + len, "commands:\tenable, disable\n");
} }
...@@ -804,26 +860,20 @@ static int wan_read(char *p) ...@@ -804,26 +860,20 @@ static int wan_read(char *p)
static int wan_write(char *buf) static int wan_write(char *buf)
{ {
int status = wan_status();
char *cmd; char *cmd;
int do_cmd = 0;
if (!tp_features.wan) if (!tp_features.wan)
return -ENODEV; return -ENODEV;
while ((cmd = next_cmd(&buf))) { while ((cmd = next_cmd(&buf))) {
if (strlencmp(cmd, "enable") == 0) { if (strlencmp(cmd, "enable") == 0) {
status |= 2; wan_set_radiosw(1);
} else if (strlencmp(cmd, "disable") == 0) { } else if (strlencmp(cmd, "disable") == 0) {
status &= ~2; wan_set_radiosw(0);
} else } else
return -EINVAL; return -EINVAL;
do_cmd = 1;
} }
if (do_cmd && !acpi_evalf(hkey_handle, NULL, "SWAN", "vd", status))
return -EIO;
return 0; return 0;
} }
......
...@@ -241,8 +241,16 @@ static int beep_write(char *buf); ...@@ -241,8 +241,16 @@ static int beep_write(char *buf);
* Bluetooth subdriver * Bluetooth subdriver
*/ */
enum {
/* ACPI GBDC/SBDC bits */
TP_ACPI_BLUETOOTH_HWPRESENT = 0x01, /* Bluetooth hw available */
TP_ACPI_BLUETOOTH_RADIOSSW = 0x02, /* Bluetooth radio enabled */
TP_ACPI_BLUETOOTH_UNK = 0x04, /* unknown function */
};
static int bluetooth_init(struct ibm_init_struct *iibm); static int bluetooth_init(struct ibm_init_struct *iibm);
static int bluetooth_status(void); static int bluetooth_get_radiosw(void);
static int bluetooth_set_radiosw(int radio_on);
static int bluetooth_read(char *p); static int bluetooth_read(char *p);
static int bluetooth_write(char *buf); static int bluetooth_write(char *buf);
...@@ -467,8 +475,16 @@ static int volume_write(char *buf); ...@@ -467,8 +475,16 @@ static int volume_write(char *buf);
* Wan subdriver * Wan subdriver
*/ */
enum {
/* ACPI GWAN/SWAN bits */
TP_ACPI_WANCARD_HWPRESENT = 0x01, /* Wan hw available */
TP_ACPI_WANCARD_RADIOSSW = 0x02, /* Wan radio enabled */
TP_ACPI_WANCARD_UNK = 0x04, /* unknown function */
};
static int wan_init(struct ibm_init_struct *iibm); static int wan_init(struct ibm_init_struct *iibm);
static int wan_status(void); static int wan_get_radiosw(void);
static int wan_set_radiosw(int radio_on);
static int wan_read(char *p); static int wan_read(char *p);
static int wan_write(char *buf); static int wan_write(char *buf);
......
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