mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-16 15:11:52 +00:00
688ebe120c
the process of exiting the kernel. The ast() function now loops as long as the PS_ASTPENDING or PS_NEEDRESCHED flags are set. It returns with preemption disabled so that any further AST's that arrive via an interrupt will be delayed until the low-level MD code returns to user mode. - Use u_int's to store the tick counts for profiling purposes so that we do not need sched_lock just to read p_sticks. This also closes a problem where the call to addupc_task() could screw up the arithmetic due to non-atomic reads of p_sticks. - Axe need_proftick(), aston(), astoff(), astpending(), need_resched(), clear_resched(), and resched_wanted() in favor of direct bit operations on p_sflag. - Fix up locking with sched_lock some. In addupc_intr(), use sched_lock to ensure pr_addr and pr_ticks are updated atomically with setting PS_OWEUPC. In ast() we clear pr_ticks atomically with clearing PS_OWEUPC. We also do not grab the lock just to test a flag. - Simplify the handling of Giant in ast() slightly. Reviewed by: bde (mostly) |
||
---|---|---|
.. | ||
autoconf.c | ||
busdma_machdep.c | ||
clock_if.m | ||
clock.c | ||
db_disasm.c | ||
db_interface.c | ||
db_trace.c | ||
elf_machdep.c | ||
exception.s | ||
exception.S | ||
genassym.c | ||
ia64-gdbstub.c | ||
in_cksum.c | ||
interrupt.c | ||
locore.s | ||
locore.S | ||
machdep.c | ||
mem.c | ||
mp_machdep.c | ||
pal.s | ||
pal.S | ||
pmap.c | ||
procfs_machdep.c | ||
ssc.c | ||
sscclock.c | ||
sscdisk.c | ||
support.s | ||
support.S | ||
swtch.s | ||
sys_machdep.c | ||
timerreg.h | ||
trap.c | ||
vm_machdep.c |