Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2accf320 authored by Wolfram Sang's avatar Wolfram Sang Committed by Wim Van Sebroeck
Browse files

watchdog: softdog: implement pretimeout support



Give devices which do not have hardware support for pretimeout at least a
software version of it.

Signed-off-by: default avatarWolfram Sang <wsa+renesas@sang-engineering.com>
Signed-off-by: default avatarVladimir Zapolskiy <vladimir_zapolskiy@mentor.com>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarWim Van Sebroeck <wim@iguana.be>
parent 89873a71
Loading
Loading
Loading
Loading
+21 −1
Original line number Diff line number Diff line
@@ -72,10 +72,27 @@ static void softdog_fire(unsigned long data)
static struct timer_list softdog_ticktock =
		TIMER_INITIALIZER(softdog_fire, 0, 0);

static struct watchdog_device softdog_dev;

static void softdog_pretimeout(unsigned long data)
{
	watchdog_notify_pretimeout(&softdog_dev);
}

static struct timer_list softdog_preticktock =
		TIMER_INITIALIZER(softdog_pretimeout, 0, 0);

static int softdog_ping(struct watchdog_device *w)
{
	if (!mod_timer(&softdog_ticktock, jiffies + (w->timeout * HZ)))
		__module_get(THIS_MODULE);

	if (w->pretimeout)
		mod_timer(&softdog_preticktock, jiffies +
			  (w->timeout - w->pretimeout) * HZ);
	else
		del_timer(&softdog_preticktock);

	return 0;
}

@@ -84,12 +101,15 @@ static int softdog_stop(struct watchdog_device *w)
	if (del_timer(&softdog_ticktock))
		module_put(THIS_MODULE);

	del_timer(&softdog_preticktock);

	return 0;
}

static struct watchdog_info softdog_info = {
	.identity = "Software Watchdog",
	.options = WDIOF_SETTIMEOUT | WDIOF_KEEPALIVEPING | WDIOF_MAGICCLOSE,
	.options = WDIOF_SETTIMEOUT | WDIOF_KEEPALIVEPING | WDIOF_MAGICCLOSE |
		   WDIOF_PRETIMEOUT,
};

static const struct watchdog_ops softdog_ops = {