watchdog: introduce CONFIG_WATCHDOG_OPEN_TIMEOUT
authorRasmus Villemoes <rasmus.villemoes@prevas.dk>
Wed, 5 Jun 2019 14:06:43 +0000 (14:06 +0000)
committerWim Van Sebroeck <wim@linux-watchdog.org>
Mon, 8 Jul 2019 18:04:13 +0000 (20:04 +0200)
This allows setting a default value for the watchdog.open_timeout
commandline parameter via Kconfig.

Some BSPs allow remote updating of the kernel image and root file
system, but updating the bootloader requires physical access. Hence, if
one has a firmware update that requires relaxing the
watchdog.open_timeout a little, the value used must be baked into the
kernel image itself and cannot come from the u-boot environment via the
kernel command line.

Being able to set the initial value in .config doesn't change the fact
that the value on the command line, if present, takes precedence, and is
of course immensely useful for development purposes while one has
console acccess, as well as usable in the cases where one can make a
permanent update of the kernel command line.

Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk>
Reviewed-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Wim Van Sebroeck <wim@linux-watchdog.org>
Documentation/watchdog/watchdog-parameters.txt
drivers/watchdog/Kconfig
drivers/watchdog/watchdog_dev.c

index 32d3606caa657de059c37d7fa13a9d95da4d1fd9..ec919dc895ff7f45222fb5f1ba6e13e14dde7941 100644 (file)
@@ -11,10 +11,10 @@ modules.
 The watchdog core parameter watchdog.open_timeout is the maximum time,
 in seconds, for which the watchdog framework will take care of pinging
 a running hardware watchdog until userspace opens the corresponding
-/dev/watchdogN device. A value of 0 (the default) means an infinite
-timeout. Setting this to a non-zero value can be useful to ensure that
-either userspace comes up properly, or the board gets reset and allows
-fallback logic in the bootloader to try something else.
+/dev/watchdogN device. A value of 0 means an infinite timeout. Setting
+this to a non-zero value can be useful to ensure that either userspace
+comes up properly, or the board gets reset and allows fallback logic
+in the bootloader to try something else.
 
 
 -------------------------------------------------
index 975e573a6ea57d94c57d8b100de57813c245ac34..ec2647ea20e961294feb5d388654e469ad780680 100644 (file)
@@ -58,6 +58,15 @@ config WATCHDOG_HANDLE_BOOT_ENABLED
          the watchdog on its own. Thus if your userspace does not start fast
          enough your device will reboot.
 
+config WATCHDOG_OPEN_TIMEOUT
+       int "Timeout value for opening watchdog device"
+       default 0
+       help
+         The maximum time, in seconds, for which the watchdog framework takes
+         care of pinging a hardware watchdog.  A value of 0 means infinite. The
+         value set here can be overridden by the commandline parameter
+         "watchdog.open_timeout".
+
 config WATCHDOG_SYSFS
        bool "Read different watchdog information through sysfs"
        help
index e4b51db48f0e9c1cc04e3d2f7e9b453767c4cd2b..334b810db2cf9ab0bd22c909732b7bfb2c106500 100644 (file)
@@ -88,7 +88,7 @@ static struct kthread_worker *watchdog_kworker;
 static bool handle_boot_enabled =
        IS_ENABLED(CONFIG_WATCHDOG_HANDLE_BOOT_ENABLED);
 
-static unsigned open_timeout;
+static unsigned open_timeout = CONFIG_WATCHDOG_OPEN_TIMEOUT;
 
 static bool watchdog_past_open_deadline(struct watchdog_core_data *data)
 {
@@ -1214,4 +1214,5 @@ MODULE_PARM_DESC(handle_boot_enabled,
 
 module_param(open_timeout, uint, 0644);
 MODULE_PARM_DESC(open_timeout,
-       "Maximum time (in seconds, 0 means infinity) for userspace to take over a running watchdog (default=0)");
+       "Maximum time (in seconds, 0 means infinity) for userspace to take over a running watchdog (default="
+       __MODULE_STRING(CONFIG_WATCHDOG_OPEN_TIMEOUT) ")");