cvs commit: src/sys/sys globaldata.h param.h proc.h src/sys/kern kern_clock.c kern_exit.c kern_switch.c kern_synch.c lwkt_thread.c src/sys/i386/i386 trap.c
Matthew Dillon
dillon at crater.dragonflybsd.org
Fri Oct 17 00:31:55 PDT 2003
dillon 2003/10/17 00:30:43 PDT
Modified files:
sys/sys globaldata.h param.h proc.h
sys/kern kern_clock.c kern_exit.c kern_switch.c
kern_synch.c lwkt_thread.c
sys/i386/i386 trap.c
Log:
Cleanup P_CURPROC and P_CP_RELEASED handling. P_CP_RELEASED prevents the
userland scheduler from messing with a process and must be set (in a lazy
fashion) when a thread that came in from userland is about to block in
the kernel. P_CURPROC is used to manage which threads belonging to
processes controlled by the userland scheduler are scheduled by LWKT.
The userland scheduler has also been streamlined considerably.
p_priority now has a rollup priority that can be compared directly,
regardless of the realtime/idle/whatever queue a process is on.
p_priority has been changed from an unsigned char to a signed short.
schedclock is now distributed, so 'top' shows the correct values.
A huge amount of cpu affinity code has been added to the scheduler. It is
not working 100% yet, but the framework is there (see kern/kern_switch.c).
globaldata now has gd_upri to support remote reschedule requests issued
by the affinity code. There are two goals to the new scheduling code for
MP boxes: (1) so niced/idleprio cpu bound programs do not interfere
*at* *all* with other things (like, say, a buildworld). (2) to reduce
the flip-flopping of processes between cpus.
lwkt_gettoken() now increments the generation number unconditionally so
kernel code can detect when other processes have used a token.
lwkt_send_ipiq_mask() removes stopped cpus from the mask automatically.
Revision Changes Path
1.18 +3 -1 src/sys/sys/globaldata.h
1.8 +5 -0 src/sys/sys/param.h
1.34 +4 -5 src/sys/sys/proc.h
1.12 +10 -2 src/sys/kern/kern_clock.c
1.25 +1 -1 src/sys/kern/kern_exit.c
1.11 +218 -71 src/sys/kern/kern_switch.c
1.25 +38 -50 src/sys/kern/kern_synch.c
1.37 +7 -3 src/sys/kern/lwkt_thread.c
1.36 +32 -21 src/sys/i386/i386/trap.c
More information about the Commits
mailing list