NAME
sched_4bsd
—
The 4.4BSD thread scheduler
SYNOPSIS
#include
<sys/sched.h>
void
resetpriority
(lwp_t
*l);
void
sched_tick
(struct
cpu_info *ci);
void
sched_schedclock
(lwp_t
*l);
void
sched_pstats_hook
(struct
proc *p, int
minslp);
void
sched_setrunnable
(lwp_t
*l);
void
updatepri
(lwp_t
*l);
DESCRIPTION
The traditional 4.4BSD scheduler employs a “multilevel feedback queues” algorithm, favouring interactive, short-running threads to CPU-bound ones.resetpriority
()
recomputes the priority of a thread running in user mode. If the resulting
priority is higher than that of the current thread, a reschedule is
arranged.
sched_tick
()
gets called from
hardclock(9) every 100ms to force a switch between equal priority
threads.
The priority of the current thread is
adjusted through
sched_schedclock
().
The priority of a thread gets worse as it accumulates CPU time.
sched_pstats_hook
()
gets called from
sched_pstats
()
every Hz ticks in order to recompute the priorities of all threads.
sched_setrunnable
()
checks if an LWP has slept for more than one second. If so, its priority is
updated by
updatepri
().
CODE REFERENCES
The 4.4BSD scheduler subsystem is implemented within the file sys/kern/sched_4bsd.c.
SEE ALSO
csf(9), hardclock(9), mi_switch(9), sched_m2(9), userret(9)
Marshall Kirk McKusick, Keith Bostic, Michael J. Karels, and John S. Quarterman, The Design and Implementation of the 4.4BSD Operating System, Addison Wesley, 1996.