diff options
Diffstat (limited to 'kernel/sched/core.c')
| -rw-r--r-- | kernel/sched/core.c | 74 | 
1 files changed, 20 insertions, 54 deletions
| diff --git a/kernel/sched/core.c b/kernel/sched/core.c index be00629f0ba4..ec126f85ff40 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -7,6 +7,8 @@   *  Copyright (C) 1991-2002  Linus Torvalds   *  Copyright (C) 1998-2024  Ingo Molnar, Red Hat   */ +#define INSTANTIATE_EXPORTED_MIGRATE_DISABLE +#include <linux/sched.h>  #include <linux/highmem.h>  #include <linux/hrtimer_api.h>  #include <linux/ktime_api.h> @@ -2381,28 +2383,7 @@ static void migrate_disable_switch(struct rq *rq, struct task_struct *p)  	__do_set_cpus_allowed(p, &ac);  } -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()->nr_pinned++; -	p->migration_disabled = 1; -} -EXPORT_SYMBOL_GPL(migrate_disable); - -void migrate_enable(void) +void ___migrate_enable(void)  {  	struct task_struct *p = current;  	struct affinity_context ac = { @@ -2410,35 +2391,19 @@ void migrate_enable(void)  		.flags     = SCA_MIGRATE_ENABLE,  	}; -#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 +	__set_cpus_allowed_ptr(p, &ac); +} +EXPORT_SYMBOL_GPL(___migrate_enable); -	if (p->migration_disabled > 1) { -		p->migration_disabled--; -		return; -	} +void migrate_disable(void) +{ +	__migrate_disable(); +} +EXPORT_SYMBOL_GPL(migrate_disable); -	/* -	 * Ensure stop_task runs either before or after this, and that -	 * __set_cpus_allowed_ptr(SCA_MIGRATE_ENABLE) doesn't schedule(). -	 */ -	guard(preempt)(); -	if (p->cpus_ptr != &p->cpus_mask) -		__set_cpus_allowed_ptr(p, &ac); -	/* -	 * 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()->nr_pinned--; +void migrate_enable(void) +{ +	__migrate_enable();  }  EXPORT_SYMBOL_GPL(migrate_enable); @@ -4472,7 +4437,7 @@ int wake_up_state(struct task_struct *p, unsigned int state)   * __sched_fork() is basic setup which is also used by sched_init() to   * initialize the boot CPU's idle task.   */ -static void __sched_fork(unsigned long clone_flags, struct task_struct *p) +static void __sched_fork(u64 clone_flags, struct task_struct *p)  {  	p->on_rq			= 0; @@ -4490,6 +4455,9 @@ static void __sched_fork(unsigned long clone_flags, struct task_struct *p)  #ifdef CONFIG_FAIR_GROUP_SCHED  	p->se.cfs_rq			= NULL; +#ifdef CONFIG_CFS_BANDWIDTH +	init_cfs_throttle_work(p); +#endif  #endif  #ifdef CONFIG_SCHEDSTATS @@ -4707,7 +4675,7 @@ late_initcall(sched_core_sysctl_init);  /*   * fork()/clone()-time setup:   */ -int sched_fork(unsigned long clone_flags, struct task_struct *p) +int sched_fork(u64 clone_flags, struct task_struct *p)  {  	__sched_fork(clone_flags, p);  	/* @@ -9362,8 +9330,6 @@ static void cpu_cgroup_attach(struct cgroup_taskset *tset)  	cgroup_taskset_for_each(task, css, tset)  		sched_move_task(task, false); - -	scx_cgroup_finish_attach();  }  static void cpu_cgroup_cancel_attach(struct cgroup_taskset *tset) @@ -9551,7 +9517,7 @@ static unsigned long tg_weight(struct task_group *tg)  #ifdef CONFIG_FAIR_GROUP_SCHED  	return scale_load_down(tg->shares);  #else -	return sched_weight_from_cgroup(tg->scx_weight); +	return sched_weight_from_cgroup(tg->scx.weight);  #endif  } | 
