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

ACPI: thinkpad-acpi: add subdriver debug statements

Add debug messages to the subdriver initialization and exit code.
Signed-off-by: default avatarHenrique de Moraes Holschuh <hmh@hmh.eng.br>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 5fba344c
...@@ -710,5 +710,9 @@ enable various classes of debugging output, for example: ...@@ -710,5 +710,9 @@ enable various classes of debugging output, for example:
will enable all debugging output classes. It takes a bitmask, so will enable all debugging output classes. It takes a bitmask, so
to enable more than one output class, just add their values. to enable more than one output class, just add their values.
Debug bitmask Description
0x0001 Initialization and probing
0x0002 Removal
There is also a kernel build option to enable more debugging There is also a kernel build option to enable more debugging
information, which may be necessary to debug driver problems. information, which may be necessary to debug driver problems.
...@@ -313,6 +313,9 @@ static int __init setup_notify(struct ibm_struct *ibm) ...@@ -313,6 +313,9 @@ static int __init setup_notify(struct ibm_struct *ibm)
if (!*ibm->handle) if (!*ibm->handle)
return 0; return 0;
dbg_printk(TPACPI_DBG_INIT,
"setting up ACPI notify for %s\n", ibm->name);
ret = acpi_bus_get_device(*ibm->handle, &ibm->device); ret = acpi_bus_get_device(*ibm->handle, &ibm->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);
...@@ -349,6 +352,9 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm) ...@@ -349,6 +352,9 @@ static int __init register_tpacpi_subdriver(struct ibm_struct *ibm)
{ {
int ret; int ret;
dbg_printk(TPACPI_DBG_INIT,
"registering %s as an ACPI driver\n", ibm->name);
ibm->driver = kzalloc(sizeof(struct acpi_driver), GFP_KERNEL); ibm->driver = kzalloc(sizeof(struct acpi_driver), GFP_KERNEL);
if (!ibm->driver) { if (!ibm->driver) {
printk(IBM_ERR "kzalloc(ibm->driver) failed\n"); printk(IBM_ERR "kzalloc(ibm->driver) failed\n");
...@@ -497,17 +503,25 @@ static int hotkey_orig_mask; ...@@ -497,17 +503,25 @@ static int hotkey_orig_mask;
static int hotkey_init(void) static int hotkey_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing hotkey subdriver\n");
IBM_HANDLE_INIT(hkey); IBM_HANDLE_INIT(hkey);
/* hotkey not supported on 570 */ /* hotkey not supported on 570 */
hotkey_supported = hkey_handle != NULL; hotkey_supported = hkey_handle != NULL;
vdbg_printk(TPACPI_DBG_INIT, "hotkeys are %s\n",
str_supported(hotkey_supported));
if (hotkey_supported) { if (hotkey_supported) {
/* mask not supported on 570, 600e/x, 770e, 770x, A21e, A2xm/p, /* mask not supported on 570, 600e/x, 770e, 770x, A21e, A2xm/p,
A30, R30, R31, T20-22, X20-21, X22-24 */ A30, R30, R31, T20-22, X20-21, X22-24 */
hotkey_mask_supported = hotkey_mask_supported =
acpi_evalf(hkey_handle, NULL, "DHKN", "qv"); acpi_evalf(hkey_handle, NULL, "DHKN", "qv");
vdbg_printk(TPACPI_DBG_INIT, "hotkey masks are %s\n",
str_supported(hotkey_mask_supported));
if (!hotkey_get(&hotkey_orig_status, &hotkey_orig_mask)) if (!hotkey_get(&hotkey_orig_status, &hotkey_orig_mask))
return -ENODEV; return -ENODEV;
} }
...@@ -518,6 +532,7 @@ static int hotkey_init(void) ...@@ -518,6 +532,7 @@ static int hotkey_init(void)
static void hotkey_exit(void) static void hotkey_exit(void)
{ {
if (hotkey_supported) { if (hotkey_supported) {
dbg_printk(TPACPI_DBG_EXIT, "restoring original hotkey mask\n");
hotkey_set(hotkey_orig_status, hotkey_orig_mask); hotkey_set(hotkey_orig_status, hotkey_orig_mask);
} }
} }
...@@ -633,6 +648,8 @@ static int bluetooth_supported; ...@@ -633,6 +648,8 @@ static int bluetooth_supported;
static int bluetooth_init(void) static int bluetooth_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing bluetooth subdriver\n");
IBM_HANDLE_INIT(hkey); IBM_HANDLE_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,
...@@ -640,6 +657,9 @@ static int bluetooth_init(void) ...@@ -640,6 +657,9 @@ static int bluetooth_init(void)
bluetooth_supported = hkey_handle && bluetooth_supported = hkey_handle &&
acpi_evalf(hkey_handle, NULL, "GBDC", "qv"); acpi_evalf(hkey_handle, NULL, "GBDC", "qv");
vdbg_printk(TPACPI_DBG_INIT, "bluetooth is %s\n",
str_supported(bluetooth_supported));
return (bluetooth_supported)? 0 : 1; return (bluetooth_supported)? 0 : 1;
} }
...@@ -704,11 +724,16 @@ static int wan_supported; ...@@ -704,11 +724,16 @@ static int wan_supported;
static int wan_init(void) static int wan_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing wan subdriver\n");
IBM_HANDLE_INIT(hkey); IBM_HANDLE_INIT(hkey);
wan_supported = hkey_handle && wan_supported = hkey_handle &&
acpi_evalf(hkey_handle, NULL, "GWAN", "qv"); acpi_evalf(hkey_handle, NULL, "GWAN", "qv");
vdbg_printk(TPACPI_DBG_INIT, "wan is %s\n",
str_supported(wan_supported));
return (wan_supported)? 0 : 1; return (wan_supported)? 0 : 1;
} }
...@@ -784,6 +809,8 @@ static int video_init(void) ...@@ -784,6 +809,8 @@ static int video_init(void)
{ {
int ivga; int ivga;
vdbg_printk(TPACPI_DBG_INIT, "initializing video subdriver\n");
IBM_HANDLE_INIT(vid); IBM_HANDLE_INIT(vid);
IBM_HANDLE_INIT(vid2); IBM_HANDLE_INIT(vid2);
...@@ -804,11 +831,16 @@ static int video_init(void) ...@@ -804,11 +831,16 @@ static int video_init(void)
/* all others */ /* all others */
video_supported = TPACPI_VIDEO_NEW; video_supported = TPACPI_VIDEO_NEW;
vdbg_printk(TPACPI_DBG_INIT, "video is %s, mode %d\n",
str_supported(video_supported != TPACPI_VIDEO_NONE),
video_supported);
return (video_supported != TPACPI_VIDEO_NONE)? 0 : 1; return (video_supported != TPACPI_VIDEO_NONE)? 0 : 1;
} }
static void video_exit(void) static void video_exit(void)
{ {
dbg_printk(TPACPI_DBG_EXIT, "restoring original video autoswitch mode\n");
acpi_evalf(vid_handle, NULL, "_DOS", "vd", video_orig_autosw); acpi_evalf(vid_handle, NULL, "_DOS", "vd", video_orig_autosw);
} }
...@@ -991,6 +1023,8 @@ IBM_HANDLE(ledb, ec, "LEDB"); /* G4x */ ...@@ -991,6 +1023,8 @@ IBM_HANDLE(ledb, ec, "LEDB"); /* G4x */
static int light_init(void) static int light_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing light subdriver\n");
IBM_HANDLE_INIT(ledb); IBM_HANDLE_INIT(ledb);
IBM_HANDLE_INIT(lght); IBM_HANDLE_INIT(lght);
IBM_HANDLE_INIT(cmos); IBM_HANDLE_INIT(cmos);
...@@ -1004,6 +1038,9 @@ static int light_init(void) ...@@ -1004,6 +1038,9 @@ static int light_init(void)
light_status_supported = acpi_evalf(ec_handle, NULL, light_status_supported = acpi_evalf(ec_handle, NULL,
"KBLT", "qv"); "KBLT", "qv");
vdbg_printk(TPACPI_DBG_INIT, "light is %s\n",
str_supported(light_supported));
return (light_supported)? 0 : 1; return (light_supported)? 0 : 1;
} }
...@@ -1075,9 +1112,14 @@ IBM_HANDLE(pci, root, "\\_SB.PCI"); /* 570 */ ...@@ -1075,9 +1112,14 @@ IBM_HANDLE(pci, root, "\\_SB.PCI"); /* 570 */
static int dock_init(void) static int dock_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing dock subdriver\n");
IBM_HANDLE_INIT(dock); IBM_HANDLE_INIT(dock);
IBM_HANDLE_INIT(pci); IBM_HANDLE_INIT(pci);
vdbg_printk(TPACPI_DBG_INIT, "dock is %s\n",
str_supported(dock_handle != NULL));
return (dock_handle)? 0 : 1; return (dock_handle)? 0 : 1;
} }
...@@ -1171,6 +1213,8 @@ IBM_HANDLE(bay2_ej, bay2, "_EJ3", /* 600e/x, 770e, A3x */ ...@@ -1171,6 +1213,8 @@ IBM_HANDLE(bay2_ej, bay2, "_EJ3", /* 600e/x, 770e, A3x */
static int bay_init(void) static int bay_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing bay subdriver\n");
IBM_HANDLE_INIT(bay); IBM_HANDLE_INIT(bay);
if (bay_handle) if (bay_handle)
IBM_HANDLE_INIT(bay_ej); IBM_HANDLE_INIT(bay_ej);
...@@ -1188,6 +1232,13 @@ static int bay_init(void) ...@@ -1188,6 +1232,13 @@ static int bay_init(void)
bay_eject2_supported = bay2_handle && bay2_ej_handle && bay_eject2_supported = bay2_handle && bay2_ej_handle &&
(strlencmp(bay2_ej_path, "_EJ0") == 0 || experimental); (strlencmp(bay2_ej_path, "_EJ0") == 0 || experimental);
vdbg_printk(TPACPI_DBG_INIT,
"bay 1: status %s, eject %s; bay 2: status %s, eject %s\n",
str_supported(bay_status_supported),
str_supported(bay_eject_supported),
str_supported(bay_status2_supported),
str_supported(bay_eject2_supported));
return (bay_status_supported || bay_eject_supported || return (bay_status_supported || bay_eject_supported ||
bay_status2_supported || bay_eject2_supported)? 0 : 1; bay_status2_supported || bay_eject2_supported)? 0 : 1;
} }
...@@ -1255,8 +1306,13 @@ static int bay_write(char *buf) ...@@ -1255,8 +1306,13 @@ static int bay_write(char *buf)
static int cmos_init(void) static int cmos_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT,
"initializing cmos commands subdriver\n");
IBM_HANDLE_INIT(cmos); IBM_HANDLE_INIT(cmos);
vdbg_printk(TPACPI_DBG_INIT, "cmos commands are %s\n",
str_supported(cmos_handle != NULL));
return (cmos_handle)? 0 : 1; return (cmos_handle)? 0 : 1;
} }
...@@ -1320,6 +1376,8 @@ IBM_HANDLE(led, ec, "SLED", /* 570 */ ...@@ -1320,6 +1376,8 @@ IBM_HANDLE(led, ec, "SLED", /* 570 */
static int led_init(void) static int led_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing LED subdriver\n");
IBM_HANDLE_INIT(led); IBM_HANDLE_INIT(led);
if (!led_handle) if (!led_handle)
...@@ -1335,6 +1393,9 @@ static int led_init(void) ...@@ -1335,6 +1393,9 @@ static int led_init(void)
/* all others */ /* all others */
led_supported = TPACPI_LED_NEW; led_supported = TPACPI_LED_NEW;
vdbg_printk(TPACPI_DBG_INIT, "LED commands are %s, mode %d\n",
str_supported(led_supported), led_supported);
return (led_supported != TPACPI_LED_NONE)? 0 : 1; return (led_supported != TPACPI_LED_NONE)? 0 : 1;
} }
...@@ -1434,8 +1495,13 @@ IBM_HANDLE(beep, ec, "BEEP"); /* all except R30, R31 */ ...@@ -1434,8 +1495,13 @@ IBM_HANDLE(beep, ec, "BEEP"); /* all except R30, R31 */
static int beep_init(void) static int beep_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing beep subdriver\n");
IBM_HANDLE_INIT(beep); IBM_HANDLE_INIT(beep);
vdbg_printk(TPACPI_DBG_INIT, "beep is %s\n",
str_supported(beep_handle != NULL));
return (beep_handle)? 0 : 1; return (beep_handle)? 0 : 1;
} }
...@@ -1486,6 +1552,8 @@ static int thermal_init(void) ...@@ -1486,6 +1552,8 @@ static int thermal_init(void)
int i; int i;
int acpi_tmp7; int acpi_tmp7;
vdbg_printk(TPACPI_DBG_INIT, "initializing thermal subdriver\n");
acpi_tmp7 = acpi_evalf(ec_handle, NULL, "TMP7", "qv"); acpi_tmp7 = acpi_evalf(ec_handle, NULL, "TMP7", "qv");
if (ibm_thinkpad_ec_found && experimental) { if (ibm_thinkpad_ec_found && experimental) {
...@@ -1542,6 +1610,10 @@ static int thermal_init(void) ...@@ -1542,6 +1610,10 @@ static int thermal_init(void)
thermal_read_mode = TPACPI_THERMAL_NONE; thermal_read_mode = TPACPI_THERMAL_NONE;
} }
vdbg_printk(TPACPI_DBG_INIT, "thermal is %s, mode %d\n",
str_supported(thermal_read_mode != TPACPI_THERMAL_NONE),
thermal_read_mode);
return (thermal_read_mode != TPACPI_THERMAL_NONE)? 0 : 1; return (thermal_read_mode != TPACPI_THERMAL_NONE)? 0 : 1;
} }
...@@ -1698,6 +1770,8 @@ static int brightness_init(void) ...@@ -1698,6 +1770,8 @@ static int brightness_init(void)
{ {
int b; int b;
vdbg_printk(TPACPI_DBG_INIT, "initializing brightness subdriver\n");
b = brightness_get(NULL); b = brightness_get(NULL);
if (b < 0) if (b < 0)
return b; return b;
...@@ -1708,6 +1782,7 @@ static int brightness_init(void) ...@@ -1708,6 +1782,7 @@ static int brightness_init(void)
printk(IBM_ERR "Could not register backlight device\n"); printk(IBM_ERR "Could not register backlight device\n");
return PTR_ERR(ibm_backlight_device); return PTR_ERR(ibm_backlight_device);
} }
vdbg_printk(TPACPI_DBG_INIT, "brightness is supported\n");
ibm_backlight_device->props.max_brightness = 7; ibm_backlight_device->props.max_brightness = 7;
ibm_backlight_device->props.brightness = b; ibm_backlight_device->props.brightness = b;
...@@ -1719,6 +1794,8 @@ static int brightness_init(void) ...@@ -1719,6 +1794,8 @@ static int brightness_init(void)
static void brightness_exit(void) static void brightness_exit(void)
{ {
if (ibm_backlight_device) { if (ibm_backlight_device) {
vdbg_printk(TPACPI_DBG_EXIT,
"calling backlight_device_unregister()\n");
backlight_device_unregister(ibm_backlight_device); backlight_device_unregister(ibm_backlight_device);
ibm_backlight_device = NULL; ibm_backlight_device = NULL;
} }
...@@ -2017,6 +2094,8 @@ IBM_HANDLE(sfan, ec, "SFAN", /* 570 */ ...@@ -2017,6 +2094,8 @@ IBM_HANDLE(sfan, ec, "SFAN", /* 570 */
static int fan_init(void) static int fan_init(void)
{ {
vdbg_printk(TPACPI_DBG_INIT, "initializing fan subdriver\n");
fan_status_access_mode = TPACPI_FAN_NONE; fan_status_access_mode = TPACPI_FAN_NONE;
fan_control_access_mode = TPACPI_FAN_WR_NONE; fan_control_access_mode = TPACPI_FAN_WR_NONE;
fan_control_commands = 0; fan_control_commands = 0;
...@@ -2095,6 +2174,11 @@ static int fan_init(void) ...@@ -2095,6 +2174,11 @@ static int fan_init(void)
} }
} }
vdbg_printk(TPACPI_DBG_INIT, "fan is %s, modes %d, %d\n",
str_supported(fan_status_access_mode != TPACPI_FAN_NONE ||
fan_control_access_mode != TPACPI_FAN_WR_NONE),
fan_status_access_mode, fan_control_access_mode);
return (fan_status_access_mode != TPACPI_FAN_NONE || return (fan_status_access_mode != TPACPI_FAN_NONE ||
fan_control_access_mode != TPACPI_FAN_WR_NONE)? fan_control_access_mode != TPACPI_FAN_WR_NONE)?
0 : 1; 0 : 1;
...@@ -2138,6 +2222,7 @@ static int fan_get_status(u8 *status) ...@@ -2138,6 +2222,7 @@ static int fan_get_status(u8 *status)
static void fan_exit(void) static void fan_exit(void)
{ {
vdbg_printk(TPACPI_DBG_EXIT, "cancelling any pending watchdogs\n");
cancel_delayed_work(&fan_watchdog_task); cancel_delayed_work(&fan_watchdog_task);
flush_scheduled_work(); flush_scheduled_work();
} }
...@@ -2622,6 +2707,15 @@ static struct ibm_struct ibms[] = { ...@@ -2622,6 +2707,15 @@ static struct ibm_struct ibms[] = {
* Module and infrastructure proble, init and exit handling * Module and infrastructure proble, init and exit handling
*/ */
#ifdef CONFIG_THINKPAD_ACPI_DEBUG
static const char * str_supported(int is_supported)
{
static const char * const text_unsupported = "not supported";
return (is_supported)? text_unsupported + 4 : text_unsupported;
}
#endif /* CONFIG_THINKPAD_ACPI_DEBUG */
static int __init ibm_init(struct ibm_struct *ibm) static int __init ibm_init(struct ibm_struct *ibm)
{ {
int ret; int ret;
...@@ -2630,6 +2724,9 @@ static int __init ibm_init(struct ibm_struct *ibm) ...@@ -2630,6 +2724,9 @@ static int __init ibm_init(struct ibm_struct *ibm)
if (ibm->experimental && !experimental) if (ibm->experimental && !experimental)
return 0; return 0;
dbg_printk(TPACPI_DBG_INIT,
"probing for %s\n", ibm->name);
if (ibm->init) { if (ibm->init) {
ret = ibm->init(); ret = ibm->init();
if (ret > 0) if (ret > 0)
...@@ -2657,6 +2754,9 @@ static int __init ibm_init(struct ibm_struct *ibm) ...@@ -2657,6 +2754,9 @@ static int __init ibm_init(struct ibm_struct *ibm)
goto err_out; goto err_out;
} }
dbg_printk(TPACPI_DBG_INIT,
"%s installed\n", ibm->name);
if (ibm->read) { if (ibm->read) {
entry = create_proc_entry(ibm->name, entry = create_proc_entry(ibm->name,
S_IFREG | S_IRUGO | S_IWUSR, S_IFREG | S_IRUGO | S_IWUSR,
...@@ -2678,24 +2778,35 @@ static int __init ibm_init(struct ibm_struct *ibm) ...@@ -2678,24 +2778,35 @@ static int __init ibm_init(struct ibm_struct *ibm)
return 0; return 0;
err_out: err_out:
dbg_printk(TPACPI_DBG_INIT,
"%s: at error exit path with result %d\n",
ibm->name, ret);
ibm_exit(ibm); ibm_exit(ibm);
return (ret < 0)? ret : 0; return (ret < 0)? ret : 0;
} }
static void ibm_exit(struct ibm_struct *ibm) static void ibm_exit(struct ibm_struct *ibm)
{ {
dbg_printk(TPACPI_DBG_EXIT, "removing %s\n", ibm->name);
if (ibm->notify_installed) { if (ibm->notify_installed) {
dbg_printk(TPACPI_DBG_EXIT,
"%s: acpi_remove_notify_handler\n", ibm->name);
acpi_remove_notify_handler(*ibm->handle, ibm->type, acpi_remove_notify_handler(*ibm->handle, ibm->type,
dispatch_notify); dispatch_notify);
ibm->notify_installed = 0; ibm->notify_installed = 0;
} }
if (ibm->proc_created) { if (ibm->proc_created) {
dbg_printk(TPACPI_DBG_EXIT,
"%s: remove_proc_entry\n", ibm->name);
remove_proc_entry(ibm->name, proc_dir); remove_proc_entry(ibm->name, proc_dir);
ibm->proc_created = 0; ibm->proc_created = 0;
} }
if (ibm->driver_registered) { if (ibm->driver_registered) {
dbg_printk(TPACPI_DBG_EXIT,
"%s: acpi_bus_unregister_driver\n", ibm->name);
acpi_bus_unregister_driver(ibm->driver); acpi_bus_unregister_driver(ibm->driver);
kfree(ibm->driver); kfree(ibm->driver);
ibm->driver = NULL; ibm->driver = NULL;
......
...@@ -76,12 +76,16 @@ ...@@ -76,12 +76,16 @@
/* Debugging */ /* Debugging */
#define TPACPI_DBG_ALL 0xffff #define TPACPI_DBG_ALL 0xffff
#define TPACPI_DBG_ALL 0xffff
#define TPACPI_DBG_INIT 0x0001
#define TPACPI_DBG_EXIT 0x0002
#define dbg_printk(a_dbg_level, format, arg...) \ #define dbg_printk(a_dbg_level, format, arg...) \
do { if (dbg_level & a_dbg_level) \ do { if (dbg_level & a_dbg_level) \
printk(IBM_DEBUG "%s: " format, __func__ , ## arg); } while (0) printk(IBM_DEBUG "%s: " format, __func__ , ## arg); } while (0)
#ifdef CONFIG_THINKPAD_ACPI_DEBUG #ifdef CONFIG_THINKPAD_ACPI_DEBUG
#define vdbg_printk(a_dbg_level, format, arg...) \ #define vdbg_printk(a_dbg_level, format, arg...) \
dbg_printk(a_dbg_level, format, ## arg) dbg_printk(a_dbg_level, format, ## arg)
static const char *str_supported(int is_supported);
#else #else
#define vdbg_printk(a_dbg_level, format, arg...) #define vdbg_printk(a_dbg_level, format, arg...)
#endif #endif
......
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