linux-watchdog.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFC PATCH v2 0/7] kernel: Add support for restart notifier call chain
@ 2014-07-06 23:38 Guenter Roeck
  2014-07-06 23:38 ` [PATCH v2 1/7] " Guenter Roeck
                   ` (6 more replies)
  0 siblings, 7 replies; 12+ messages in thread
From: Guenter Roeck @ 2014-07-06 23:38 UTC (permalink / raw)
  To: linux-watchdog, linux-arm-kernel
  Cc: Wim Van Sebroeck, Catalin Marinas, Maxime Ripard, Will Deacon,
	Arnd Bergmann, Heiko Stuebner, Russell King, Jonas Jensen,
	Randy Dunlap, Andrew Morton, Steven Rostedt, Ingo Molnar,
	Dmitry Eremin-Solenikov, David Woodhouse, linux-doc, linux-kernel,
	Guenter Roeck

Various drivers implement architecture and/or device specific means
to restart (reset) the system. Various mechanisms have been implemented
to support those schemes. The best known mechanism is arm_pm_restart,
which is a function pointer to be set either from platform specific code
or from drivers. Another mechanism is to use hardware watchdogs to issue
a reset; this mechanism is used if there is no other method available
to reset a board or system. Two examples are alim7101_wdt, which currently
uses the reboot notifier to trigger a reset, and moxart_wdt, which registers
the arm_pm_restart function.

The existing mechanisms have a number of drawbacks. Typically only one scheme
to restart the system is supported (at least if arm_pm_restart is used).
At least in theory there can be mutliple means to restart the system, some of
which may be less desirable (for example one mechanism may only reset the CPU,
while another may reset the entire system). Using arm_pm_restart can also be
racy if the function pointer is set from a driver, as the driver may be in
the process of being unloaded when arm_pm_restart is called.
Using the reboot notifier is always racy, as it is unknown if and when
other functions using the reboot notifier have completed execution
by the time the watchdog fires.

To solve the problem, introduce a system restart notifier. This notifier
is expected to be called from the architecture specific machine_restart()
function. Drivers providing system restart functionality (such as the watchdog
drivers mentioned above) are expected to register with this notifier.

Patch 1 of this series implements the notifier function. Patches 2 and 3
implement calling the notifier chain from arm and arm64 restart code.

Patch 4 modifies the restart-poweroff driver to no longer call arm_pm_restart
directly but machine_restart. This is done to avoid calling arm_pm_restart
from more than one place. The change makes the driver architecture independent,
so it would be possible to drop the arm dependency from its Kconfig entry.

Patch 5 and 6 convert existing restart handlers in the watchdog subsystem
to use the restart notifier. Patch 7 unexports arm_pm_restart to ensure
that no one gets the idea to implement a restart handler as module.

---
v2: Add patch 4
    Only call blocking notifier call chain if arm_pm_restart was not set.

^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2014-07-08  1:12 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-07-06 23:38 [RFC PATCH v2 0/7] kernel: Add support for restart notifier call chain Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 1/7] " Guenter Roeck
2014-07-07 21:14   ` Andrew Morton
2014-07-08  1:10     ` Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 2/7] arm64: Support restart through " Guenter Roeck
2014-07-07 21:16   ` Andrew Morton
2014-07-08  1:12     ` Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 3/7] arm: " Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 4/7] power/restart: Call machine_restart instead of arm_pm_restart Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 5/7] watchdog: moxart: Register restart handler with restart notifier Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 6/7] watchdog: alim7101: " Guenter Roeck
2014-07-06 23:38 ` [PATCH v2 7/7] arm/arm64: Unexport restart handlers Guenter Roeck

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).