[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20250207060917.30201-1-15645113830zzh@gmail.com>
Date: Fri, 7 Feb 2025 14:09:18 +0800
From: zihan zhou <15645113830zzh@...il.com>
To: mingo@...hat.com,
peterz@...radead.org,
juri.lelli@...hat.com,
vincent.guittot@...aro.org,
dietmar.eggemann@....com,
rostedt@...dmis.org,
bsegall@...gle.com,
mgorman@...e.de,
vschneid@...hat.com
Cc: linux-kernel@...r.kernel.org,
zihan zhou <15645113830zzh@...il.com>
Subject: [PATCH V2 0/2] sched: Reduce the default slice to avoid tasks getting an extra tick
The old default value for slice is 0.75 msec * (1 + ilog(ncpus)) which
means that we have a default slice of
0.75 for 1 cpu
1.50 up to 3 cpus
2.25 up to 7 cpus
3.00 for 8 cpus and above.
For HZ=250 and HZ=100, because of the tick accuracy, the runtime of
tasks is far higher than their slice.
For HZ=1000 with 8 cpus or more, the accuracy of tick is already
satisfactory, but there is still an issue that tasks will get an extra
tick because the tick often arrives a little faster than expected. In this
case, the task can only wait until the next tick to consider that it has
reached its deadline, and will run 1ms longer.
vruntime + sysctl_sched_base_slice = deadline
|-----------|-----------|-----------|-----------|
1ms 1ms 1ms 1ms
^ ^ ^ ^
tick1 tick2 tick3 tick4(nearly 4ms)
There are two reasons for tick error: clockevent precision and the
CONFIG_IRQ_TIME_ACCOUNTING/CONFIG_PARAVIRT_TIME_ACCOUNTING.
with CONFIG_IRQ_TIME_ACCOUNTING every tick will be less than 1ms, but
even
without it, because of clockevent precision, tick still often less than
1ms.
In order to make scheduling more precise, we changed 0.75 to 0.70,
Using 0.70 instead of 0.75 should not change much for other configs
and would fix this issue:
0.70 for 1 cpu
1.40 up to 3 cpus
2.10 up to 7 cpus
2.8 for 8 cpus and above.
This does not guarantee that tasks can run the slice time accurately
every
time, but occasionally running an extra tick has little impact.
Changes from v1:
- update sysctl_sched_base_slice with debugfs, limit its value and
update normalized_sysctl_sched_base_slice.
zihan zhou (2):
sched/fair: reduce the default slice.
sched/debug: update sysctl_sched_base_slice with debugfs.
kernel/sched/debug.c | 51 +++++++++++++++++++++++++++++++++++++++++++-
kernel/sched/fair.c | 47 ++++++++++++++++++++++++++++++++++++----
2 files changed, 93 insertions(+), 5 deletions(-)
--
2.33.0
Powered by blists - more mailing lists