git: kernel - Optimize idle thread halt
Matthew Dillon
dillon at crater.dragonflybsd.org
Sun Dec 19 11:24:01 PST 2010
commit be71787bd3c8d2d199af9bb30ffb6df730c6b858
Author: Matthew Dillon <dillon at apollo.backplane.com>
Date: Sun Dec 19 11:17:36 2010 -0800
kernel - Optimize idle thread halt
* Count the number of times the idle thread is entered on a cpu without
switching to a non-idle thread. Use the fast-halt (non-ACPI) until the
count exceeds a reasonable machdep.cpu_idle_repeat.
This improves the default performance to levels closer to cpu_idle_hlt
mode 1 but still gives us the power savings from mode 3. Performanced is
improved significantly because many threads on SMP boxes are event
or pipe oriented and only sleep for short periods of time or ping-pong
back and forth. For example, a cc -pipe, or typical kernel threads
blocking on tokens or locks for short periods of time.
* Adjust machdep.cpu_idle_hlt modes:
0 Never halt, the idle thread just spins.
1 Always use a fast HLT/MONITOR/MWAIT
2 Hybrid approach use (1) up to a certain point, then use (3).
(this is the default)
3 Always use the ACPI halt
Summary of changes:
sys/kern/lwkt_thread.c | 4 ++
sys/platform/pc32/i386/machdep.c | 55 ++++++++++++++++++++++++++++++-----
sys/platform/pc64/x86_64/machdep.c | 47 ++++++++++++++++++++++++++----
sys/sys/globaldata.h | 5 ++-
4 files changed, 96 insertions(+), 15 deletions(-)
http://gitweb.dragonflybsd.org/dragonfly.git/commitdiff/be71787bd3c8d2d199af9bb30ffb6df730c6b858
--
DragonFly BSD source repository
More information about the Commits
mailing list