sched: Fix various typos

Fix ~42 single-word typos in scheduler code comments.

We have accumulated a few fun ones over the years. :-)

Signed-off-by: Ingo Molnar <mingo@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Juri Lelli <juri.lelli@redhat.com>
Cc: Vincent Guittot <vincent.guittot@linaro.org>
Cc: Dietmar Eggemann <dietmar.eggemann@arm.com>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Ben Segall <bsegall@google.com>
Cc: Mel Gorman <mgorman@suse.de>
Cc: linux-kernel@vger.kernel.org
This commit is contained in:
Ingo Molnar 2021-03-18 13:38:50 +01:00
parent 90f093fa8e
commit 3b03706fa6
20 changed files with 42 additions and 42 deletions

View File

@ -1097,7 +1097,7 @@ struct task_struct {
#ifdef CONFIG_CPUSETS #ifdef CONFIG_CPUSETS
/* Protected by ->alloc_lock: */ /* Protected by ->alloc_lock: */
nodemask_t mems_allowed; nodemask_t mems_allowed;
/* Seqence number to catch updates: */ /* Sequence number to catch updates: */
seqcount_spinlock_t mems_allowed_seq; seqcount_spinlock_t mems_allowed_seq;
int cpuset_mem_spread_rotor; int cpuset_mem_spread_rotor;
int cpuset_slab_spread_rotor; int cpuset_slab_spread_rotor;

View File

@ -41,7 +41,7 @@
* Otherwise it tries to create a semi stable clock from a mixture of other * Otherwise it tries to create a semi stable clock from a mixture of other
* clocks, including: * clocks, including:
* *
* - GTOD (clock monotomic) * - GTOD (clock monotonic)
* - sched_clock() * - sched_clock()
* - explicit idle events * - explicit idle events
* *

View File

@ -8975,7 +8975,7 @@ static int tg_set_cfs_bandwidth(struct task_group *tg, u64 period, u64 quota)
return -EINVAL; return -EINVAL;
/* /*
* Likewise, bound things on the otherside by preventing insane quota * Likewise, bound things on the other side by preventing insane quota
* periods. This also allows us to normalize in computing quota * periods. This also allows us to normalize in computing quota
* feasibility. * feasibility.
*/ */

View File

@ -104,7 +104,7 @@ static u64 cpuacct_cpuusage_read(struct cpuacct *ca, int cpu,
/* /*
* We allow index == CPUACCT_STAT_NSTATS here to read * We allow index == CPUACCT_STAT_NSTATS here to read
* the sum of suages. * the sum of usages.
*/ */
BUG_ON(index > CPUACCT_STAT_NSTATS); BUG_ON(index > CPUACCT_STAT_NSTATS);

View File

@ -471,7 +471,7 @@ static void sugov_work(struct kthread_work *work)
/* /*
* Hold sg_policy->update_lock shortly to handle the case where: * Hold sg_policy->update_lock shortly to handle the case where:
* incase sg_policy->next_freq is read here, and then updated by * in case sg_policy->next_freq is read here, and then updated by
* sugov_deferred_update() just before work_in_progress is set to false * sugov_deferred_update() just before work_in_progress is set to false
* here, we may miss queueing the new update. * here, we may miss queueing the new update.
* *

View File

@ -77,7 +77,7 @@ static inline int __cpupri_find(struct cpupri *cp, struct task_struct *p,
* When looking at the vector, we need to read the counter, * When looking at the vector, we need to read the counter,
* do a memory barrier, then read the mask. * do a memory barrier, then read the mask.
* *
* Note: This is still all racey, but we can deal with it. * Note: This is still all racy, but we can deal with it.
* Ideally, we only want to look at masks that are set. * Ideally, we only want to look at masks that are set.
* *
* If a mask is not set, then the only thing wrong is that we * If a mask is not set, then the only thing wrong is that we
@ -186,7 +186,7 @@ int cpupri_find_fitness(struct cpupri *cp, struct task_struct *p,
* The cost of this trade-off is not entirely clear and will probably * The cost of this trade-off is not entirely clear and will probably
* be good for some workloads and bad for others. * be good for some workloads and bad for others.
* *
* The main idea here is that if some CPUs were overcommitted, we try * The main idea here is that if some CPUs were over-committed, we try
* to spread which is what the scheduler traditionally did. Sys admins * to spread which is what the scheduler traditionally did. Sys admins
* must do proper RT planning to avoid overloading the system if they * must do proper RT planning to avoid overloading the system if they
* really care. * really care.

View File

@ -563,7 +563,7 @@ void cputime_adjust(struct task_cputime *curr, struct prev_cputime *prev,
/* /*
* If either stime or utime are 0, assume all runtime is userspace. * If either stime or utime are 0, assume all runtime is userspace.
* Once a task gets some ticks, the monotonicy code at 'update:' * Once a task gets some ticks, the monotonicity code at 'update:'
* will ensure things converge to the observed ratio. * will ensure things converge to the observed ratio.
*/ */
if (stime == 0) { if (stime == 0) {

View File

@ -245,7 +245,7 @@ static void dl_change_utilization(struct task_struct *p, u64 new_bw)
p->dl.dl_non_contending = 0; p->dl.dl_non_contending = 0;
/* /*
* If the timer handler is currently running and the * If the timer handler is currently running and the
* timer cannot be cancelled, inactive_task_timer() * timer cannot be canceled, inactive_task_timer()
* will see that dl_not_contending is not set, and * will see that dl_not_contending is not set, and
* will not touch the rq's active utilization, * will not touch the rq's active utilization,
* so we are still safe. * so we are still safe.
@ -267,7 +267,7 @@ static void dl_change_utilization(struct task_struct *p, u64 new_bw)
* fires. * fires.
* *
* If the task wakes up again before the inactive timer fires, * If the task wakes up again before the inactive timer fires,
* the timer is cancelled, whereas if the task wakes up after the * the timer is canceled, whereas if the task wakes up after the
* inactive timer fired (and running_bw has been decreased) the * inactive timer fired (and running_bw has been decreased) the
* task's utilization has to be added to running_bw again. * task's utilization has to be added to running_bw again.
* A flag in the deadline scheduling entity (dl_non_contending) * A flag in the deadline scheduling entity (dl_non_contending)
@ -385,7 +385,7 @@ static void task_contending(struct sched_dl_entity *dl_se, int flags)
dl_se->dl_non_contending = 0; dl_se->dl_non_contending = 0;
/* /*
* If the timer handler is currently running and the * If the timer handler is currently running and the
* timer cannot be cancelled, inactive_task_timer() * timer cannot be canceled, inactive_task_timer()
* will see that dl_not_contending is not set, and * will see that dl_not_contending is not set, and
* will not touch the rq's active utilization, * will not touch the rq's active utilization,
* so we are still safe. * so we are still safe.
@ -1206,7 +1206,7 @@ extern bool sched_rt_bandwidth_account(struct rt_rq *rt_rq);
* Since rq->dl.running_bw and rq->dl.this_bw contain utilizations * Since rq->dl.running_bw and rq->dl.this_bw contain utilizations
* multiplied by 2^BW_SHIFT, the result has to be shifted right by * multiplied by 2^BW_SHIFT, the result has to be shifted right by
* BW_SHIFT. * BW_SHIFT.
* Since rq->dl.bw_ratio contains 1 / Umax multipled by 2^RATIO_SHIFT, * Since rq->dl.bw_ratio contains 1 / Umax multiplied by 2^RATIO_SHIFT,
* dl_bw is multiped by rq->dl.bw_ratio and shifted right by RATIO_SHIFT. * dl_bw is multiped by rq->dl.bw_ratio and shifted right by RATIO_SHIFT.
* Since delta is a 64 bit variable, to have an overflow its value * Since delta is a 64 bit variable, to have an overflow its value
* should be larger than 2^(64 - 20 - 8), which is more than 64 seconds. * should be larger than 2^(64 - 20 - 8), which is more than 64 seconds.
@ -1737,7 +1737,7 @@ static void migrate_task_rq_dl(struct task_struct *p, int new_cpu __maybe_unused
p->dl.dl_non_contending = 0; p->dl.dl_non_contending = 0;
/* /*
* If the timer handler is currently running and the * If the timer handler is currently running and the
* timer cannot be cancelled, inactive_task_timer() * timer cannot be canceled, inactive_task_timer()
* will see that dl_not_contending is not set, and * will see that dl_not_contending is not set, and
* will not touch the rq's active utilization, * will not touch the rq's active utilization,
* so we are still safe. * so we are still safe.
@ -2745,7 +2745,7 @@ void __getparam_dl(struct task_struct *p, struct sched_attr *attr)
/* /*
* Default limits for DL period; on the top end we guard against small util * Default limits for DL period; on the top end we guard against small util
* tasks still getting rediculous long effective runtimes, on the bottom end we * tasks still getting ridiculously long effective runtimes, on the bottom end we
* guard against timer DoS. * guard against timer DoS.
*/ */
unsigned int sysctl_sched_dl_period_max = 1 << 22; /* ~4 seconds */ unsigned int sysctl_sched_dl_period_max = 1 << 22; /* ~4 seconds */

View File

@ -815,7 +815,7 @@ void sysrq_sched_debug_show(void)
} }
/* /*
* This itererator needs some explanation. * This iterator needs some explanation.
* It returns 1 for the header position. * It returns 1 for the header position.
* This means 2 is CPU 0. * This means 2 is CPU 0.
* In a hotplugged system some CPUs, including CPU 0, may be missing so we have * In a hotplugged system some CPUs, including CPU 0, may be missing so we have

View File

@ -1125,7 +1125,7 @@ static unsigned int task_nr_scan_windows(struct task_struct *p)
return rss / nr_scan_pages; return rss / nr_scan_pages;
} }
/* For sanitys sake, never scan more PTEs than MAX_SCAN_WINDOW MB/sec. */ /* For sanity's sake, never scan more PTEs than MAX_SCAN_WINDOW MB/sec. */
#define MAX_SCAN_WINDOW 2560 #define MAX_SCAN_WINDOW 2560
static unsigned int task_scan_min(struct task_struct *p) static unsigned int task_scan_min(struct task_struct *p)
@ -2577,7 +2577,7 @@ static void task_numa_group(struct task_struct *p, int cpupid, int flags,
} }
/* /*
* Get rid of NUMA staticstics associated with a task (either current or dead). * Get rid of NUMA statistics associated with a task (either current or dead).
* If @final is set, the task is dead and has reached refcount zero, so we can * If @final is set, the task is dead and has reached refcount zero, so we can
* safely free all relevant data structures. Otherwise, there might be * safely free all relevant data structures. Otherwise, there might be
* concurrent reads from places like load balancing and procfs, and we should * concurrent reads from places like load balancing and procfs, and we should
@ -3952,7 +3952,7 @@ static inline void util_est_dequeue(struct cfs_rq *cfs_rq,
* *
* abs(x) < y := (unsigned)(x + y - 1) < (2 * y - 1) * abs(x) < y := (unsigned)(x + y - 1) < (2 * y - 1)
* *
* NOTE: this only works when value + maring < INT_MAX. * NOTE: this only works when value + margin < INT_MAX.
*/ */
static inline bool within_margin(int value, int margin) static inline bool within_margin(int value, int margin)
{ {
@ -4256,7 +4256,7 @@ enqueue_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int flags)
/* /*
* When bandwidth control is enabled, cfs might have been removed * When bandwidth control is enabled, cfs might have been removed
* because of a parent been throttled but cfs->nr_running > 1. Try to * because of a parent been throttled but cfs->nr_running > 1. Try to
* add it unconditionnally. * add it unconditionally.
*/ */
if (cfs_rq->nr_running == 1 || cfs_bandwidth_used()) if (cfs_rq->nr_running == 1 || cfs_bandwidth_used())
list_add_leaf_cfs_rq(cfs_rq); list_add_leaf_cfs_rq(cfs_rq);
@ -5311,7 +5311,7 @@ static void destroy_cfs_bandwidth(struct cfs_bandwidth *cfs_b)
* bits doesn't do much. * bits doesn't do much.
*/ */
/* cpu online calback */ /* cpu online callback */
static void __maybe_unused update_runtime_enabled(struct rq *rq) static void __maybe_unused update_runtime_enabled(struct rq *rq)
{ {
struct task_group *tg; struct task_group *tg;
@ -6963,7 +6963,7 @@ static void check_preempt_wakeup(struct rq *rq, struct task_struct *p, int wake_
/* /*
* This is possible from callers such as attach_tasks(), in which we * This is possible from callers such as attach_tasks(), in which we
* unconditionally check_prempt_curr() after an enqueue (which may have * unconditionally check_preempt_curr() after an enqueue (which may have
* lead to a throttle). This both saves work and prevents false * lead to a throttle). This both saves work and prevents false
* next-buddy nomination below. * next-buddy nomination below.
*/ */
@ -7595,7 +7595,7 @@ int can_migrate_task(struct task_struct *p, struct lb_env *env)
return 0; return 0;
} }
/* Record that we found atleast one task that could run on dst_cpu */ /* Record that we found at least one task that could run on dst_cpu */
env->flags &= ~LBF_ALL_PINNED; env->flags &= ~LBF_ALL_PINNED;
if (task_running(env->src_rq, p)) { if (task_running(env->src_rq, p)) {
@ -9690,7 +9690,7 @@ static int load_balance(int this_cpu, struct rq *this_rq,
* load to given_cpu. In rare situations, this may cause * load to given_cpu. In rare situations, this may cause
* conflicts (balance_cpu and given_cpu/ilb_cpu deciding * conflicts (balance_cpu and given_cpu/ilb_cpu deciding
* _independently_ and at _same_ time to move some load to * _independently_ and at _same_ time to move some load to
* given_cpu) causing exceess load to be moved to given_cpu. * given_cpu) causing excess load to be moved to given_cpu.
* This however should not happen so much in practice and * This however should not happen so much in practice and
* moreover subsequent load balance cycles should correct the * moreover subsequent load balance cycles should correct the
* excess load moved. * excess load moved.
@ -9834,7 +9834,7 @@ static int load_balance(int this_cpu, struct rq *this_rq,
/* /*
* newidle_balance() disregards balance intervals, so we could * newidle_balance() disregards balance intervals, so we could
* repeatedly reach this code, which would lead to balance_interval * repeatedly reach this code, which would lead to balance_interval
* skyrocketting in a short amount of time. Skip the balance_interval * skyrocketing in a short amount of time. Skip the balance_interval
* increase logic to avoid that. * increase logic to avoid that.
*/ */
if (env.idle == CPU_NEWLY_IDLE) if (env.idle == CPU_NEWLY_IDLE)

View File

@ -27,7 +27,7 @@ SCHED_FEAT(NEXT_BUDDY, false)
SCHED_FEAT(LAST_BUDDY, true) SCHED_FEAT(LAST_BUDDY, true)
/* /*
* Consider buddies to be cache hot, decreases the likelyness of a * Consider buddies to be cache hot, decreases the likeliness of a
* cache buddy being migrated away, increases cache locality. * cache buddy being migrated away, increases cache locality.
*/ */
SCHED_FEAT(CACHE_HOT_BUDDY, true) SCHED_FEAT(CACHE_HOT_BUDDY, true)

View File

@ -163,7 +163,7 @@ static int call_cpuidle(struct cpuidle_driver *drv, struct cpuidle_device *dev,
* *
* NOTE: no locks or semaphores should be used here * NOTE: no locks or semaphores should be used here
* *
* On archs that support TIF_POLLING_NRFLAG, is called with polling * On architectures that support TIF_POLLING_NRFLAG, is called with polling
* set, and it returns with polling set. If it ever stops polling, it * set, and it returns with polling set. If it ever stops polling, it
* must clear the polling bit. * must clear the polling bit.
*/ */
@ -199,7 +199,7 @@ static void cpuidle_idle_call(void)
* Suspend-to-idle ("s2idle") is a system state in which all user space * Suspend-to-idle ("s2idle") is a system state in which all user space
* has been frozen, all I/O devices have been suspended and the only * has been frozen, all I/O devices have been suspended and the only
* activity happens here and in interrupts (if any). In that case bypass * activity happens here and in interrupts (if any). In that case bypass
* the cpuidle governor and go stratight for the deepest idle state * the cpuidle governor and go straight for the deepest idle state
* available. Possibly also suspend the local tick and the entire * available. Possibly also suspend the local tick and the entire
* timekeeping to prevent timer interrupts from kicking us out of idle * timekeeping to prevent timer interrupts from kicking us out of idle
* until a proper wakeup interrupt happens. * until a proper wakeup interrupt happens.

View File

@ -189,7 +189,7 @@ calc_load_n(unsigned long load, unsigned long exp,
* w:0 1 1 0 0 1 1 0 0 * w:0 1 1 0 0 1 1 0 0
* *
* This ensures we'll fold the old NO_HZ contribution in this window while * This ensures we'll fold the old NO_HZ contribution in this window while
* accumlating the new one. * accumulating the new one.
* *
* - When we wake up from NO_HZ during the window, we push up our * - When we wake up from NO_HZ during the window, we push up our
* contribution, since we effectively move our sample point to a known * contribution, since we effectively move our sample point to a known

View File

@ -133,7 +133,7 @@ accumulate_sum(u64 delta, struct sched_avg *sa,
* runnable = running = 0; * runnable = running = 0;
* *
* clause from ___update_load_sum(); this results in * clause from ___update_load_sum(); this results in
* the below usage of @contrib to dissapear entirely, * the below usage of @contrib to disappear entirely,
* so no point in calculating it. * so no point in calculating it.
*/ */
contrib = __accumulate_pelt_segments(periods, contrib = __accumulate_pelt_segments(periods,

View File

@ -130,7 +130,7 @@ static inline void update_idle_rq_clock_pelt(struct rq *rq)
* Reflecting stolen time makes sense only if the idle * Reflecting stolen time makes sense only if the idle
* phase would be present at max capacity. As soon as the * phase would be present at max capacity. As soon as the
* utilization of a rq has reached the maximum value, it is * utilization of a rq has reached the maximum value, it is
* considered as an always runnig rq without idle time to * considered as an always running rq without idle time to
* steal. This potential idle time is considered as lost in * steal. This potential idle time is considered as lost in
* this case. We keep track of this lost idle time compare to * this case. We keep track of this lost idle time compare to
* rq's clock_task. * rq's clock_task.

View File

@ -62,7 +62,7 @@
* states, we would have to conclude a CPU SOME pressure number of * states, we would have to conclude a CPU SOME pressure number of
* 100%, since *somebody* is waiting on a runqueue at all * 100%, since *somebody* is waiting on a runqueue at all
* times. However, that is clearly not the amount of contention the * times. However, that is clearly not the amount of contention the
* workload is experiencing: only one out of 256 possible exceution * workload is experiencing: only one out of 256 possible execution
* threads will be contended at any given time, or about 0.4%. * threads will be contended at any given time, or about 0.4%.
* *
* Conversely, consider a scenario of 4 tasks and 4 CPUs where at any * Conversely, consider a scenario of 4 tasks and 4 CPUs where at any
@ -76,7 +76,7 @@
* we have to base our calculation on the number of non-idle tasks in * we have to base our calculation on the number of non-idle tasks in
* conjunction with the number of available CPUs, which is the number * conjunction with the number of available CPUs, which is the number
* of potential execution threads. SOME becomes then the proportion of * of potential execution threads. SOME becomes then the proportion of
* delayed tasks to possibe threads, and FULL is the share of possible * delayed tasks to possible threads, and FULL is the share of possible
* threads that are unproductive due to delays: * threads that are unproductive due to delays:
* *
* threads = min(nr_nonidle_tasks, nr_cpus) * threads = min(nr_nonidle_tasks, nr_cpus)
@ -446,7 +446,7 @@ static void psi_avgs_work(struct work_struct *work)
mutex_unlock(&group->avgs_lock); mutex_unlock(&group->avgs_lock);
} }
/* Trigger tracking window manupulations */ /* Trigger tracking window manipulations */
static void window_reset(struct psi_window *win, u64 now, u64 value, static void window_reset(struct psi_window *win, u64 now, u64 value,
u64 prev_growth) u64 prev_growth)
{ {

View File

@ -700,7 +700,7 @@ static void do_balance_runtime(struct rt_rq *rt_rq)
/* /*
* Either all rqs have inf runtime and there's nothing to steal * Either all rqs have inf runtime and there's nothing to steal
* or __disable_runtime() below sets a specific rq to inf to * or __disable_runtime() below sets a specific rq to inf to
* indicate its been disabled and disalow stealing. * indicate its been disabled and disallow stealing.
*/ */
if (iter->rt_runtime == RUNTIME_INF) if (iter->rt_runtime == RUNTIME_INF)
goto next; goto next;
@ -1998,7 +1998,7 @@ static void push_rt_tasks(struct rq *rq)
* *
* Each root domain has its own irq work function that can iterate over * Each root domain has its own irq work function that can iterate over
* all CPUs with RT overloaded tasks. Since all CPUs with overloaded RT * all CPUs with RT overloaded tasks. Since all CPUs with overloaded RT
* tassk must be checked if there's one or many CPUs that are lowering * task must be checked if there's one or many CPUs that are lowering
* their priority, there's a single irq work iterator that will try to * their priority, there's a single irq work iterator that will try to
* push off RT tasks that are waiting to run. * push off RT tasks that are waiting to run.
* *
@ -2216,7 +2216,7 @@ static void pull_rt_task(struct rq *this_rq)
/* /*
* There's a chance that p is higher in priority * There's a chance that p is higher in priority
* than what's currently running on its CPU. * than what's currently running on its CPU.
* This is just that p is wakeing up and hasn't * This is just that p is waking up and hasn't
* had a chance to schedule. We only pull * had a chance to schedule. We only pull
* p if it is lower in priority than the * p if it is lower in priority than the
* current task on the run queue * current task on the run queue

View File

@ -1155,7 +1155,7 @@ static inline u64 __rq_clock_broken(struct rq *rq)
* *
* if (rq-clock_update_flags >= RQCF_UPDATED) * if (rq-clock_update_flags >= RQCF_UPDATED)
* *
* to check if %RQCF_UPADTED is set. It'll never be shifted more than * to check if %RQCF_UPDATED is set. It'll never be shifted more than
* one position though, because the next rq_unpin_lock() will shift it * one position though, because the next rq_unpin_lock() will shift it
* back. * back.
*/ */
@ -1214,7 +1214,7 @@ static inline void rq_clock_skip_update(struct rq *rq)
/* /*
* See rt task throttling, which is the only time a skip * See rt task throttling, which is the only time a skip
* request is cancelled. * request is canceled.
*/ */
static inline void rq_clock_cancel_skipupdate(struct rq *rq) static inline void rq_clock_cancel_skipupdate(struct rq *rq)
{ {
@ -1861,7 +1861,7 @@ struct sched_class {
/* /*
* The switched_from() call is allowed to drop rq->lock, therefore we * The switched_from() call is allowed to drop rq->lock, therefore we
* cannot assume the switched_from/switched_to pair is serliazed by * cannot assume the switched_from/switched_to pair is serialized by
* rq->lock. They are however serialized by p->pi_lock. * rq->lock. They are however serialized by p->pi_lock.
*/ */
void (*switched_from)(struct rq *this_rq, struct task_struct *task); void (*switched_from)(struct rq *this_rq, struct task_struct *task);
@ -2452,7 +2452,7 @@ DECLARE_PER_CPU(struct irqtime, cpu_irqtime);
/* /*
* Returns the irqtime minus the softirq time computed by ksoftirqd. * Returns the irqtime minus the softirq time computed by ksoftirqd.
* Otherwise ksoftirqd's sum_exec_runtime is substracted its own runtime * Otherwise ksoftirqd's sum_exec_runtime is subtracted its own runtime
* and never move forward. * and never move forward.
*/ */
static inline u64 irq_time_read(int cpu) static inline u64 irq_time_read(int cpu)

View File

@ -74,7 +74,7 @@ static int show_schedstat(struct seq_file *seq, void *v)
} }
/* /*
* This itererator needs some explanation. * This iterator needs some explanation.
* It returns 1 for the header position. * It returns 1 for the header position.
* This means 2 is cpu 0. * This means 2 is cpu 0.
* In a hotplugged system some CPUs, including cpu 0, may be missing so we have * In a hotplugged system some CPUs, including cpu 0, may be missing so we have

View File

@ -2159,7 +2159,7 @@ static cpumask_var_t *doms_cur;
/* Number of sched domains in 'doms_cur': */ /* Number of sched domains in 'doms_cur': */
static int ndoms_cur; static int ndoms_cur;
/* Attribues of custom domains in 'doms_cur' */ /* Attributes of custom domains in 'doms_cur' */
static struct sched_domain_attr *dattr_cur; static struct sched_domain_attr *dattr_cur;
/* /*