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

ACPI: thinkpad-acpi: prepare for device model conversion

Prepare the thinkpad-acpi driver for the conversion to the device
model, by renaming variables and doing other glue work that shall
make the later patches much cleaner.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent d8fd94d9
...@@ -277,7 +277,7 @@ static int _sta(acpi_handle handle) ...@@ -277,7 +277,7 @@ static int _sta(acpi_handle handle)
* ACPI device model * ACPI device model
*/ */
static void ibm_handle_init(char *name, static void drv_acpi_handle_init(char *name,
acpi_handle *handle, acpi_handle parent, acpi_handle *handle, acpi_handle parent,
char **paths, int num_paths, char **path) char **paths, int num_paths, char **path)
{ {
...@@ -295,40 +295,42 @@ static void ibm_handle_init(char *name, ...@@ -295,40 +295,42 @@ static void ibm_handle_init(char *name,
*handle = NULL; *handle = NULL;
} }
static void dispatch_notify(acpi_handle handle, u32 event, void *data) static void dispatch_acpi_notify(acpi_handle handle, u32 event, void *data)
{ {
struct ibm_struct *ibm = data; struct ibm_struct *ibm = data;
if (!ibm || !ibm->notify) if (!ibm || !ibm->acpi || !ibm->acpi->notify)
return; return;
ibm->notify(ibm, event); ibm->acpi->notify(ibm, event);
} }
static int __init setup_notify(struct ibm_struct *ibm) static int __init setup_acpi_notify(struct ibm_struct *ibm)
{ {
acpi_status status; acpi_status status;
int ret; int ret;
if (!*ibm->handle) BUG_ON(!ibm->acpi);
if (!*ibm->acpi->handle)
return 0; return 0;
dbg_printk(TPACPI_DBG_INIT, dbg_printk(TPACPI_DBG_INIT,
"setting up ACPI notify for %s\n", ibm->name); "setting up ACPI notify for %s\n", ibm->name);
ret = acpi_bus_get_device(*ibm->handle, &ibm->device); ret = acpi_bus_get_device(*ibm->acpi->handle, &ibm->acpi->device);
if (ret < 0) { if (ret < 0) {
printk(IBM_ERR "%s device not present\n", ibm->name); printk(IBM_ERR "%s device not present\n", ibm->name);
return -ENODEV; return -ENODEV;
} }
acpi_driver_data(ibm->device) = ibm; acpi_driver_data(ibm->acpi->device) = ibm;
sprintf(acpi_device_class(ibm->device), "%s/%s", sprintf(acpi_device_class(ibm->acpi->device), "%s/%s",
IBM_ACPI_EVENT_PREFIX, IBM_ACPI_EVENT_PREFIX,
ibm->name); ibm->name);
status = acpi_install_notify_handler(*ibm->handle, ibm->type, status = acpi_install_notify_handler(*ibm->acpi->handle,
dispatch_notify, ibm); ibm->acpi->type, dispatch_acpi_notify, ibm);
if (ACPI_FAILURE(status)) { if (ACPI_FAILURE(status)) {
if (status == AE_ALREADY_EXISTS) { if (status == AE_ALREADY_EXISTS) {
printk(IBM_NOTICE "another device driver is already handling %s events\n", printk(IBM_NOTICE "another device driver is already handling %s events\n",
...@@ -339,11 +341,11 @@ static int __init setup_notify(struct ibm_struct *ibm) ...@@ -339,11 +341,11 @@ static int __init setup_notify(struct ibm_struct *ibm)
} }
return -ENODEV; return -ENODEV;
} }
ibm->flags.notify_installed = 1; ibm->flags.acpi_notify_installed = 1;
return 0; return 0;
} }
static int __init ibm_device_add(struct acpi_device *device) static int __init tpacpi_device_add(struct acpi_device *device)
{ {
return 0; return 0;
} }
...@@ -355,24 +357,26 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm) ...@@ -355,24 +357,26 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm)
dbg_printk(TPACPI_DBG_INIT, dbg_printk(TPACPI_DBG_INIT,
"registering %s as an ACPI driver\n", ibm->name); "registering %s as an ACPI driver\n", ibm->name);
ibm->driver = kzalloc(sizeof(struct acpi_driver), GFP_KERNEL); BUG_ON(!ibm->acpi);
if (!ibm->driver) {
ibm->acpi->driver = kzalloc(sizeof(struct acpi_driver), GFP_KERNEL);
if (!ibm->acpi->driver) {
printk(IBM_ERR "kzalloc(ibm->driver) failed\n"); printk(IBM_ERR "kzalloc(ibm->driver) failed\n");
return -ENOMEM; return -ENOMEM;
} }
sprintf(ibm->driver->name, "%s_%s", IBM_NAME, ibm->name); sprintf(ibm->acpi->driver->name, "%s_%s", IBM_NAME, ibm->name);
ibm->driver->ids = ibm->hid; ibm->acpi->driver->ids = ibm->acpi->hid;
ibm->driver->ops.add = &ibm_device_add; ibm->acpi->driver->ops.add = &tpacpi_device_add;
ret = acpi_bus_register_driver(ibm->driver); ret = acpi_bus_register_driver(ibm->acpi->driver);
if (ret < 0) { if (ret < 0) {
printk(IBM_ERR "acpi_bus_register_driver(%s) failed: %d\n", printk(IBM_ERR "acpi_bus_register_driver(%s) failed: %d\n",
ibm->hid, ret); ibm->acpi->hid, ret);
kfree(ibm->driver); kfree(ibm->acpi->driver);
ibm->driver = NULL; ibm->acpi->driver = NULL;
} else if (!ret) } else if (!ret)
ibm->flags.driver_registered = 1; ibm->flags.acpi_driver_registered = 1;
return ret; return ret;
} }
...@@ -386,8 +390,8 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm) ...@@ -386,8 +390,8 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm)
**************************************************************************** ****************************************************************************
****************************************************************************/ ****************************************************************************/
static int dispatch_read(char *page, char **start, off_t off, int count, static int dispatch_procfs_read(char *page, char **start, off_t off,
int *eof, void *data) int count, int *eof, void *data)
{ {
struct ibm_struct *ibm = data; struct ibm_struct *ibm = data;
int len; int len;
...@@ -411,8 +415,9 @@ static int dispatch_read(char *page, char **start, off_t off, int count, ...@@ -411,8 +415,9 @@ static int dispatch_read(char *page, char **start, off_t off, int count,
return len; return len;
} }
static int dispatch_write(struct file *file, const char __user * userbuf, static int dispatch_procfs_write(struct file *file,
unsigned long count, void *data) const char __user * userbuf,
unsigned long count, void *data)
{ {
struct ibm_struct *ibm = data; struct ibm_struct *ibm = data;
char *kernbuf; char *kernbuf;
...@@ -508,7 +513,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm) ...@@ -508,7 +513,7 @@ static int __init hotkey_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing hotkey subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing hotkey subdriver\n");
IBM_HANDLE_INIT(hkey); IBM_ACPIHANDLE_INIT(hkey);
/* hotkey not supported on 570 */ /* hotkey not supported on 570 */
tp_features.hotkey = hkey_handle != NULL; tp_features.hotkey = hkey_handle != NULL;
...@@ -545,10 +550,10 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event) ...@@ -545,10 +550,10 @@ static void hotkey_notify(struct ibm_struct *ibm, u32 event)
int hkey; int hkey;
if (acpi_evalf(hkey_handle, &hkey, "MHKP", "d")) if (acpi_evalf(hkey_handle, &hkey, "MHKP", "d"))
acpi_bus_generate_event(ibm->device, event, hkey); acpi_bus_generate_event(ibm->acpi->device, event, hkey);
else { else {
printk(IBM_ERR "unknown hotkey event %d\n", event); printk(IBM_ERR "unknown hotkey event %d\n", event);
acpi_bus_generate_event(ibm->device, event, 0); acpi_bus_generate_event(ibm->acpi->device, event, 0);
} }
} }
...@@ -643,15 +648,19 @@ static int hotkey_write(char *buf) ...@@ -643,15 +648,19 @@ static int hotkey_write(char *buf)
return 0; return 0;
} }
static struct tp_acpi_drv_struct ibm_hotkey_acpidriver = {
.hid = IBM_HKEY_HID,
.notify = hotkey_notify,
.handle = &hkey_handle,
.type = ACPI_DEVICE_NOTIFY,
};
static struct ibm_struct hotkey_driver_data = { static struct ibm_struct hotkey_driver_data = {
.name = "hotkey", .name = "hotkey",
.hid = IBM_HKEY_HID,
.read = hotkey_read, .read = hotkey_read,
.write = hotkey_write, .write = hotkey_write,
.exit = hotkey_exit, .exit = hotkey_exit,
.notify = hotkey_notify, .acpi = &ibm_hotkey_acpidriver,
.handle = &hkey_handle,
.type = ACPI_DEVICE_NOTIFY,
}; };
/************************************************************************* /*************************************************************************
...@@ -662,7 +671,7 @@ static int __init bluetooth_init(struct ibm_init_struct *iibm) ...@@ -662,7 +671,7 @@ static int __init bluetooth_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing bluetooth subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing bluetooth subdriver\n");
IBM_HANDLE_INIT(hkey); IBM_ACPIHANDLE_INIT(hkey);
/* 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 */
...@@ -742,7 +751,7 @@ static int __init wan_init(struct ibm_init_struct *iibm) ...@@ -742,7 +751,7 @@ static int __init wan_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing wan subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing wan subdriver\n");
IBM_HANDLE_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, NULL, "GWAN", "qv");
...@@ -835,8 +844,8 @@ static int __init video_init(struct ibm_init_struct *iibm) ...@@ -835,8 +844,8 @@ static int __init video_init(struct ibm_init_struct *iibm)
vdbg_printk(TPACPI_DBG_INIT, "initializing video subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing video subdriver\n");
IBM_HANDLE_INIT(vid); IBM_ACPIHANDLE_INIT(vid);
IBM_HANDLE_INIT(vid2); IBM_ACPIHANDLE_INIT(vid2);
if (vid2_handle && acpi_evalf(NULL, &ivga, "\\IVGA", "d") && ivga) if (vid2_handle && acpi_evalf(NULL, &ivga, "\\IVGA", "d") && ivga)
/* G41, assume IVGA doesn't change */ /* G41, assume IVGA doesn't change */
...@@ -1053,9 +1062,9 @@ static int __init light_init(struct ibm_init_struct *iibm) ...@@ -1053,9 +1062,9 @@ static int __init light_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing light subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing light subdriver\n");
IBM_HANDLE_INIT(ledb); IBM_ACPIHANDLE_INIT(ledb);
IBM_HANDLE_INIT(lght); IBM_ACPIHANDLE_INIT(lght);
IBM_HANDLE_INIT(cmos); IBM_ACPIHANDLE_INIT(cmos);
/* light not supported on 570, 600e/x, 770e, 770x, G4x, R30, R31 */ /* light not supported on 570, 600e/x, 770e, 770x, G4x, R30, R31 */
tp_features.light = (cmos_handle || lght_handle) && !ledb_handle; tp_features.light = (cmos_handle || lght_handle) && !ledb_handle;
...@@ -1148,8 +1157,8 @@ static int __init dock_init(struct ibm_init_struct *iibm) ...@@ -1148,8 +1157,8 @@ static int __init dock_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing dock subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing dock subdriver\n");
IBM_HANDLE_INIT(dock); IBM_ACPIHANDLE_INIT(dock);
IBM_HANDLE_INIT(pci); IBM_ACPIHANDLE_INIT(pci);
vdbg_printk(TPACPI_DBG_INIT, "dock is %s\n", vdbg_printk(TPACPI_DBG_INIT, "dock is %s\n",
str_supported(dock_handle != NULL)); str_supported(dock_handle != NULL));
...@@ -1160,22 +1169,22 @@ static int __init dock_init(struct ibm_init_struct *iibm) ...@@ -1160,22 +1169,22 @@ static int __init dock_init(struct ibm_init_struct *iibm)
static void dock_notify(struct ibm_struct *ibm, u32 event) static void dock_notify(struct ibm_struct *ibm, u32 event)
{ {
int docked = dock_docked(); int docked = dock_docked();
int pci = ibm->hid && strstr(ibm->hid, IBM_PCI_HID); int pci = ibm->acpi->hid && strstr(ibm->acpi->hid, IBM_PCI_HID);
if (event == 1 && !pci) /* 570 */ if (event == 1 && !pci) /* 570 */
acpi_bus_generate_event(ibm->device, event, 1); /* button */ acpi_bus_generate_event(ibm->acpi->device, event, 1); /* button */
else if (event == 1 && pci) /* 570 */ else if (event == 1 && pci) /* 570 */
acpi_bus_generate_event(ibm->device, event, 3); /* dock */ acpi_bus_generate_event(ibm->acpi->device, event, 3); /* dock */
else if (event == 3 && docked) else if (event == 3 && docked)
acpi_bus_generate_event(ibm->device, event, 1); /* button */ acpi_bus_generate_event(ibm->acpi->device, event, 1); /* button */
else if (event == 3 && !docked) else if (event == 3 && !docked)
acpi_bus_generate_event(ibm->device, event, 2); /* undock */ acpi_bus_generate_event(ibm->acpi->device, event, 2); /* undock */
else if (event == 0 && docked) else if (event == 0 && docked)
acpi_bus_generate_event(ibm->device, event, 3); /* dock */ acpi_bus_generate_event(ibm->acpi->device, event, 3); /* dock */
else { else {
printk(IBM_ERR "unknown dock event %d, status %d\n", printk(IBM_ERR "unknown dock event %d, status %d\n",
event, _sta(dock_handle)); event, _sta(dock_handle));
acpi_bus_generate_event(ibm->device, event, 0); /* unknown */ acpi_bus_generate_event(ibm->acpi->device, event, 0); /* unknown */
} }
} }
...@@ -1218,17 +1227,13 @@ static int dock_write(char *buf) ...@@ -1218,17 +1227,13 @@ static int dock_write(char *buf)
return 0; return 0;
} }
static struct ibm_struct dock_driver_data[2] = { static struct tp_acpi_drv_struct ibm_dock_acpidriver[2] = {
{ {
.name = "dock",
.read = dock_read,
.write = dock_write,
.notify = dock_notify, .notify = dock_notify,
.handle = &dock_handle, .handle = &dock_handle,
.type = ACPI_SYSTEM_NOTIFY, .type = ACPI_SYSTEM_NOTIFY,
}, },
{ {
.name = "dock",
.hid = IBM_PCI_HID, .hid = IBM_PCI_HID,
.notify = dock_notify, .notify = dock_notify,
.handle = &pci_handle, .handle = &pci_handle,
...@@ -1236,6 +1241,19 @@ static struct ibm_struct dock_driver_data[2] = { ...@@ -1236,6 +1241,19 @@ static struct ibm_struct dock_driver_data[2] = {
}, },
}; };
static struct ibm_struct dock_driver_data[2] = {
{
.name = "dock",
.read = dock_read,
.write = dock_write,
.acpi = &ibm_dock_acpidriver[0],
},
{
.name = "dock",
.acpi = &ibm_dock_acpidriver[1],
},
};
#endif /* CONFIG_THINKPAD_ACPI_DOCK */ #endif /* CONFIG_THINKPAD_ACPI_DOCK */
/************************************************************************* /*************************************************************************
...@@ -1262,12 +1280,12 @@ static int __init bay_init(struct ibm_init_struct *iibm) ...@@ -1262,12 +1280,12 @@ static int __init bay_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing bay subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing bay subdriver\n");
IBM_HANDLE_INIT(bay); IBM_ACPIHANDLE_INIT(bay);
if (bay_handle) if (bay_handle)
IBM_HANDLE_INIT(bay_ej); IBM_ACPIHANDLE_INIT(bay_ej);
IBM_HANDLE_INIT(bay2); IBM_ACPIHANDLE_INIT(bay2);
if (bay2_handle) if (bay2_handle)
IBM_HANDLE_INIT(bay2_ej); IBM_ACPIHANDLE_INIT(bay2_ej);
tp_features.bay_status = bay_handle && tp_features.bay_status = bay_handle &&
acpi_evalf(bay_handle, NULL, "_STA", "qv"); acpi_evalf(bay_handle, NULL, "_STA", "qv");
...@@ -1292,7 +1310,7 @@ static int __init bay_init(struct ibm_init_struct *iibm) ...@@ -1292,7 +1310,7 @@ static int __init bay_init(struct ibm_init_struct *iibm)
static void bay_notify(struct ibm_struct *ibm, u32 event) static void bay_notify(struct ibm_struct *ibm, u32 event)
{ {
acpi_bus_generate_event(ibm->device, event, 0); acpi_bus_generate_event(ibm->acpi->device, event, 0);
} }
#define bay_occupied(b) (_sta(b##_handle) & 1) #define bay_occupied(b) (_sta(b##_handle) & 1)
...@@ -1347,13 +1365,17 @@ static int bay_write(char *buf) ...@@ -1347,13 +1365,17 @@ static int bay_write(char *buf)
return 0; return 0;
} }
static struct tp_acpi_drv_struct ibm_bay_acpidriver = {
.notify = bay_notify,
.handle = &bay_handle,
.type = ACPI_SYSTEM_NOTIFY,
};
static struct ibm_struct bay_driver_data = { static struct ibm_struct bay_driver_data = {
.name = "bay", .name = "bay",
.read = bay_read, .read = bay_read,
.write = bay_write, .write = bay_write,
.notify = bay_notify, .acpi = &ibm_bay_acpidriver,
.handle = &bay_handle,
.type = ACPI_SYSTEM_NOTIFY,
}; };
#endif /* CONFIG_THINKPAD_ACPI_BAY */ #endif /* CONFIG_THINKPAD_ACPI_BAY */
...@@ -1367,7 +1389,7 @@ static int __init cmos_init(struct ibm_init_struct *iibm) ...@@ -1367,7 +1389,7 @@ static int __init cmos_init(struct ibm_init_struct *iibm)
vdbg_printk(TPACPI_DBG_INIT, vdbg_printk(TPACPI_DBG_INIT,
"initializing cmos commands subdriver\n"); "initializing cmos commands subdriver\n");
IBM_HANDLE_INIT(cmos); IBM_ACPIHANDLE_INIT(cmos);
vdbg_printk(TPACPI_DBG_INIT, "cmos commands are %s\n", vdbg_printk(TPACPI_DBG_INIT, "cmos commands are %s\n",
str_supported(cmos_handle != NULL)); str_supported(cmos_handle != NULL));
...@@ -1441,7 +1463,7 @@ static int __init led_init(struct ibm_init_struct *iibm) ...@@ -1441,7 +1463,7 @@ static int __init led_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing LED subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing LED subdriver\n");
IBM_HANDLE_INIT(led); IBM_ACPIHANDLE_INIT(led);
if (!led_handle) if (!led_handle)
/* led not supported on R30, R31 */ /* led not supported on R30, R31 */
...@@ -1566,7 +1588,7 @@ static int __init beep_init(struct ibm_init_struct *iibm) ...@@ -1566,7 +1588,7 @@ static int __init beep_init(struct ibm_init_struct *iibm)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing beep subdriver\n"); vdbg_printk(TPACPI_DBG_INIT, "initializing beep subdriver\n");
IBM_HANDLE_INIT(beep); IBM_ACPIHANDLE_INIT(beep);
vdbg_printk(TPACPI_DBG_INIT, "beep is %s\n", vdbg_printk(TPACPI_DBG_INIT, "beep is %s\n",
str_supported(beep_handle != NULL)); str_supported(beep_handle != NULL));
...@@ -2200,9 +2222,9 @@ static int __init fan_init(struct ibm_init_struct *iibm) ...@@ -2200,9 +2222,9 @@ static int __init fan_init(struct ibm_init_struct *iibm)
fan_watchdog_maxinterval = 0; fan_watchdog_maxinterval = 0;
tp_features.fan_ctrl_status_undef = 0; tp_features.fan_ctrl_status_undef = 0;
IBM_HANDLE_INIT(fans); IBM_ACPIHANDLE_INIT(fans);
IBM_HANDLE_INIT(gfan); IBM_ACPIHANDLE_INIT(gfan);
IBM_HANDLE_INIT(sfan); IBM_ACPIHANDLE_INIT(sfan);
if (gfan_handle) { if (gfan_handle) {
/* 570, 600e/x, 770e, 770x */ /* 570, 600e/x, 770e, 770x */
...@@ -2728,22 +2750,24 @@ static int __init ibm_init(struct ibm_init_struct *iibm) ...@@ -2728,22 +2750,24 @@ static int __init ibm_init(struct ibm_init_struct *iibm)
ibm->flags.init_called = 1; ibm->flags.init_called = 1;
} }
if (ibm->hid) { if (ibm->acpi) {
ret = register_tpacpi_subdriver(ibm); if (ibm->acpi->hid) {
if (ret) ret = register_tpacpi_subdriver(ibm);
goto err_out; if (ret)
} goto err_out;
}
if (ibm->notify) { if (ibm->acpi->notify) {
ret = setup_notify(ibm); ret = setup_acpi_notify(ibm);
if (ret == -ENODEV) { if (ret == -ENODEV) {
printk(IBM_NOTICE "disabling subdriver %s\n", printk(IBM_NOTICE "disabling subdriver %s\n",
ibm->name); ibm->name);
ret = 0; ret = 0;
goto err_out; goto err_out;
}
if (ret < 0)
goto err_out;
} }
if (ret < 0)
goto err_out;
} }
dbg_printk(TPACPI_DBG_INIT, dbg_printk(TPACPI_DBG_INIT,
...@@ -2761,9 +2785,9 @@ static int __init ibm_init(struct ibm_init_struct *iibm) ...@@ -2761,9 +2785,9 @@ static int __init ibm_init(struct ibm_init_struct *iibm)
} }
entry->owner = THIS_MODULE; entry->owner = THIS_MODULE;
entry->data = ibm; entry->data = ibm;
entry->read_proc = &dispatch_read; entry->read_proc = &dispatch_procfs_read;
if (ibm->write) if (ibm->write)
entry->write_proc = &dispatch_write; entry->write_proc = &dispatch_procfs_write;
ibm->flags.proc_created = 1; ibm->flags.proc_created = 1;
} }
...@@ -2786,12 +2810,15 @@ static void ibm_exit(struct ibm_struct *ibm) ...@@ -2786,12 +2810,15 @@ static void ibm_exit(struct ibm_struct *ibm)
list_del_init(&ibm->all_drivers); list_del_init(&ibm->all_drivers);
if (ibm->flags.notify_installed) { if (ibm->flags.acpi_notify_installed) {
dbg_printk(TPACPI_DBG_EXIT, dbg_printk(TPACPI_DBG_EXIT,
"%s: acpi_remove_notify_handler\n", ibm->name); "%s: acpi_remove_notify_handler\n", ibm->name);
acpi_remove_notify_handler(*ibm->handle, ibm->type, BUG_ON(!ibm->acpi);
dispatch_notify); acpi_remove_notify_handler(*ibm->acpi->handle,
ibm->flags.notify_installed = 0; ibm->acpi->type,
dispatch_acpi_notify);
ibm->flags.acpi_notify_installed = 0;
ibm->flags.acpi_notify_installed = 0;
} }
if (ibm->flags.proc_created) { if (ibm->flags.proc_created) {
...@@ -2801,13 +2828,14 @@ static void ibm_exit(struct ibm_struct *ibm) ...@@ -2801,13 +2828,14 @@ static void ibm_exit(struct ibm_struct *ibm)
ibm->flags.proc_created = 0; ibm->flags.proc_created = 0;
} }
if (ibm->flags.driver_registered) { if (ibm->flags.acpi_driver_registered) {
dbg_printk(TPACPI_DBG_EXIT, dbg_printk(TPACPI_DBG_EXIT,
"%s: acpi_bus_unregister_driver\n", ibm->name); "%s: acpi_bus_unregister_driver\n", ibm->name);
acpi_bus_unregister_driver(ibm->driver); BUG_ON(!ibm->acpi);
kfree(ibm->driver); acpi_bus_unregister_driver(ibm->acpi->driver);
ibm->driver = NULL; kfree(ibm->acpi->driver);
ibm->flags.driver_registered = 0; ibm->acpi->driver = NULL;
ibm->flags.acpi_driver_registered = 0;
} }
if (ibm->flags.init_called && ibm->exit) { if (ibm->flags.init_called && ibm->exit) {
...@@ -2860,7 +2888,7 @@ static int __init probe_for_thinkpad(void) ...@@ -2860,7 +2888,7 @@ static int __init probe_for_thinkpad(void)
is_thinkpad = dmi_name_in_vendors("ThinkPad"); is_thinkpad = dmi_name_in_vendors("ThinkPad");
/* ec is required because many other handles are relative to it */ /* ec is required because many other handles are relative to it */
IBM_HANDLE_INIT(ec); IBM_ACPIHANDLE_INIT(ec);
if (!ec_handle) { if (!ec_handle) {
if (is_thinkpad) if (is_thinkpad)
printk(IBM_ERR printk(IBM_ERR
...@@ -3016,12 +3044,12 @@ static int __init thinkpad_acpi_module_init(void) ...@@ -3016,12 +3044,12 @@ static int __init thinkpad_acpi_module_init(void)
return ret; return ret;
ibm_thinkpad_ec_found = check_dmi_for_ec(); ibm_thinkpad_ec_found = check_dmi_for_ec();
IBM_HANDLE_INIT(ecrd); IBM_ACPIHANDLE_INIT(ecrd);
IBM_HANDLE_INIT(ecwr); IBM_ACPIHANDLE_INIT(ecwr);
proc_dir = proc_mkdir(IBM_DIR, acpi_root_dir); proc_dir = proc_mkdir(IBM_PROC_DIR, acpi_root_dir);
if (!proc_dir) { if (!proc_dir) {
printk(IBM_ERR "unable to create proc dir %s", IBM_DIR); printk(IBM_ERR "unable to create proc dir " IBM_PROC_DIR);
thinkpad_acpi_module_exit(); thinkpad_acpi_module_exit();
return -ENODEV; return -ENODEV;
} }
...@@ -3053,10 +3081,9 @@ static void thinkpad_acpi_module_exit(void) ...@@ -3053,10 +3081,9 @@ static void thinkpad_acpi_module_exit(void)
dbg_printk(TPACPI_DBG_INIT, "finished subdriver exit path...\n"); dbg_printk(TPACPI_DBG_INIT, "finished subdriver exit path...\n");
if (proc_dir) if (proc_dir)
remove_proc_entry(IBM_DIR, acpi_root_dir); remove_proc_entry(IBM_PROC_DIR, acpi_root_dir);
if (ibm_thinkpad_ec_found) kfree(ibm_thinkpad_ec_found);
kfree(ibm_thinkpad_ec_found);
} }
module_init(thinkpad_acpi_module_init); module_init(thinkpad_acpi_module_init);
......
...@@ -52,8 +52,9 @@ ...@@ -52,8 +52,9 @@
#define IBM_DESC "ThinkPad ACPI Extras" #define IBM_DESC "ThinkPad ACPI Extras"
#define IBM_FILE "thinkpad_acpi" #define IBM_FILE "thinkpad_acpi"
#define IBM_URL "http://ibm-acpi.sf.net/" #define IBM_URL "http://ibm-acpi.sf.net/"
#define IBM_MAIL "ibm-acpi-devel@lists.sourceforge.net"
#define IBM_DIR "ibm" #define IBM_PROC_DIR "ibm"
#define IBM_ACPI_EVENT_PREFIX "ibm" #define IBM_ACPI_EVENT_PREFIX "ibm"
#define IBM_LOG IBM_FILE ": " #define IBM_LOG IBM_FILE ": "
...@@ -108,20 +109,21 @@ static acpi_handle ec_handle; /* EC */ ...@@ -108,20 +109,21 @@ static acpi_handle ec_handle; /* EC */
static acpi_handle ecrd_handle, ecwr_handle; /* 570 EC access */ static acpi_handle ecrd_handle, ecwr_handle; /* 570 EC access */
static acpi_handle cmos_handle, hkey_handle; /* basic thinkpad handles */ static acpi_handle cmos_handle, hkey_handle; /* basic thinkpad handles */
static void ibm_handle_init(char *name, static void drv_acpi_handle_init(char *name,
acpi_handle *handle, acpi_handle parent, acpi_handle *handle, acpi_handle parent,
char **paths, int num_paths, char **path); char **paths, int num_paths, char **path);
#define IBM_HANDLE_INIT(object) \ #define IBM_ACPIHANDLE_INIT(object) \
ibm_handle_init(#object, &object##_handle, *object##_parent, \ drv_acpi_handle_init(#object, &object##_handle, *object##_parent, \
object##_paths, ARRAY_SIZE(object##_paths), &object##_path) object##_paths, ARRAY_SIZE(object##_paths), &object##_path)
/* procfs support */ /* procfs support */
static struct proc_dir_entry *proc_dir; static struct proc_dir_entry *proc_dir;
/* procfs helpers */ /* procfs helpers */
static int dispatch_read(char *page, char **start, off_t off, int count, static int dispatch_procfs_read(char *page, char **start, off_t off,
int *eof, void *data); int count, int *eof, void *data);
static int dispatch_write(struct file *file, const char __user * userbuf, static int dispatch_procfs_write(struct file *file,
const char __user * userbuf,
unsigned long count, void *data); unsigned long count, void *data);
static char *next_cmd(char **cmds); static char *next_cmd(char **cmds);
...@@ -140,28 +142,34 @@ static void thinkpad_acpi_module_exit(void); ...@@ -140,28 +142,34 @@ static void thinkpad_acpi_module_exit(void);
* Subdrivers * Subdrivers
*/ */
struct ibm_struct { struct ibm_struct;
char *name;
struct tp_acpi_drv_struct {
char *hid; char *hid;
struct acpi_driver *driver; struct acpi_driver *driver;
int (*read) (char *);
int (*write) (char *);
void (*exit) (void);
void (*notify) (struct ibm_struct *, u32); void (*notify) (struct ibm_struct *, u32);
acpi_handle *handle; acpi_handle *handle;
int type; u32 type;
struct acpi_device *device; struct acpi_device *device;
};
struct ibm_struct {
char *name;
int (*read) (char *);
int (*write) (char *);
void (*exit) (void);
struct list_head all_drivers; struct list_head all_drivers;
struct tp_acpi_drv_struct *acpi;
struct { struct {
u8 driver_registered:1; u8 acpi_driver_registered:1;
u8 acpi_notify_installed:1;
u8 proc_created:1; u8 proc_created:1;
u8 init_called:1; u8 init_called:1;
u8 notify_installed:1;
u8 experimental:1; u8 experimental:1;
} flags; } flags;
}; };
......
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