diff options
Diffstat (limited to 'kernel/sched/ext.c')
| -rw-r--r-- | kernel/sched/ext.c | 29 | 
1 files changed, 19 insertions, 10 deletions
| diff --git a/kernel/sched/ext.c b/kernel/sched/ext.c index 2c41c78be61e..7dd5cbcb7a06 100644 --- a/kernel/sched/ext.c +++ b/kernel/sched/ext.c @@ -1272,7 +1272,8 @@ static inline struct rq *scx_locked_rq(void)  #define SCX_CALL_OP(sch, mask, op, rq, args...)					\  do {										\ -	update_locked_rq(rq);							\ +	if (rq)									\ +		update_locked_rq(rq);						\  	if (mask) {								\  		scx_kf_allow(mask);						\  		(sch)->ops.op(args);						\ @@ -1280,14 +1281,16 @@ do {										\  	} else {								\  		(sch)->ops.op(args);						\  	}									\ -	update_locked_rq(NULL);							\ +	if (rq)									\ +		update_locked_rq(NULL);						\  } while (0)  #define SCX_CALL_OP_RET(sch, mask, op, rq, args...)				\  ({										\  	__typeof__((sch)->ops.op(args)) __ret;					\  										\ -	update_locked_rq(rq);							\ +	if (rq)									\ +		update_locked_rq(rq);						\  	if (mask) {								\  		scx_kf_allow(mask);						\  		__ret = (sch)->ops.op(args);					\ @@ -1295,7 +1298,8 @@ do {										\  	} else {								\  		__ret = (sch)->ops.op(args);					\  	}									\ -	update_locked_rq(NULL);							\ +	if (rq)									\ +		update_locked_rq(NULL);						\  	__ret;									\  }) @@ -4092,6 +4096,11 @@ bool scx_can_stop_tick(struct rq *rq)  DEFINE_STATIC_PERCPU_RWSEM(scx_cgroup_rwsem);  static bool scx_cgroup_enabled; +void scx_tg_init(struct task_group *tg) +{ +	tg->scx_weight = CGROUP_WEIGHT_DFL; +} +  int scx_tg_online(struct task_group *tg)  {  	struct scx_sched *sch = scx_root; @@ -4241,12 +4250,12 @@ void scx_group_set_weight(struct task_group *tg, unsigned long weight)  	percpu_down_read(&scx_cgroup_rwsem); -	if (scx_cgroup_enabled && tg->scx_weight != weight) { -		if (SCX_HAS_OP(sch, cgroup_set_weight)) -			SCX_CALL_OP(sch, SCX_KF_UNLOCKED, cgroup_set_weight, NULL, -				    tg_cgrp(tg), weight); -		tg->scx_weight = weight; -	} +	if (scx_cgroup_enabled && SCX_HAS_OP(sch, cgroup_set_weight) && +	    tg->scx_weight != weight) +		SCX_CALL_OP(sch, SCX_KF_UNLOCKED, cgroup_set_weight, NULL, +			    tg_cgrp(tg), weight); + +	tg->scx_weight = weight;  	percpu_up_read(&scx_cgroup_rwsem);  } | 
