Sukadev Bhattiprolu wrote:
> Oren Laadan [[email protected]] wrote:
> | From ee2f3b5c8548136229cc2f41c5271b0a81ab8a4d Mon Sep 17 00:00:00 2001
> | From: Oren Laadan <[email protected]>
> | Date: Mon, 30 Mar 2009 15:06:13 -0400
> | Subject: [PATCH 14/29] Checkpoint multiple processes

[...]

> | +/* count number of tasks in tree (and optionally fill pid's in array) */
> | +static int cr_tree_count_tasks(struct cr_ctx *ctx)
> | +{
> | +   struct task_struct *root = ctx->root_task;
> | +   struct task_struct *task = root;
> | +   struct task_struct *parent = NULL;
> | +   struct task_struct **tasks_arr = ctx->tasks_arr;
> | +   int tasks_nr = ctx->tasks_nr;
> | +   int nr = 0;
> | +
> | +   read_lock(&tasklist_lock);
> | +
> | +   /* count tasks via DFS scan of the tree */
> | +   while (1) {
> | +           if (tasks_arr) {
> | +                   /* unlikely... but if so then try again later */
> | +                   if (nr == tasks_nr) {
> | +                           nr = -EAGAIN;   /* cleanup in cr_ctx_free() */
> | +                           break;
> | +                   }
> | +                   tasks_arr[nr] = task;
> | +                   get_task_struct(task);
> 
> Can we do an early cr_may_checkpoint_task() here ?

Sure, moved the test to here.

Oren.

> 
> Sukadev
> 

_______________________________________________
Containers mailing list
[email protected]
https://lists.linux-foundation.org/mailman/listinfo/containers

_______________________________________________
Devel mailing list
[email protected]
https://openvz.org/mailman/listinfo/devel

Reply via email to