[CRIU] [PATCH 07/15] crtools: put kobj-ids into separate image file
Andrey Vagin
avagin at openvz.org
Thu Jan 10 05:00:32 EST 2013
It is read together with pstree items for checking what kind of
resources should be shared. Core is too big for reading it in
this place.
Signed-off-by: Andrey Vagin <avagin at openvz.org>
---
cr-dump.c | 71 +++++++++++++++++++++++++++++++++---------------------
cr-restore.c | 2 +-
cr-show.c | 5 ++++
image.c | 1 +
include/crtools.h | 2 ++
include/image.h | 1 +
include/protobuf.h | 1 +
include/pstree.h | 2 ++
protobuf.c | 1 +
pstree.c | 14 ++++++++++-
10 files changed, 71 insertions(+), 29 deletions(-)
diff --git a/cr-dump.c b/cr-dump.c
index afe010e..36da8b1 100644
--- a/cr-dump.c
+++ b/cr-dump.c
@@ -656,7 +656,7 @@ static DECLARE_KCMP_TREE(fs_tree, KCMP_FS);
static DECLARE_KCMP_TREE(files_tree, KCMP_FILES);
static DECLARE_KCMP_TREE(sighand_tree, KCMP_SIGHAND);
-static int dump_task_kobj_ids(pid_t pid, CoreEntry *core)
+static int dump_task_kobj_ids(pid_t pid, TaskKobjIdsEntry *ids)
{
int new;
struct kid_elem elem;
@@ -666,29 +666,29 @@ static int dump_task_kobj_ids(pid_t pid, CoreEntry *core)
elem.genid = 0; /* FIXME optimize */
new = 0;
- core->ids->vm_id = kid_generate_gen(&vm_tree, &elem, &new);
- if (!core->ids->vm_id || !new) {
+ ids->vm_id = kid_generate_gen(&vm_tree, &elem, &new);
+ if (!ids->vm_id || !new) {
pr_err("Can't make VM id for %d\n", pid);
return -1;
}
new = 0;
- core->ids->fs_id = kid_generate_gen(&fs_tree, &elem, &new);
- if (!core->ids->fs_id || !new) {
+ ids->fs_id = kid_generate_gen(&fs_tree, &elem, &new);
+ if (!ids->fs_id || !new) {
pr_err("Can't make FS id for %d\n", pid);
return -1;
}
new = 0;
- core->ids->files_id = kid_generate_gen(&files_tree, &elem, &new);
- if (!core->ids->files_id || !new) {
+ ids->files_id = kid_generate_gen(&files_tree, &elem, &new);
+ if (!ids->files_id || !new) {
pr_err("Can't make FILES id for %d\n", pid);
return -1;
}
new = 0;
- core->ids->sighand_id = kid_generate_gen(&sighand_tree, &elem, &new);
- if (!core->ids->sighand_id || !new) {
+ ids->sighand_id = kid_generate_gen(&sighand_tree, &elem, &new);
+ if (!ids->sighand_id || !new) {
pr_err("Can't make IO id for %d\n", pid);
return -1;
}
@@ -697,12 +697,10 @@ static int dump_task_kobj_ids(pid_t pid, CoreEntry *core)
}
static CoreEntry *core_entry_alloc(int alloc_thread_info,
- int alloc_tc,
- int alloc_ids)
+ int alloc_tc)
{
CoreEntry *core;
TaskCoreEntry *tc;
- TaskKobjIdsEntry *ids;
core = xmalloc(sizeof(*core));
if (!core)
@@ -725,20 +723,37 @@ static CoreEntry *core_entry_alloc(int alloc_thread_info,
core->tc = tc;
}
- if (alloc_ids) {
- ids = xmalloc(sizeof(*ids));
- if (!ids)
- goto err;
- task_kobj_ids_entry__init(ids);
- core->ids = ids;
- }
-
return core;
err:
core_entry_free(core);
return NULL;
}
+static int dump_task_ids(pid_t pid, const struct cr_fdset *cr_fdset)
+{
+ int fd_ids = fdset_fd(cr_fdset, CR_FD_IDS);
+ TaskKobjIdsEntry *ids;
+ int ret;
+
+ ids = xmalloc(sizeof(*ids));
+ if (!ids)
+ return -1;
+ task_kobj_ids_entry__init(ids);
+
+ ret = dump_task_kobj_ids(pid, ids);
+ if (ret)
+ goto err_free;
+
+ ret = pb_write_one(fd_ids, ids, PB_IDS);
+ if (ret < 0)
+ goto err_free;
+
+err_free:
+ xfree(ids);
+
+ return ret;
+}
+
static int dump_task_core_all(pid_t pid, const struct proc_pid_stat *stat,
const struct parasite_dump_misc *misc, const struct parasite_ctl *ctl,
const struct cr_fdset *cr_fdset,
@@ -748,7 +763,7 @@ static int dump_task_core_all(pid_t pid, const struct proc_pid_stat *stat,
CoreEntry *core;
int ret = -1;
- core = core_entry_alloc(1, 1, 1);
+ core = core_entry_alloc(1, 1);
if (!core)
return -1;
@@ -756,10 +771,6 @@ static int dump_task_core_all(pid_t pid, const struct proc_pid_stat *stat,
pr_info("Dumping core (pid: %d)\n", pid);
pr_info("----------------------------------------\n");
- ret = dump_task_kobj_ids(pid, core);
- if (ret)
- goto err_free;
-
ret = dump_task_mm(pid, stat, misc, cr_fdset);
if (ret)
goto err_free;
@@ -1162,7 +1173,7 @@ static int dump_task_thread(struct parasite_ctl *parasite_ctl, struct pid *tid)
pr_info("Dumping core for thread (pid: %d)\n", pid);
pr_info("----------------------------------------\n");
- core = core_entry_alloc(1, 0, 0);
+ core = core_entry_alloc(1, 0);
if (!core)
goto err;
@@ -1206,7 +1217,7 @@ static int dump_one_zombie(const struct pstree_item *item,
CoreEntry *core;
int ret = -1, fd_core;
- core = core_entry_alloc(0, 1, 0);
+ core = core_entry_alloc(0, 1);
if (core == NULL)
goto err;
@@ -1436,6 +1447,12 @@ static int dump_one_task(struct pstree_item *item)
goto err_cure;
}
+ ret = dump_task_ids(pid, cr_fdset);
+ if (ret) {
+ pr_err("Dump ids (pid: %d) failed with %d\n", pid, ret);
+ goto err_cure;
+ }
+
ret = dump_task_threads(parasite_ctl, item);
if (ret) {
pr_err("Can't dump threads\n");
diff --git a/cr-restore.c b/cr-restore.c
index 417d36f..fd2fe0d 100644
--- a/cr-restore.c
+++ b/cr-restore.c
@@ -716,7 +716,7 @@ static int check_core(CoreEntry *core)
}
if (core->tc->task_state != TASK_DEAD) {
- if (!core->ids) {
+ if (!current->ids) {
pr_err("Core IDS data missed for non-zombie\n");
goto out;
}
diff --git a/cr-show.c b/cr-show.c
index 61373be..b9654d0 100644
--- a/cr-show.c
+++ b/cr-show.c
@@ -351,6 +351,11 @@ void show_core(int fd_core, struct cr_options *o)
pb_show_vertical(fd_core, PB_CORE);
}
+void show_ids(int fd_ids, struct cr_options *o)
+{
+ pb_show_vertical(fd_ids, PB_IDS);
+}
+
void show_mm(int fd_mm, struct cr_options *o)
{
pb_show_vertical(fd_mm, PB_MM);
diff --git a/image.c b/image.c
index 855388e..954c5aa 100644
--- a/image.c
+++ b/image.c
@@ -100,6 +100,7 @@ struct cr_fd_desc_tmpl fdset_template[CR_FD_MAX] = {
FD_ENTRY(INOTIFY, "inotify", show_inotify),
FD_ENTRY(INOTIFY_WD, "inotify-wd", show_inotify_wd),
FD_ENTRY(CORE, "core-%d", show_core),
+ FD_ENTRY(IDS, "ids-%d", show_ids),
FD_ENTRY(MM, "mm-%d", show_mm),
FD_ENTRY(VMAS, "vmas-%d", show_vmas),
FD_ENTRY(PIPES, "pipes", show_pipes),
diff --git a/include/crtools.h b/include/crtools.h
index 1ec1a3a..2dc30c7 100644
--- a/include/crtools.h
+++ b/include/crtools.h
@@ -26,6 +26,7 @@ enum {
CR_FD_FDINFO,
CR_FD_PAGES,
CR_FD_CORE,
+ CR_FD_IDS,
CR_FD_MM,
CR_FD_VMAS,
CR_FD_SIGACT,
@@ -140,6 +141,7 @@ void show_files(int fd_files, struct cr_options *o);
void show_pages(int fd_pages, struct cr_options *o);
void show_reg_files(int fd_reg_files, struct cr_options *o);
void show_core(int fd_core, struct cr_options *o);
+void show_ids(int fd_ids, struct cr_options *o);
void show_mm(int fd_mm, struct cr_options *o);
void show_vmas(int fd_vma, struct cr_options *o);
void show_pipes(int fd_pipes, struct cr_options *o);
diff --git a/include/image.h b/include/image.h
index cdf362d..ee75a5d 100644
--- a/include/image.h
+++ b/include/image.h
@@ -28,6 +28,7 @@
#define PAGES_MAGIC 0x56084025 /* Vladimir */
#define SHMEM_PAGES_MAGIC PAGES_MAGIC
#define CORE_MAGIC 0x55053847 /* Kolomna */
+#define IDS_MAGIC 0x54432030 /* Konigsberg */
#define VMAS_MAGIC 0x54123737 /* Tula */
#define PIPES_MAGIC 0x56513555 /* Tver */
#define PIPES_DATA_MAGIC 0x56453709 /* Dubna */
diff --git a/include/protobuf.h b/include/protobuf.h
index 4bed9f9..86d6101 100644
--- a/include/protobuf.h
+++ b/include/protobuf.h
@@ -43,6 +43,7 @@ enum {
PB_INOTIFY_WD,
PB_TTY,
PB_TTY_INFO,
+ PB_IDS,
PB_MAX
};
diff --git a/include/pstree.h b/include/pstree.h
index d13dacf..7e1a40c 100644
--- a/include/pstree.h
+++ b/include/pstree.h
@@ -3,6 +3,7 @@
#include "list.h"
#include "crtools.h"
+#include "../protobuf/core.pb-c.h"
/*
* That's the init process which usually inherit
@@ -40,6 +41,7 @@ struct pstree_item {
int nr_threads; /* number of threads */
struct pid *threads; /* array of threads */
+ TaskKobjIdsEntry *ids;
struct rst_info rst[0];
};
diff --git a/protobuf.c b/protobuf.c
index 5213d48..2598037 100644
--- a/protobuf.c
+++ b/protobuf.c
@@ -97,6 +97,7 @@ void cr_pb_init(void)
CR_PB_DESC(INOTIFY, InotifyFile, inotify_file);
CR_PB_DESC(INOTIFY_WD, InotifyWd, inotify_wd);
CR_PB_DESC(CORE, Core, core);
+ CR_PB_DESC(IDS, TaskKobjIds, task_kobj_ids);
CR_PB_DESC(MM, Mm, mm);
CR_PB_DESC(VMAS, Vma, vma);
CR_PB_DESC(PIPES, Pipe, pipe);
diff --git a/pstree.c b/pstree.c
index 3ba645e..2e2171b 100644
--- a/pstree.c
+++ b/pstree.c
@@ -177,7 +177,7 @@ static int prepare_pstree_for_shell_job(void)
static int read_pstree_image(void)
{
- int ret = 0, i, ps_fd;
+ int ret = 0, i, ps_fd, fd;
struct pstree_item *pi, *parent = NULL;
pr_info("Reading image tree\n");
@@ -260,6 +260,18 @@ static int read_pstree_image(void)
task_entries->nr_tasks++;
pstree_entry__free_unpacked(e, NULL);
+
+ fd = open_image_ro(CR_FD_IDS, pi->pid.virt);
+ if (fd < 0) {
+ if (errno == ENOENT)
+ continue;
+ return -1;
+ }
+ ret = pb_read_one(fd, &pi->ids, PB_IDS);
+ close(fd);
+ if (ret != 1)
+ goto err;
+
}
err:
close(ps_fd);
--
1.7.11.7
More information about the CRIU
mailing list