Watchdog: disable watchdog timer when hard-rebooting a guest.
commit36888c6335422f07bbc50bf3443a39f24b90c7c6
authorRichard W.M. Jones <rjones@redhat.com>
Fri, 24 Sep 2010 15:08:06 +0000 (24 16:08 +0100)
committerBlue Swirl <blauwirbel@gmail.com>
Sun, 12 Dec 2010 13:10:55 +0000 (12 13:10 +0000)
treedc83339d92d931d8e3e96c82052e507975d40ac6
parent962630f207a33b7de4316022884b5241e05491cd
Watchdog: disable watchdog timer when hard-rebooting a guest.

This commit causes the watchdog timer to be reset when a guest is
hard-rebooted.

The failure case previously was as follows:

  (a) guest boots, watchdog is enabled

  (b) guest does a reset eg:
        echo 'b' > /proc/sysrq-trigger
    (note that an ordinary /sbin/reboot wouldn't hit this case
    since as the watchdog daemon is shut down, the daemon would
    properly disable the watchdog device)

  (c) the reboot takes longer than the remaining time on the
    watchdog

  (d) the watchdog therefore fires during the reboot

  (e) probably the VM would just reboot again at this point which
    is pretty benign, but it could depend on the action that the
    user had selected for the watchdog

Now we use the qdev reset function to register a reset handler
which disables the timer.  Note the handler is called _either_
just after init _or_ when the guest reboots.

In the i6300esb case there is a small refactoring of the code so
that the device's internal state is now fully restored to defaults
on a reboot.

Signed-off-by: Richard W.M. Jones <rjones@redhat.com>
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
hw/wdt_i6300esb.c
hw/wdt_ib700.c