public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH v1] sched_ext: keep running prev when prev->scx.slice != 0
@ 2025-01-07  4:25 Henry Huang
  2025-01-07  4:25 ` Henry Huang
  0 siblings, 1 reply; 4+ messages in thread
From: Henry Huang @ 2025-01-07  4:25 UTC (permalink / raw)
  To: tj, void
  Cc: 谈鉴锋, Yan Yan(cailing), linux-kernel,
	Henry Huang

In our environment, we have various types of tasks. Some tasks can keep running after their slice is exhausted,
while others need to be dispatched into the global DSQ for rescheduling. Therefore, we set %SCX_OPS_ENQ_LAST.

However, we encountered a problem:
Because put_prev_task_scx() is executed after pick_task_scx(), @prev only has the opportunity to be dispatched
into local DSQ in put_prev_task_scx(). Since pick_task_scx returns NULL, the CPU enters the idle state instead of running @prev.

Our current workaround is to set a value to @prev->scx.slice in ops.dispatch() and call scx_bpf_kick_cpu(cpu, 0) to trigger a reschedule.
Of course, this approach introduces some overhead.

Our solution:
When %SCX_OPS_ENQ_LAST is set and prev->scx.slice != 0, we only need to set %SCX_RQ_BAL_KEEP in blance_one to
ensure pick_task_scx() can pick the correct task.

Henry Huang (1):
  sched_ext: keep running prev when prev->scx.slice != 0

 kernel/sched/ext.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

-- 
1.8.3.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2025-01-08  4:14 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-01-07  4:25 [PATCH v1] sched_ext: keep running prev when prev->scx.slice != 0 Henry Huang
2025-01-07  4:25 ` Henry Huang
2025-01-07 21:20   ` Tejun Heo
2025-01-08  4:09     ` Henry Huang

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox