Commit 742e8cd3 authored by Honglei Wang's avatar Honglei Wang Committed by Tejun Heo

cgroup: freezer: don't change task and cgroups status unnecessarily

It's not necessary to adjust the task state and revisit the state
of source and destination cgroups if the cgroups are not in freeze
state and the task itself is not frozen.

And in this scenario, it wakes up the task who's not supposed to be
ready to run.

Don't do the unnecessary task state adjustment can help stop waking
up the task without a reason.
Signed-off-by: default avatarHonglei Wang <honglei.wang@oracle.com>
Acked-by: default avatarRoman Gushchin <guro@fb.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent 1bb5ec2e
...@@ -230,6 +230,15 @@ void cgroup_freezer_migrate_task(struct task_struct *task, ...@@ -230,6 +230,15 @@ void cgroup_freezer_migrate_task(struct task_struct *task,
if (task->flags & PF_KTHREAD) if (task->flags & PF_KTHREAD)
return; return;
/*
* It's not necessary to do changes if both of the src and dst cgroups
* are not freezing and task is not frozen.
*/
if (!test_bit(CGRP_FREEZE, &src->flags) &&
!test_bit(CGRP_FREEZE, &dst->flags) &&
!task->frozen)
return;
/* /*
* Adjust counters of freezing and frozen tasks. * Adjust counters of freezing and frozen tasks.
* Note, that if the task is frozen, but the destination cgroup is not * Note, that if the task is frozen, but the destination cgroup is not
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment