[systemd-devel] [PATCH] shutdown: do reboot() for openvz container
Kir Kolyshkin
kolyshkin at gmail.com
Sun Aug 26 05:42:39 PDT 2012
From: Kir Kolyshkin <kir at openvz.org>
Proper handling of reboot() syscall issued from the inside of a container
was always supported by OpenVZ kernels. More to say, OpenVZ relies on the fact
that container calls reboot in order to distinguish between shutdown and
reboot-- in the latter case container is being restarted.
This patch brings the reboot() back for OpenVZ container.
Originally found when using Fedora 17 container (systemd-44-17.fc17)
and reported to OpenVZ bugzilla: http://bugzilla.openvz.org/2336
Reported-by: Dāvis <davispuh at inbox.lv>
Cc: Konstantin Volckov <wolf at parallels.com>
Cc: Alexander Fenster <afenster at parallels.com>
Signed-off-by: Kir Kolyshkin <kir at openvz.org>
---
src/core/shutdown.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/src/core/shutdown.c b/src/core/shutdown.c
index c3a4c39..50536fc 100644
--- a/src/core/shutdown.c
+++ b/src/core/shutdown.c
@@ -132,8 +132,9 @@ static int pivot_to_new_root(void) {
int main(int argc, char *argv[]) {
int cmd, r;
unsigned retries;
- bool need_umount = true, need_swapoff = true, need_loop_detach = true, need_dm_detach = true;
+ bool need_umount = true, need_swapoff = true, need_loop_detach = true, need_dm_detach = true, need_reboot = true;
bool in_container, use_watchdog = false;
+ const char *container_type;
char *arguments[3];
log_parse_environment();
@@ -154,7 +155,7 @@ int main(int argc, char *argv[]) {
goto error;
}
- in_container = detect_container(NULL) > 0;
+ in_container = detect_container(&container_type) > 0;
if (streq(argv[1], "reboot"))
cmd = RB_AUTOBOOT;
@@ -185,6 +186,8 @@ int main(int argc, char *argv[]) {
need_swapoff = false;
need_dm_detach = false;
need_loop_detach = false;
+ if (!streq(container_type, "openvz"))
+ need_reboot = false;
}
/* Unmount all mountpoints, swaps, and loopback devices */
@@ -265,7 +268,7 @@ int main(int argc, char *argv[]) {
/* If we are in a container, just exit, this will kill our
* container for good. */
- if (in_container) {
+ if (!need_reboot) {
log_error("Exiting container.");
exit(0);
}
--
1.7.10.4
More information about the systemd-devel
mailing list