cvs commit: src/sys/gnu/fs/ext2fs ext2_bmap.c src/sys/kern
init_main.c kern_acct.c kern_clock.c kern_exit.c kern_fork.c
kern_proc.c kern_resource.c kern_sig.c kern_synch.c kern_thread.c
subr_trap.c uipc_socket.c vfs_aio.c vfs_bio.c vfs_cluster.c ...
Jeff Roberson
jeff at FreeBSD.org
Fri Jun 1 01:12:46 UTC 2007
jeff 2007-06-01 01:12:45 UTC
FreeBSD src repository
Modified files:
sys/gnu/fs/ext2fs ext2_bmap.c
sys/kern init_main.c kern_acct.c kern_clock.c
kern_exit.c kern_fork.c kern_proc.c
kern_resource.c kern_sig.c kern_synch.c
kern_thread.c subr_trap.c uipc_socket.c
vfs_aio.c vfs_bio.c vfs_cluster.c
sys/netinet sctp_output.c
sys/nfs4client nfs4_vnops.c
sys/nfsclient nfs_vnops.c
sys/sys proc.h resource.h resourcevar.h
sys/ufs/ffs ffs_inode.c
sys/ufs/ufs ufs_bmap.c
sys/vm vm_fault.c vm_glue.c
Log:
- Move rusage from being per-process in struct pstats to per-thread in
td_ru. This removes the requirement for per-process synchronization in
statclock() and mi_switch(). This was previously supported by
sched_lock which is going away. All modifications to rusage are now
done in the context of the owning thread. reads proceed without locks.
- Aggregate exiting threads rusage in thread_exit() such that the exiting
thread's rusage is not lost.
- Provide a new routine, rufetch() to fetch an aggregate of all rusage
structures from all threads in a process. This routine must be used
in any place requiring a rusage from a process prior to it's exit. The
exited process's rusage is still available via p_ru.
- Aggregate tick statistics only on demand via rufetch() or when a thread
exits. Tick statistics are kept in the thread and protected by sched_lock
until it exits.
Initial patch by: attilio
Reviewed by: attilio, bde (some objections), arch (mostly silent)
Revision Changes Path
1.64 +1 -1 src/sys/gnu/fs/ext2fs/ext2_bmap.c
1.277 +1 -0 src/sys/kern/init_main.c
1.91 +5 -5 src/sys/kern/kern_acct.c
1.199 +4 -6 src/sys/kern/kern_clock.c
1.299 +17 -9 src/sys/kern/kern_exit.c
1.274 +1 -1 src/sys/kern/kern_fork.c
1.248 +1 -1 src/sys/kern/kern_proc.c
1.172 +103 -22 src/sys/kern/kern_resource.c
1.345 +2 -2 src/sys/kern/kern_sig.c
1.297 +5 -27 src/sys/kern/kern_synch.c
1.245 +11 -8 src/sys/kern/kern_thread.c
1.294 +2 -18 src/sys/kern/subr_trap.c
1.301 +3 -3 src/sys/kern/uipc_socket.c
1.231 +8 -10 src/sys/kern/vfs_aio.c
1.524 +3 -3 src/sys/kern/vfs_bio.c
1.176 +2 -2 src/sys/kern/vfs_cluster.c
1.31 +1 -1 src/sys/netinet/sctp_output.c
1.37 +1 -1 src/sys/nfs4client/nfs4_vnops.c
1.276 +1 -1 src/sys/nfsclient/nfs_vnops.c
1.478 +10 -7 src/sys/sys/proc.h
1.31 +18 -20 src/sys/sys/resource.h
1.50 +5 -2 src/sys/sys/resourcevar.h
1.108 +1 -1 src/sys/ufs/ffs/ffs_inode.c
1.66 +1 -1 src/sys/ufs/ufs/ufs_bmap.c
1.230 +4 -9 src/sys/vm/vm_fault.c
1.222 +2 -2 src/sys/vm/vm_glue.c
More information about the cvs-all
mailing list