[CRIU] lazy: BUG at criu/pstree.c:499
Mike Rapoport
rppt at linux.vnet.ibm.com
Tue Jan 10 08:47:48 PST 2017
Hello Adrian,
On Tue, Jan 10, 2017 at 02:24:32PM +0100, Adrian Reber wrote:
> Hello Mike,
>
> trying to dump a process with --lazy-pages leads to:
>
> $ criu dump -t 14227 -D /tmp/1 --port 27 --lazy-pages -j
> Error (criu/pstree.c:499): BUG at criu/pstree.c:499
> Aborted
>
> Should that currently work?
Can you please check if the patch below works for you?
> Adrian
>
>From 718527c5986d9bda0008bc2d195d5185b987367c Mon Sep 17 00:00:00 2001
From: Mike Rapoport <rppt at linux.vnet.ibm.com>
Date: Tue, 10 Jan 2017 18:44:22 +0200
Subject: [CRIU][PATCH] lazy-pages: fix lazy dump
The introduction of page-server send mode have broken the lazy dump because
instead of using existing pstree, the page server now tries to recreate the
pstree from the images.
Adding lazy_dump parameter to cr_page_server resolves this issue.
Signed-off-by: Mike Rapoport <rppt at linux.vnet.ibm.com>
---
criu/cr-dump.c | 2 +-
criu/cr-service.c | 2 +-
criu/crtools.c | 2 +-
criu/include/page-xfer.h | 2 +-
criu/page-xfer.c | 7 +++----
5 files changed, 7 insertions(+), 8 deletions(-)
diff --git a/criu/cr-dump.c b/criu/cr-dump.c
index b6a9c9b..555814b 100644
--- a/criu/cr-dump.c
+++ b/criu/cr-dump.c
@@ -1576,7 +1576,7 @@ static int cr_lazy_mem_dump(void)
int ret = 0;
pr_info("Starting lazy pages server\n");
- ret = cr_page_server(false, -1);
+ ret = cr_page_server(false, true, -1);
for_each_pstree_item(item) {
destroy_page_pipe(dmpi(item)->mem_pp);
diff --git a/criu/cr-service.c b/criu/cr-service.c
index 00a2d07..fbd1065 100644
--- a/criu/cr-service.c
+++ b/criu/cr-service.c
@@ -704,7 +704,7 @@ static int start_page_server_req(int sk, CriuOpts *req)
pr_debug("Starting page server\n");
- pid = cr_page_server(true, start_pipe[1]);
+ pid = cr_page_server(true, false, start_pipe[1]);
if (pid <= 0)
goto out_ch;
diff --git a/criu/crtools.c b/criu/crtools.c
index 06b2fa7..f6e0263 100644
--- a/criu/crtools.c
+++ b/criu/crtools.c
@@ -772,7 +772,7 @@ int main(int argc, char *argv[], char *envp[])
#endif
if (!strcmp(argv[optind], "page-server"))
- return cr_page_server(opts.daemon_mode, -1) > 0 ? 0 : 1;
+ return cr_page_server(opts.daemon_mode, false -1) > 0 ? 0 : 1;
if (!strcmp(argv[optind], "service"))
return cr_service(opts.daemon_mode);
diff --git a/criu/include/page-xfer.h b/criu/include/page-xfer.h
index dfe43e5..1f59bdb 100644
--- a/criu/include/page-xfer.h
+++ b/criu/include/page-xfer.h
@@ -2,7 +2,7 @@
#define __CR_PAGE_XFER__H__
#include "pagemap.h"
-extern int cr_page_server(bool daemon_mode, int cfd);
+extern int cr_page_server(bool daemon_mode, bool lazy_dump, int cfd);
/*
* page_xfer -- transfer pages into image file.
diff --git a/criu/page-xfer.c b/criu/page-xfer.c
index 770cb97..7974d1d 100644
--- a/criu/page-xfer.c
+++ b/criu/page-xfer.c
@@ -906,18 +906,17 @@ static int page_server_init_send(void)
return 0;
}
-int cr_page_server(bool daemon_mode, int cfd)
+int cr_page_server(bool daemon_mode, bool lazy_dump, int cfd)
{
int ask = -1;
int sk = -1;
int ret;
- if (!opts.lazy_pages) {
+ if (!opts.lazy_pages)
up_page_ids_base();
- } else {
+ else if (lazy_dump)
if (page_server_init_send())
return -1;
- }
if (opts.ps_socket != -1) {
ret = 0;
--
1.9.1
More information about the CRIU
mailing list