diff options
| -rw-r--r-- | drivers/char/watchdog/pcwd_usb.c | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/drivers/char/watchdog/pcwd_usb.c b/drivers/char/watchdog/pcwd_usb.c index e5c2206c6a18..1ad1f22e97d7 100644 --- a/drivers/char/watchdog/pcwd_usb.c +++ b/drivers/char/watchdog/pcwd_usb.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * Berkshire USB-PC Watchdog Card Driver | 2 | * Berkshire USB-PC Watchdog Card Driver |
| 3 | * | 3 | * |
| 4 | * (c) Copyright 2004 Wim Van Sebroeck <wim@iguana.be>. | 4 | * (c) Copyright 2004-2007 Wim Van Sebroeck <wim@iguana.be>. |
| 5 | * | 5 | * |
| 6 | * Based on source code of the following authors: | 6 | * Based on source code of the following authors: |
| 7 | * Ken Hollis <kenji@bitgate.com>, | 7 | * Ken Hollis <kenji@bitgate.com>, |
| @@ -56,8 +56,8 @@ | |||
| 56 | 56 | ||
| 57 | 57 | ||
| 58 | /* Module and Version Information */ | 58 | /* Module and Version Information */ |
| 59 | #define DRIVER_VERSION "1.01" | 59 | #define DRIVER_VERSION "1.02" |
| 60 | #define DRIVER_DATE "15 Mar 2005" | 60 | #define DRIVER_DATE "06 Jan 2007" |
| 61 | #define DRIVER_AUTHOR "Wim Van Sebroeck <wim@iguana.be>" | 61 | #define DRIVER_AUTHOR "Wim Van Sebroeck <wim@iguana.be>" |
| 62 | #define DRIVER_DESC "Berkshire USB-PC Watchdog driver" | 62 | #define DRIVER_DESC "Berkshire USB-PC Watchdog driver" |
| 63 | #define DRIVER_LICENSE "GPL" | 63 | #define DRIVER_LICENSE "GPL" |
| @@ -74,10 +74,10 @@ MODULE_ALIAS_MISCDEV(TEMP_MINOR); | |||
| 74 | module_param(debug, int, 0); | 74 | module_param(debug, int, 0); |
| 75 | MODULE_PARM_DESC(debug, "Debug enabled or not"); | 75 | MODULE_PARM_DESC(debug, "Debug enabled or not"); |
| 76 | 76 | ||
| 77 | #define WATCHDOG_HEARTBEAT 2 /* 2 sec default heartbeat */ | 77 | #define WATCHDOG_HEARTBEAT 0 /* default heartbeat = delay-time from dip-switches */ |
| 78 | static int heartbeat = WATCHDOG_HEARTBEAT; | 78 | static int heartbeat = WATCHDOG_HEARTBEAT; |
| 79 | module_param(heartbeat, int, 0); | 79 | module_param(heartbeat, int, 0); |
| 80 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds. (0<heartbeat<65536, default=" __MODULE_STRING(WATCHDOG_HEARTBEAT) ")"); | 80 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds. (0<heartbeat<65536 or 0=delay-time from dip-switches, default=" __MODULE_STRING(WATCHDOG_HEARTBEAT) ")"); |
| 81 | 81 | ||
| 82 | static int nowayout = WATCHDOG_NOWAYOUT; | 82 | static int nowayout = WATCHDOG_NOWAYOUT; |
| 83 | module_param(nowayout, int, 0); | 83 | module_param(nowayout, int, 0); |
| @@ -109,6 +109,18 @@ MODULE_DEVICE_TABLE (usb, usb_pcwd_table); | |||
| 109 | #define CMD_ENABLE_WATCHDOG 0x30 /* Enable / Disable Watchdog */ | 109 | #define CMD_ENABLE_WATCHDOG 0x30 /* Enable / Disable Watchdog */ |
| 110 | #define CMD_DISABLE_WATCHDOG CMD_ENABLE_WATCHDOG | 110 | #define CMD_DISABLE_WATCHDOG CMD_ENABLE_WATCHDOG |
| 111 | 111 | ||
| 112 | /* Watchdog's Dip Switch heartbeat values */ | ||
| 113 | static const int heartbeat_tbl [] = { | ||
| 114 | 5, /* OFF-OFF-OFF = 5 Sec */ | ||
| 115 | 10, /* OFF-OFF-ON = 10 Sec */ | ||
| 116 | 30, /* OFF-ON-OFF = 30 Sec */ | ||
| 117 | 60, /* OFF-ON-ON = 1 Min */ | ||
| 118 | 300, /* ON-OFF-OFF = 5 Min */ | ||
| 119 | 600, /* ON-OFF-ON = 10 Min */ | ||
| 120 | 1800, /* ON-ON-OFF = 30 Min */ | ||
| 121 | 3600, /* ON-ON-ON = 1 hour */ | ||
| 122 | }; | ||
| 123 | |||
| 112 | /* We can only use 1 card due to the /dev/watchdog restriction */ | 124 | /* We can only use 1 card due to the /dev/watchdog restriction */ |
| 113 | static int cards_found; | 125 | static int cards_found; |
| 114 | 126 | ||
| @@ -681,6 +693,10 @@ static int usb_pcwd_probe(struct usb_interface *interface, const struct usb_devi | |||
| 681 | ((option_switches & 0x10) ? "ON" : "OFF"), | 693 | ((option_switches & 0x10) ? "ON" : "OFF"), |
| 682 | ((option_switches & 0x08) ? "ON" : "OFF")); | 694 | ((option_switches & 0x08) ? "ON" : "OFF")); |
| 683 | 695 | ||
| 696 | /* If heartbeat = 0 then we use the heartbeat from the dip-switches */ | ||
| 697 | if (heartbeat == 0) | ||
| 698 | heartbeat = heartbeat_tbl[(option_switches & 0x07)]; | ||
| 699 | |||
| 684 | /* Check that the heartbeat value is within it's range ; if not reset to the default */ | 700 | /* Check that the heartbeat value is within it's range ; if not reset to the default */ |
| 685 | if (usb_pcwd_set_heartbeat(usb_pcwd, heartbeat)) { | 701 | if (usb_pcwd_set_heartbeat(usb_pcwd, heartbeat)) { |
| 686 | usb_pcwd_set_heartbeat(usb_pcwd, WATCHDOG_HEARTBEAT); | 702 | usb_pcwd_set_heartbeat(usb_pcwd, WATCHDOG_HEARTBEAT); |
