aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/watchdog/i6300esb.c90
1 files changed, 57 insertions, 33 deletions
diff --git a/drivers/watchdog/i6300esb.c b/drivers/watchdog/i6300esb.c
index 97ac6bf42224..fbe852853248 100644
--- a/drivers/watchdog/i6300esb.c
+++ b/drivers/watchdog/i6300esb.c
@@ -13,7 +13,7 @@
13 * 13 *
14 * The timer is implemented in the following I/O controller hubs: 14 * The timer is implemented in the following I/O controller hubs:
15 * (See the intel documentation on http://developer.intel.com.) 15 * (See the intel documentation on http://developer.intel.com.)
16 * 6300ESB chip : document number 300641-003 16 * 6300ESB chip : document number 300641-004
17 * 17 *
18 * 2004YYZZ Ross Biro 18 * 2004YYZZ Ross Biro
19 * Initial version 0.01 19 * Initial version 0.01
@@ -34,7 +34,7 @@
34#include <linux/mm.h> 34#include <linux/mm.h>
35#include <linux/miscdevice.h> 35#include <linux/miscdevice.h>
36#include <linux/watchdog.h> 36#include <linux/watchdog.h>
37#include <linux/reboot.h> 37#include <linux/platform_device.h>
38#include <linux/init.h> 38#include <linux/init.h>
39#include <linux/pci.h> 39#include <linux/pci.h>
40#include <linux/ioport.h> 40#include <linux/ioport.h>
@@ -42,7 +42,7 @@
42#include <linux/io.h> 42#include <linux/io.h>
43 43
44/* Module and version information */ 44/* Module and version information */
45#define ESB_VERSION "0.03" 45#define ESB_VERSION "0.04"
46#define ESB_MODULE_NAME "i6300ESB timer" 46#define ESB_MODULE_NAME "i6300ESB timer"
47#define ESB_DRIVER_NAME ESB_MODULE_NAME ", v" ESB_VERSION 47#define ESB_DRIVER_NAME ESB_MODULE_NAME ", v" ESB_VERSION
48#define PFX ESB_MODULE_NAME ": " 48#define PFX ESB_MODULE_NAME ": "
@@ -81,6 +81,8 @@ static unsigned long timer_alive;
81static struct pci_dev *esb_pci; 81static struct pci_dev *esb_pci;
82static unsigned short triggered; /* The status of the watchdog upon boot */ 82static unsigned short triggered; /* The status of the watchdog upon boot */
83static char esb_expect_close; 83static char esb_expect_close;
84static struct platform_device *esb_platform_device;
85
84 86
85/* module parameters */ 87/* module parameters */
86/* 30 sec default heartbeat (1 < heartbeat < 2*1023) */ 88/* 30 sec default heartbeat (1 < heartbeat < 2*1023) */
@@ -320,19 +322,6 @@ static long esb_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
320} 322}
321 323
322/* 324/*
323 * Notify system
324 */
325
326static int esb_notify_sys(struct notifier_block *this,
327 unsigned long code, void *unused)
328{
329 if (code == SYS_DOWN || code == SYS_HALT)
330 esb_timer_stop(); /* Turn the WDT off */
331
332 return NOTIFY_DONE;
333}
334
335/*
336 * Kernel Interfaces 325 * Kernel Interfaces
337 */ 326 */
338 327
@@ -351,10 +340,6 @@ static struct miscdevice esb_miscdev = {
351 .fops = &esb_fops, 340 .fops = &esb_fops,
352}; 341};
353 342
354static struct notifier_block esb_notifier = {
355 .notifier_call = esb_notify_sys,
356};
357
358/* 343/*
359 * Data for PCI driver interface 344 * Data for PCI driver interface
360 * 345 *
@@ -373,7 +358,7 @@ MODULE_DEVICE_TABLE(pci, esb_pci_tbl);
373 * Init & exit routines 358 * Init & exit routines
374 */ 359 */
375 360
376static unsigned char __init esb_getdevice(void) 361static unsigned char __devinit esb_getdevice(void)
377{ 362{
378 u8 val1; 363 u8 val1;
379 unsigned short val2; 364 unsigned short val2;
@@ -444,7 +429,7 @@ err_devput:
444 return 0; 429 return 0;
445} 430}
446 431
447static int __init watchdog_init(void) 432static int __devinit esb_probe(struct platform_device *dev)
448{ 433{
449 int ret; 434 int ret;
450 435
@@ -460,19 +445,13 @@ static int __init watchdog_init(void)
460 "heartbeat value must be 1<heartbeat<2046, using %d\n", 445 "heartbeat value must be 1<heartbeat<2046, using %d\n",
461 heartbeat); 446 heartbeat);
462 } 447 }
463 ret = register_reboot_notifier(&esb_notifier);
464 if (ret != 0) {
465 printk(KERN_ERR PFX
466 "cannot register reboot notifier (err=%d)\n", ret);
467 goto err_unmap;
468 }
469 448
470 ret = misc_register(&esb_miscdev); 449 ret = misc_register(&esb_miscdev);
471 if (ret != 0) { 450 if (ret != 0) {
472 printk(KERN_ERR PFX 451 printk(KERN_ERR PFX
473 "cannot register miscdev on minor=%d (err=%d)\n", 452 "cannot register miscdev on minor=%d (err=%d)\n",
474 WATCHDOG_MINOR, ret); 453 WATCHDOG_MINOR, ret);
475 goto err_notifier; 454 goto err_unmap;
476 } 455 }
477 esb_timer_stop(); 456 esb_timer_stop();
478 printk(KERN_INFO PFX 457 printk(KERN_INFO PFX
@@ -480,8 +459,6 @@ static int __init watchdog_init(void)
480 BASEADDR, heartbeat, nowayout); 459 BASEADDR, heartbeat, nowayout);
481 return 0; 460 return 0;
482 461
483err_notifier:
484 unregister_reboot_notifier(&esb_notifier);
485err_unmap: 462err_unmap:
486 iounmap(BASEADDR); 463 iounmap(BASEADDR);
487/* err_release: */ 464/* err_release: */
@@ -493,7 +470,7 @@ err_unmap:
493 return ret; 470 return ret;
494} 471}
495 472
496static void __exit watchdog_cleanup(void) 473static int __devexit esb_remove(struct platform_device *dev)
497{ 474{
498 /* Stop the timer before we leave */ 475 /* Stop the timer before we leave */
499 if (!nowayout) 476 if (!nowayout)
@@ -501,11 +478,58 @@ static void __exit watchdog_cleanup(void)
501 478
502 /* Deregister */ 479 /* Deregister */
503 misc_deregister(&esb_miscdev); 480 misc_deregister(&esb_miscdev);
504 unregister_reboot_notifier(&esb_notifier);
505 iounmap(BASEADDR); 481 iounmap(BASEADDR);
506 pci_release_region(esb_pci, 0); 482 pci_release_region(esb_pci, 0);
507 pci_disable_device(esb_pci); 483 pci_disable_device(esb_pci);
508 pci_dev_put(esb_pci); 484 pci_dev_put(esb_pci);
485 return 0;
486}
487
488static void esb_shutdown(struct platform_device *dev)
489{
490 esb_timer_stop();
491}
492
493static struct platform_driver esb_platform_driver = {
494 .probe = esb_probe,
495 .remove = __devexit_p(esb_remove),
496 .shutdown = esb_shutdown,
497 .driver = {
498 .owner = THIS_MODULE,
499 .name = ESB_MODULE_NAME,
500 },
501};
502
503static int __init watchdog_init(void)
504{
505 int err;
506
507 printk(KERN_INFO PFX "Intel 6300ESB WatchDog Timer Driver v%s\n",
508 ESB_VERSION);
509
510 err = platform_driver_register(&esb_platform_driver);
511 if (err)
512 return err;
513
514 esb_platform_device = platform_device_register_simple(ESB_MODULE_NAME,
515 -1, NULL, 0);
516 if (IS_ERR(esb_platform_device)) {
517 err = PTR_ERR(esb_platform_device);
518 goto unreg_platform_driver;
519 }
520
521 return 0;
522
523unreg_platform_driver:
524 platform_driver_unregister(&esb_platform_driver);
525 return err;
526}
527
528static void __exit watchdog_cleanup(void)
529{
530 platform_device_unregister(esb_platform_device);
531 platform_driver_unregister(&esb_platform_driver);
532 printk(KERN_INFO PFX "Watchdog Module Unloaded.\n");
509} 533}
510 534
511module_init(watchdog_init); 535module_init(watchdog_init);