diff options
Diffstat (limited to 'include/linux/sched.h')
| -rw-r--r-- | include/linux/sched.h | 120 | 
1 files changed, 118 insertions, 2 deletions
| diff --git a/include/linux/sched.h b/include/linux/sched.h index f8188b833350..cbb7340c5866 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -49,6 +49,9 @@  #include <linux/tracepoint-defs.h>  #include <linux/unwind_deferred_types.h>  #include <asm/kmap_size.h> +#ifndef COMPILE_OFFSETS +#include <generated/rq-offsets.h> +#endif  /* task_struct member predeclarations (sorted alphabetically): */  struct audit_context; @@ -706,7 +709,6 @@ struct sched_dl_entity {  	unsigned int			dl_defer	  : 1;  	unsigned int			dl_defer_armed	  : 1;  	unsigned int			dl_defer_running  : 1; -	unsigned int			dl_server_idle    : 1;  	/*  	 * Bandwidth enforcement timer. Each -deadline task has its @@ -733,7 +735,6 @@ struct sched_dl_entity {  	 * runnable task.  	 */  	struct rq			*rq; -	dl_server_has_tasks_f		server_has_tasks;  	dl_server_pick_f		server_pick_task;  #ifdef CONFIG_RT_MUTEXES @@ -883,6 +884,11 @@ struct task_struct {  #ifdef CONFIG_CGROUP_SCHED  	struct task_group		*sched_task_group; +#ifdef CONFIG_CFS_BANDWIDTH +	struct callback_head		sched_throttle_work; +	struct list_head		throttle_node; +	bool				throttled; +#endif  #endif @@ -2312,4 +2318,114 @@ static __always_inline void alloc_tag_restore(struct alloc_tag *tag, struct allo  #define alloc_tag_restore(_tag, _old)		do {} while (0)  #endif +#ifndef MODULE +#ifndef COMPILE_OFFSETS + +extern void ___migrate_enable(void); + +struct rq; +DECLARE_PER_CPU_SHARED_ALIGNED(struct rq, runqueues); + +/* + * The "struct rq" is not available here, so we can't access the + * "runqueues" with this_cpu_ptr(), as the compilation will fail in + * this_cpu_ptr() -> raw_cpu_ptr() -> __verify_pcpu_ptr(): + *   typeof((ptr) + 0) + * + * So use arch_raw_cpu_ptr()/PERCPU_PTR() directly here. + */ +#ifdef CONFIG_SMP +#define this_rq_raw() arch_raw_cpu_ptr(&runqueues) +#else +#define this_rq_raw() PERCPU_PTR(&runqueues) +#endif +#define this_rq_pinned() (*(unsigned int *)((void *)this_rq_raw() + RQ_nr_pinned)) + +static inline void __migrate_enable(void) +{ +	struct task_struct *p = current; + +#ifdef CONFIG_DEBUG_PREEMPT +	/* +	 * Check both overflow from migrate_disable() and superfluous +	 * migrate_enable(). +	 */ +	if (WARN_ON_ONCE((s16)p->migration_disabled <= 0)) +		return; +#endif + +	if (p->migration_disabled > 1) { +		p->migration_disabled--; +		return; +	} + +	/* +	 * Ensure stop_task runs either before or after this, and that +	 * __set_cpus_allowed_ptr(SCA_MIGRATE_ENABLE) doesn't schedule(). +	 */ +	guard(preempt)(); +	if (unlikely(p->cpus_ptr != &p->cpus_mask)) +		___migrate_enable(); +	/* +	 * Mustn't clear migration_disabled() until cpus_ptr points back at the +	 * regular cpus_mask, otherwise things that race (eg. +	 * select_fallback_rq) get confused. +	 */ +	barrier(); +	p->migration_disabled = 0; +	this_rq_pinned()--; +} + +static inline void __migrate_disable(void) +{ +	struct task_struct *p = current; + +	if (p->migration_disabled) { +#ifdef CONFIG_DEBUG_PREEMPT +		/* +		 *Warn about overflow half-way through the range. +		 */ +		WARN_ON_ONCE((s16)p->migration_disabled < 0); +#endif +		p->migration_disabled++; +		return; +	} + +	guard(preempt)(); +	this_rq_pinned()++; +	p->migration_disabled = 1; +} +#else /* !COMPILE_OFFSETS */ +static inline void __migrate_disable(void) { } +static inline void __migrate_enable(void) { } +#endif /* !COMPILE_OFFSETS */ + +/* + * So that it is possible to not export the runqueues variable, define and + * export migrate_enable/migrate_disable in kernel/sched/core.c too, and use + * them for the modules. The macro "INSTANTIATE_EXPORTED_MIGRATE_DISABLE" will + * be defined in kernel/sched/core.c. + */ +#ifndef INSTANTIATE_EXPORTED_MIGRATE_DISABLE +static inline void migrate_disable(void) +{ +	__migrate_disable(); +} + +static inline void migrate_enable(void) +{ +	__migrate_enable(); +} +#else /* INSTANTIATE_EXPORTED_MIGRATE_DISABLE */ +extern void migrate_disable(void); +extern void migrate_enable(void); +#endif /* INSTANTIATE_EXPORTED_MIGRATE_DISABLE */ + +#else /* MODULE */ +extern void migrate_disable(void); +extern void migrate_enable(void); +#endif /* MODULE */ + +DEFINE_LOCK_GUARD_0(migrate, migrate_disable(), migrate_enable()) +  #endif | 
