diff options
Diffstat (limited to 'kernel/sched/sched.h')
| -rw-r--r-- | kernel/sched/sched.h | 202 | 
1 files changed, 111 insertions, 91 deletions
| diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index 9683f458aec7..618577fc9aa8 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h @@ -54,9 +54,9 @@  #include <linux/proc_fs.h>  #include <linux/prefetch.h>  #include <linux/profile.h> +#include <linux/psi.h>  #include <linux/rcupdate_wait.h>  #include <linux/security.h> -#include <linux/stackprotector.h>  #include <linux/stop_machine.h>  #include <linux/suspend.h>  #include <linux/swait.h> @@ -320,6 +320,7 @@ extern bool dl_cpu_busy(unsigned int cpu);  #ifdef CONFIG_CGROUP_SCHED  #include <linux/cgroup.h> +#include <linux/psi.h>  struct cfs_rq;  struct rt_rq; @@ -717,8 +718,12 @@ struct root_domain {  	cpumask_var_t		span;  	cpumask_var_t		online; -	/* Indicate more than one runnable task for any CPU */ -	bool			overload; +	/* +	 * Indicate pullable load on at least one CPU, e.g: +	 * - More than one runnable task +	 * - Running task is misfit +	 */ +	int			overload;  	/*  	 * The bit corresponding to a CPU gets set here if such CPU has more @@ -845,6 +850,8 @@ struct rq {  	unsigned char		idle_balance; +	unsigned long		misfit_task_load; +  	/* For active balancing */  	int			active_balance;  	int			push_cpu; @@ -858,8 +865,7 @@ struct rq {  	struct sched_avg	avg_rt;  	struct sched_avg	avg_dl; -#if defined(CONFIG_IRQ_TIME_ACCOUNTING) || defined(CONFIG_PARAVIRT_TIME_ACCOUNTING) -#define HAVE_SCHED_AVG_IRQ +#ifdef CONFIG_HAVE_SCHED_AVG_IRQ  	struct sched_avg	avg_irq;  #endif  	u64			idle_stamp; @@ -953,6 +959,8 @@ DECLARE_PER_CPU_SHARED_ALIGNED(struct rq, runqueues);  #define cpu_curr(cpu)		(cpu_rq(cpu)->curr)  #define raw_rq()		raw_cpu_ptr(&runqueues) +extern void update_rq_clock(struct rq *rq); +  static inline u64 __rq_clock_broken(struct rq *rq)  {  	return READ_ONCE(rq->clock); @@ -1071,6 +1079,98 @@ static inline void rq_repin_lock(struct rq *rq, struct rq_flags *rf)  #endif  } +struct rq *__task_rq_lock(struct task_struct *p, struct rq_flags *rf) +	__acquires(rq->lock); + +struct rq *task_rq_lock(struct task_struct *p, struct rq_flags *rf) +	__acquires(p->pi_lock) +	__acquires(rq->lock); + +static inline void __task_rq_unlock(struct rq *rq, struct rq_flags *rf) +	__releases(rq->lock) +{ +	rq_unpin_lock(rq, rf); +	raw_spin_unlock(&rq->lock); +} + +static inline void +task_rq_unlock(struct rq *rq, struct task_struct *p, struct rq_flags *rf) +	__releases(rq->lock) +	__releases(p->pi_lock) +{ +	rq_unpin_lock(rq, rf); +	raw_spin_unlock(&rq->lock); +	raw_spin_unlock_irqrestore(&p->pi_lock, rf->flags); +} + +static inline void +rq_lock_irqsave(struct rq *rq, struct rq_flags *rf) +	__acquires(rq->lock) +{ +	raw_spin_lock_irqsave(&rq->lock, rf->flags); +	rq_pin_lock(rq, rf); +} + +static inline void +rq_lock_irq(struct rq *rq, struct rq_flags *rf) +	__acquires(rq->lock) +{ +	raw_spin_lock_irq(&rq->lock); +	rq_pin_lock(rq, rf); +} + +static inline void +rq_lock(struct rq *rq, struct rq_flags *rf) +	__acquires(rq->lock) +{ +	raw_spin_lock(&rq->lock); +	rq_pin_lock(rq, rf); +} + +static inline void +rq_relock(struct rq *rq, struct rq_flags *rf) +	__acquires(rq->lock) +{ +	raw_spin_lock(&rq->lock); +	rq_repin_lock(rq, rf); +} + +static inline void +rq_unlock_irqrestore(struct rq *rq, struct rq_flags *rf) +	__releases(rq->lock) +{ +	rq_unpin_lock(rq, rf); +	raw_spin_unlock_irqrestore(&rq->lock, rf->flags); +} + +static inline void +rq_unlock_irq(struct rq *rq, struct rq_flags *rf) +	__releases(rq->lock) +{ +	rq_unpin_lock(rq, rf); +	raw_spin_unlock_irq(&rq->lock); +} + +static inline void +rq_unlock(struct rq *rq, struct rq_flags *rf) +	__releases(rq->lock) +{ +	rq_unpin_lock(rq, rf); +	raw_spin_unlock(&rq->lock); +} + +static inline struct rq * +this_rq_lock_irq(struct rq_flags *rf) +	__acquires(rq->lock) +{ +	struct rq *rq; + +	local_irq_disable(); +	rq = this_rq(); +	rq_lock(rq, rf); +	return rq; +} +  #ifdef CONFIG_NUMA  enum numa_topology_type {  	NUMA_DIRECT, @@ -1188,6 +1288,7 @@ DECLARE_PER_CPU(int, sd_llc_id);  DECLARE_PER_CPU(struct sched_domain_shared *, sd_llc_shared);  DECLARE_PER_CPU(struct sched_domain *, sd_numa);  DECLARE_PER_CPU(struct sched_domain *, sd_asym); +extern struct static_key_false sched_asym_cpucapacity;  struct sched_group_capacity {  	atomic_t		ref; @@ -1197,6 +1298,7 @@ struct sched_group_capacity {  	 */  	unsigned long		capacity;  	unsigned long		min_capacity;		/* Min per-CPU capacity in group */ +	unsigned long		max_capacity;		/* Max per-CPU capacity in group */  	unsigned long		next_update;  	int			imbalance;		/* XXX unrelated to capacity but shared group state */ @@ -1396,7 +1498,7 @@ static const_debug __maybe_unused unsigned int sysctl_sched_features =  	0;  #undef SCHED_FEAT -#define sched_feat(x) (sysctl_sched_features & (1UL << __SCHED_FEAT_##x)) +#define sched_feat(x) !!(sysctl_sched_features & (1UL << __SCHED_FEAT_##x))  #endif /* SCHED_DEBUG && HAVE_JUMP_LABEL */ @@ -1696,8 +1798,8 @@ static inline void add_nr_running(struct rq *rq, unsigned count)  	if (prev_nr < 2 && rq->nr_running >= 2) {  #ifdef CONFIG_SMP -		if (!rq->rd->overload) -			rq->rd->overload = true; +		if (!READ_ONCE(rq->rd->overload)) +			WRITE_ONCE(rq->rd->overload, 1);  #endif  	} @@ -1711,8 +1813,6 @@ static inline void sub_nr_running(struct rq *rq, unsigned count)  	sched_update_tick_dependency(rq);  } -extern void update_rq_clock(struct rq *rq); -  extern void activate_task(struct rq *rq, struct task_struct *p, int flags);  extern void deactivate_task(struct rq *rq, struct task_struct *p, int flags); @@ -1777,86 +1877,6 @@ unsigned long arch_scale_cpu_capacity(void __always_unused *sd, int cpu)  #endif  #endif -struct rq *__task_rq_lock(struct task_struct *p, struct rq_flags *rf) -	__acquires(rq->lock); - -struct rq *task_rq_lock(struct task_struct *p, struct rq_flags *rf) -	__acquires(p->pi_lock) -	__acquires(rq->lock); - -static inline void __task_rq_unlock(struct rq *rq, struct rq_flags *rf) -	__releases(rq->lock) -{ -	rq_unpin_lock(rq, rf); -	raw_spin_unlock(&rq->lock); -} - -static inline void -task_rq_unlock(struct rq *rq, struct task_struct *p, struct rq_flags *rf) -	__releases(rq->lock) -	__releases(p->pi_lock) -{ -	rq_unpin_lock(rq, rf); -	raw_spin_unlock(&rq->lock); -	raw_spin_unlock_irqrestore(&p->pi_lock, rf->flags); -} - -static inline void -rq_lock_irqsave(struct rq *rq, struct rq_flags *rf) -	__acquires(rq->lock) -{ -	raw_spin_lock_irqsave(&rq->lock, rf->flags); -	rq_pin_lock(rq, rf); -} - -static inline void -rq_lock_irq(struct rq *rq, struct rq_flags *rf) -	__acquires(rq->lock) -{ -	raw_spin_lock_irq(&rq->lock); -	rq_pin_lock(rq, rf); -} - -static inline void -rq_lock(struct rq *rq, struct rq_flags *rf) -	__acquires(rq->lock) -{ -	raw_spin_lock(&rq->lock); -	rq_pin_lock(rq, rf); -} - -static inline void -rq_relock(struct rq *rq, struct rq_flags *rf) -	__acquires(rq->lock) -{ -	raw_spin_lock(&rq->lock); -	rq_repin_lock(rq, rf); -} - -static inline void -rq_unlock_irqrestore(struct rq *rq, struct rq_flags *rf) -	__releases(rq->lock) -{ -	rq_unpin_lock(rq, rf); -	raw_spin_unlock_irqrestore(&rq->lock, rf->flags); -} - -static inline void -rq_unlock_irq(struct rq *rq, struct rq_flags *rf) -	__releases(rq->lock) -{ -	rq_unpin_lock(rq, rf); -	raw_spin_unlock_irq(&rq->lock); -} - -static inline void -rq_unlock(struct rq *rq, struct rq_flags *rf) -	__releases(rq->lock) -{ -	rq_unpin_lock(rq, rf); -	raw_spin_unlock(&rq->lock); -} -  #ifdef CONFIG_SMP  #ifdef CONFIG_PREEMPT @@ -2217,7 +2237,7 @@ static inline unsigned long cpu_util_rt(struct rq *rq)  }  #endif -#ifdef HAVE_SCHED_AVG_IRQ +#ifdef CONFIG_HAVE_SCHED_AVG_IRQ  static inline unsigned long cpu_util_irq(struct rq *rq)  {  	return rq->avg_irq.util_avg; | 
