Merge "cgroup: Iterate tasks that did not finish do_exit()"
This commit is contained in:
commit
7b895f3b55
2 changed files with 17 additions and 7 deletions
|
@ -62,6 +62,7 @@ struct css_task_iter {
|
||||||
struct list_head *mg_tasks_head;
|
struct list_head *mg_tasks_head;
|
||||||
struct list_head *dying_tasks_head;
|
struct list_head *dying_tasks_head;
|
||||||
|
|
||||||
|
struct list_head *cur_tasks_head;
|
||||||
struct css_set *cur_cset;
|
struct css_set *cur_cset;
|
||||||
struct css_set *cur_dcset;
|
struct css_set *cur_dcset;
|
||||||
struct task_struct *cur_task;
|
struct task_struct *cur_task;
|
||||||
|
|
|
@ -4242,12 +4242,16 @@ static void css_task_iter_advance_css_set(struct css_task_iter *it)
|
||||||
}
|
}
|
||||||
} while (!css_set_populated(cset) && list_empty(&cset->dying_tasks));
|
} while (!css_set_populated(cset) && list_empty(&cset->dying_tasks));
|
||||||
|
|
||||||
if (!list_empty(&cset->tasks))
|
if (!list_empty(&cset->tasks)) {
|
||||||
it->task_pos = cset->tasks.next;
|
it->task_pos = cset->tasks.next;
|
||||||
else if (!list_empty(&cset->mg_tasks))
|
it->cur_tasks_head = &cset->tasks;
|
||||||
|
} else if (!list_empty(&cset->mg_tasks)) {
|
||||||
it->task_pos = cset->mg_tasks.next;
|
it->task_pos = cset->mg_tasks.next;
|
||||||
else
|
it->cur_tasks_head = &cset->mg_tasks;
|
||||||
|
} else {
|
||||||
it->task_pos = cset->dying_tasks.next;
|
it->task_pos = cset->dying_tasks.next;
|
||||||
|
it->cur_tasks_head = &cset->dying_tasks;
|
||||||
|
}
|
||||||
|
|
||||||
it->tasks_head = &cset->tasks;
|
it->tasks_head = &cset->tasks;
|
||||||
it->mg_tasks_head = &cset->mg_tasks;
|
it->mg_tasks_head = &cset->mg_tasks;
|
||||||
|
@ -4305,10 +4309,14 @@ repeat:
|
||||||
else
|
else
|
||||||
it->task_pos = it->task_pos->next;
|
it->task_pos = it->task_pos->next;
|
||||||
|
|
||||||
if (it->task_pos == it->tasks_head)
|
if (it->task_pos == it->tasks_head) {
|
||||||
it->task_pos = it->mg_tasks_head->next;
|
it->task_pos = it->mg_tasks_head->next;
|
||||||
if (it->task_pos == it->mg_tasks_head)
|
it->cur_tasks_head = it->mg_tasks_head;
|
||||||
|
}
|
||||||
|
if (it->task_pos == it->mg_tasks_head) {
|
||||||
it->task_pos = it->dying_tasks_head->next;
|
it->task_pos = it->dying_tasks_head->next;
|
||||||
|
it->cur_tasks_head = it->dying_tasks_head;
|
||||||
|
}
|
||||||
if (it->task_pos == it->dying_tasks_head)
|
if (it->task_pos == it->dying_tasks_head)
|
||||||
css_task_iter_advance_css_set(it);
|
css_task_iter_advance_css_set(it);
|
||||||
} else {
|
} else {
|
||||||
|
@ -4327,11 +4335,12 @@ repeat:
|
||||||
goto repeat;
|
goto repeat;
|
||||||
|
|
||||||
/* and dying leaders w/o live member threads */
|
/* and dying leaders w/o live member threads */
|
||||||
if (!atomic_read(&task->signal->live))
|
if (it->cur_tasks_head == it->dying_tasks_head &&
|
||||||
|
!atomic_read(&task->signal->live))
|
||||||
goto repeat;
|
goto repeat;
|
||||||
} else {
|
} else {
|
||||||
/* skip all dying ones */
|
/* skip all dying ones */
|
||||||
if (task->flags & PF_EXITING)
|
if (it->cur_tasks_head == it->dying_tasks_head)
|
||||||
goto repeat;
|
goto repeat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue