cgroup: freezer: don't change task and cgroups status unnecessarily
authorHonglei Wang <honglei.wang@oracle.com>
Wed, 30 Oct 2019 08:18:10 +0000 (16:18 +0800)
committerTejun Heo <tj@kernel.org>
Thu, 7 Nov 2019 15:38:41 +0000 (07:38 -0800)
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: Honglei Wang <honglei.wang@oracle.com>
Acked-by: Roman Gushchin <guro@fb.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
kernel/cgroup/freezer.c

index 8cf010680678949cd131c9913b5cd08e521227f9..3984dd6b8ddbc3d684d5193bf3dddd50b37a1a6e 100644 (file)
@@ -230,6 +230,15 @@ void cgroup_freezer_migrate_task(struct task_struct *task,
        if (task->flags & PF_KTHREAD)
                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.
         * Note, that if the task is frozen, but the destination cgroup is not