diff options
Diffstat (limited to 'drivers/watchdog/nv_tco.c')
-rw-r--r-- | drivers/watchdog/nv_tco.c | 46 |
1 files changed, 21 insertions, 25 deletions
diff --git a/drivers/watchdog/nv_tco.c b/drivers/watchdog/nv_tco.c index 809f41c30c44..6bbb9efc6125 100644 --- a/drivers/watchdog/nv_tco.c +++ b/drivers/watchdog/nv_tco.c | |||
@@ -21,6 +21,8 @@ | |||
21 | * Includes, defines, variables, module parameters, ... | 21 | * Includes, defines, variables, module parameters, ... |
22 | */ | 22 | */ |
23 | 23 | ||
24 | #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt | ||
25 | |||
24 | #include <linux/module.h> | 26 | #include <linux/module.h> |
25 | #include <linux/moduleparam.h> | 27 | #include <linux/moduleparam.h> |
26 | #include <linux/types.h> | 28 | #include <linux/types.h> |
@@ -41,7 +43,6 @@ | |||
41 | #define TCO_VERSION "0.01" | 43 | #define TCO_VERSION "0.01" |
42 | #define TCO_MODULE_NAME "NV_TCO" | 44 | #define TCO_MODULE_NAME "NV_TCO" |
43 | #define TCO_DRIVER_NAME TCO_MODULE_NAME ", v" TCO_VERSION | 45 | #define TCO_DRIVER_NAME TCO_MODULE_NAME ", v" TCO_VERSION |
44 | #define PFX TCO_MODULE_NAME ": " | ||
45 | 46 | ||
46 | /* internal variables */ | 47 | /* internal variables */ |
47 | static unsigned int tcobase; | 48 | static unsigned int tcobase; |
@@ -60,8 +61,8 @@ module_param(heartbeat, int, 0); | |||
60 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds. (2<heartbeat<39, " | 61 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds. (2<heartbeat<39, " |
61 | "default=" __MODULE_STRING(WATCHDOG_HEARTBEAT) ")"); | 62 | "default=" __MODULE_STRING(WATCHDOG_HEARTBEAT) ")"); |
62 | 63 | ||
63 | static int nowayout = WATCHDOG_NOWAYOUT; | 64 | static bool nowayout = WATCHDOG_NOWAYOUT; |
64 | module_param(nowayout, int, 0); | 65 | module_param(nowayout, bool, 0); |
65 | MODULE_PARM_DESC(nowayout, "Watchdog cannot be stopped once started" | 66 | MODULE_PARM_DESC(nowayout, "Watchdog cannot be stopped once started" |
66 | " (default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")"); | 67 | " (default=" __MODULE_STRING(WATCHDOG_NOWAYOUT) ")"); |
67 | 68 | ||
@@ -169,8 +170,7 @@ static int nv_tco_release(struct inode *inode, struct file *file) | |||
169 | if (tco_expect_close == 42) { | 170 | if (tco_expect_close == 42) { |
170 | tco_timer_stop(); | 171 | tco_timer_stop(); |
171 | } else { | 172 | } else { |
172 | printk(KERN_CRIT PFX "Unexpected close, not stopping " | 173 | pr_crit("Unexpected close, not stopping watchdog!\n"); |
173 | "watchdog!\n"); | ||
174 | tco_timer_keepalive(); | 174 | tco_timer_keepalive(); |
175 | } | 175 | } |
176 | clear_bit(0, &timer_alive); | 176 | clear_bit(0, &timer_alive); |
@@ -323,15 +323,14 @@ static unsigned char __devinit nv_tco_getdevice(void) | |||
323 | val &= 0xffff; | 323 | val &= 0xffff; |
324 | if (val == 0x0001 || val == 0x0000) { | 324 | if (val == 0x0001 || val == 0x0000) { |
325 | /* Something is wrong here, bar isn't setup */ | 325 | /* Something is wrong here, bar isn't setup */ |
326 | printk(KERN_ERR PFX "failed to get tcobase address\n"); | 326 | pr_err("failed to get tcobase address\n"); |
327 | return 0; | 327 | return 0; |
328 | } | 328 | } |
329 | val &= 0xff00; | 329 | val &= 0xff00; |
330 | tcobase = val + 0x40; | 330 | tcobase = val + 0x40; |
331 | 331 | ||
332 | if (!request_region(tcobase, 0x10, "NV TCO")) { | 332 | if (!request_region(tcobase, 0x10, "NV TCO")) { |
333 | printk(KERN_ERR PFX "I/O address 0x%04x already in use\n", | 333 | pr_err("I/O address 0x%04x already in use\n", tcobase); |
334 | tcobase); | ||
335 | return 0; | 334 | return 0; |
336 | } | 335 | } |
337 | 336 | ||
@@ -347,7 +346,7 @@ static unsigned char __devinit nv_tco_getdevice(void) | |||
347 | 346 | ||
348 | /* Disable SMI caused by TCO */ | 347 | /* Disable SMI caused by TCO */ |
349 | if (!request_region(MCP51_SMI_EN(tcobase), 4, "NV TCO")) { | 348 | if (!request_region(MCP51_SMI_EN(tcobase), 4, "NV TCO")) { |
350 | printk(KERN_ERR PFX "I/O address 0x%04x already in use\n", | 349 | pr_err("I/O address 0x%04x already in use\n", |
351 | MCP51_SMI_EN(tcobase)); | 350 | MCP51_SMI_EN(tcobase)); |
352 | goto out; | 351 | goto out; |
353 | } | 352 | } |
@@ -357,7 +356,7 @@ static unsigned char __devinit nv_tco_getdevice(void) | |||
357 | val = inl(MCP51_SMI_EN(tcobase)); | 356 | val = inl(MCP51_SMI_EN(tcobase)); |
358 | release_region(MCP51_SMI_EN(tcobase), 4); | 357 | release_region(MCP51_SMI_EN(tcobase), 4); |
359 | if (val & MCP51_SMI_EN_TCO) { | 358 | if (val & MCP51_SMI_EN_TCO) { |
360 | printk(KERN_ERR PFX "Could not disable SMI caused by TCO\n"); | 359 | pr_err("Could not disable SMI caused by TCO\n"); |
361 | goto out; | 360 | goto out; |
362 | } | 361 | } |
363 | 362 | ||
@@ -367,8 +366,7 @@ static unsigned char __devinit nv_tco_getdevice(void) | |||
367 | pci_write_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, val); | 366 | pci_write_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, val); |
368 | pci_read_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, &val); | 367 | pci_read_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, &val); |
369 | if (!(val & MCP51_SMBUS_SETUP_B_TCO_REBOOT)) { | 368 | if (!(val & MCP51_SMBUS_SETUP_B_TCO_REBOOT)) { |
370 | printk(KERN_ERR PFX "failed to reset NO_REBOOT flag, reboot " | 369 | pr_err("failed to reset NO_REBOOT flag, reboot disabled by hardware\n"); |
371 | "disabled by hardware\n"); | ||
372 | goto out; | 370 | goto out; |
373 | } | 371 | } |
374 | 372 | ||
@@ -387,8 +385,8 @@ static int __devinit nv_tco_init(struct platform_device *dev) | |||
387 | return -ENODEV; | 385 | return -ENODEV; |
388 | 386 | ||
389 | /* Check to see if last reboot was due to watchdog timeout */ | 387 | /* Check to see if last reboot was due to watchdog timeout */ |
390 | printk(KERN_INFO PFX "Watchdog reboot %sdetected.\n", | 388 | pr_info("Watchdog reboot %sdetected\n", |
391 | inl(TCO_STS(tcobase)) & TCO_STS_TCO2TO_STS ? "" : "not "); | 389 | inl(TCO_STS(tcobase)) & TCO_STS_TCO2TO_STS ? "" : "not "); |
392 | 390 | ||
393 | /* Clear out the old status */ | 391 | /* Clear out the old status */ |
394 | outl(TCO_STS_RESET, TCO_STS(tcobase)); | 392 | outl(TCO_STS_RESET, TCO_STS(tcobase)); |
@@ -400,14 +398,14 @@ static int __devinit nv_tco_init(struct platform_device *dev) | |||
400 | if (tco_timer_set_heartbeat(heartbeat)) { | 398 | if (tco_timer_set_heartbeat(heartbeat)) { |
401 | heartbeat = WATCHDOG_HEARTBEAT; | 399 | heartbeat = WATCHDOG_HEARTBEAT; |
402 | tco_timer_set_heartbeat(heartbeat); | 400 | tco_timer_set_heartbeat(heartbeat); |
403 | printk(KERN_INFO PFX "heartbeat value must be 2<heartbeat<39, " | 401 | pr_info("heartbeat value must be 2<heartbeat<39, using %d\n", |
404 | "using %d\n", heartbeat); | 402 | heartbeat); |
405 | } | 403 | } |
406 | 404 | ||
407 | ret = misc_register(&nv_tco_miscdev); | 405 | ret = misc_register(&nv_tco_miscdev); |
408 | if (ret != 0) { | 406 | if (ret != 0) { |
409 | printk(KERN_ERR PFX "cannot register miscdev on minor=%d " | 407 | pr_err("cannot register miscdev on minor=%d (err=%d)\n", |
410 | "(err=%d)\n", WATCHDOG_MINOR, ret); | 408 | WATCHDOG_MINOR, ret); |
411 | goto unreg_region; | 409 | goto unreg_region; |
412 | } | 410 | } |
413 | 411 | ||
@@ -415,8 +413,8 @@ static int __devinit nv_tco_init(struct platform_device *dev) | |||
415 | 413 | ||
416 | tco_timer_stop(); | 414 | tco_timer_stop(); |
417 | 415 | ||
418 | printk(KERN_INFO PFX "initialized (0x%04x). heartbeat=%d sec " | 416 | pr_info("initialized (0x%04x). heartbeat=%d sec (nowayout=%d)\n", |
419 | "(nowayout=%d)\n", tcobase, heartbeat, nowayout); | 417 | tcobase, heartbeat, nowayout); |
420 | 418 | ||
421 | return 0; | 419 | return 0; |
422 | 420 | ||
@@ -439,8 +437,7 @@ static void __devexit nv_tco_cleanup(void) | |||
439 | pci_write_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, val); | 437 | pci_write_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, val); |
440 | pci_read_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, &val); | 438 | pci_read_config_dword(tco_pci, MCP51_SMBUS_SETUP_B, &val); |
441 | if (val & MCP51_SMBUS_SETUP_B_TCO_REBOOT) { | 439 | if (val & MCP51_SMBUS_SETUP_B_TCO_REBOOT) { |
442 | printk(KERN_CRIT PFX "Couldn't unset REBOOT bit. Machine may " | 440 | pr_crit("Couldn't unset REBOOT bit. Machine may soon reset\n"); |
443 | "soon reset\n"); | ||
444 | } | 441 | } |
445 | 442 | ||
446 | /* Deregister */ | 443 | /* Deregister */ |
@@ -483,8 +480,7 @@ static int __init nv_tco_init_module(void) | |||
483 | { | 480 | { |
484 | int err; | 481 | int err; |
485 | 482 | ||
486 | printk(KERN_INFO PFX "NV TCO WatchDog Timer Driver v%s\n", | 483 | pr_info("NV TCO WatchDog Timer Driver v%s\n", TCO_VERSION); |
487 | TCO_VERSION); | ||
488 | 484 | ||
489 | err = platform_driver_register(&nv_tco_driver); | 485 | err = platform_driver_register(&nv_tco_driver); |
490 | if (err) | 486 | if (err) |
@@ -508,7 +504,7 @@ static void __exit nv_tco_cleanup_module(void) | |||
508 | { | 504 | { |
509 | platform_device_unregister(nv_tco_platform_device); | 505 | platform_device_unregister(nv_tco_platform_device); |
510 | platform_driver_unregister(&nv_tco_driver); | 506 | platform_driver_unregister(&nv_tco_driver); |
511 | printk(KERN_INFO PFX "NV TCO Watchdog Module Unloaded.\n"); | 507 | pr_info("NV TCO Watchdog Module Unloaded\n"); |
512 | } | 508 | } |
513 | 509 | ||
514 | module_init(nv_tco_init_module); | 510 | module_init(nv_tco_init_module); |