Commit 58b74842 authored by Waiman Long's avatar Waiman Long Committed by Tejun Heo

cpuset: Define data structures to support scheduling partition

>From a cpuset point of view, a scheduling partition is a group of
cpusets with their own set of exclusive CPUs that are not shared by
other tasks outside the scheduling partition.

In the legacy hierarchy, scheduling partitions are supported indirectly
via the right use of the load balancing and the exclusive CPUs flag
which is not intuitive and can be hard to use.

To fully support the concept of scheduling partitions in the default
hierarchy, we need to add some new field into the cpuset structure as
well as a new tmpmasks structure that is used to pre-allocate cpumasks
at the top level cpuset functions to avoid memory allocation in inner
functions as memory allocation failure in those inner functions may
cause a cpuset to have inconsistent states.
Signed-off-by: default avatarWaiman Long <longman@redhat.com>
Acked-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent 4ec22e9c
...@@ -109,6 +109,13 @@ struct cpuset { ...@@ -109,6 +109,13 @@ struct cpuset {
cpumask_var_t effective_cpus; cpumask_var_t effective_cpus;
nodemask_t effective_mems; nodemask_t effective_mems;
/*
* CPUs allocated to child sub-partitions (default hierarchy only)
* - CPUs granted by the parent = effective_cpus U subparts_cpus
* - effective_cpus and subparts_cpus are mutually exclusive.
*/
cpumask_var_t subparts_cpus;
/* /*
* This is old Memory Nodes tasks took on. * This is old Memory Nodes tasks took on.
* *
...@@ -134,6 +141,30 @@ struct cpuset { ...@@ -134,6 +141,30 @@ struct cpuset {
/* for custom sched domain */ /* for custom sched domain */
int relax_domain_level; int relax_domain_level;
/* number of CPUs in subparts_cpus */
int nr_subparts_cpus;
/* partition root state */
int partition_root_state;
};
/*
* Partition root states:
*
* 0 - not a partition root
* 1 - partition root
*/
#define PRS_DISABLED 0
#define PRS_ENABLED 1
/*
* Temporary cpumasks for working with partitions that are passed among
* functions to avoid memory allocation in inner functions.
*/
struct tmpmasks {
cpumask_var_t addmask, delmask; /* For partition root */
cpumask_var_t new_cpus; /* For update_cpumasks_hier() */
}; };
static inline struct cpuset *css_cs(struct cgroup_subsys_state *css) static inline struct cpuset *css_cs(struct cgroup_subsys_state *css)
...@@ -218,9 +249,15 @@ static inline int is_spread_slab(const struct cpuset *cs) ...@@ -218,9 +249,15 @@ static inline int is_spread_slab(const struct cpuset *cs)
return test_bit(CS_SPREAD_SLAB, &cs->flags); return test_bit(CS_SPREAD_SLAB, &cs->flags);
} }
static inline int is_partition_root(const struct cpuset *cs)
{
return cs->partition_root_state;
}
static struct cpuset top_cpuset = { static struct cpuset top_cpuset = {
.flags = ((1 << CS_ONLINE) | (1 << CS_CPU_EXCLUSIVE) | .flags = ((1 << CS_ONLINE) | (1 << CS_CPU_EXCLUSIVE) |
(1 << CS_MEM_EXCLUSIVE)), (1 << CS_MEM_EXCLUSIVE)),
.partition_root_state = PRS_ENABLED,
}; };
/** /**
......
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