diff options
author | Waiman Long <longman@redhat.com> | 2023-01-31 18:48:03 +0300 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2023-02-01 01:14:02 +0300 |
commit | e5ae8803847b80fe9d744a3174abe2b7bfed222a (patch) | |
tree | d5bdf23c5bba0d92306483780f75f0f2eb2d153b /tools/perf/scripts/python/exported-sql-viewer.py | |
parent | 58706f7fb045b7019bada81fa17f372189315fe5 (diff) | |
download | linux-e5ae8803847b80fe9d744a3174abe2b7bfed222a.tar.xz |
cgroup/cpuset: Fix wrong check in update_parent_subparts_cpumask()
It was found that the check to see if a partition could use up all
the cpus from the parent cpuset in update_parent_subparts_cpumask()
was incorrect. As a result, it is possible to leave parent with no
effective cpu left even if there are tasks in the parent cpuset. This
can lead to system panic as reported in [1].
Fix this probem by updating the check to fail the enabling the partition
if parent's effective_cpus is a subset of the child's cpus_allowed.
Also record the error code when an error happens in update_prstate()
and add a test case where parent partition and child have the same cpu
list and parent has task. Enabling partition in the child will fail in
this case.
[1] https://www.spinics.net/lists/cgroups/msg36254.html
Fixes: f0af1bfc27b5 ("cgroup/cpuset: Relax constraints to partition & cpus changes")
Cc: stable@vger.kernel.org # v6.1
Reported-by: Srinivas Pandruvada <srinivas.pandruvada@intel.com>
Signed-off-by: Waiman Long <longman@redhat.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/exported-sql-viewer.py')
0 files changed, 0 insertions, 0 deletions