The process spin lock currently has the following distinct uses:
authorkib <kib@FreeBSD.org>
Wed, 26 Nov 2014 14:10:00 +0000 (14:10 +0000)
committerkib <kib@FreeBSD.org>
Wed, 26 Nov 2014 14:10:00 +0000 (14:10 +0000)
commit11cee2ecf718fa761131860c639d7818651056ec
treea1ba3d51716b09fd5fc82995da8ea68bc729c69f
parent4501dadd00cece6d06392c42e5fc6af07731e451
The process spin lock currently has the following distinct uses:

- Threads lifetime cycle, in particular, counting of the threads in
  the process, and interlocking with process mutex and thread lock.
  The main reason of this is that turnstile locks are after thread
  locks, so you e.g. cannot unlock blockable mutex (think process
  mutex) while owning thread lock.

- Virtual and profiling itimers, since the timers activation is done
  from the clock interrupt context.  Replace the p_slock by p_itimmtx
  and PROC_ITIMLOCK().

- Profiling code (profil(2)), for similar reason.  Replace the p_slock
  by p_profmtx and PROC_PROFLOCK().

- Resource usage accounting.  Need for the spinlock there is subtle,
  my understanding is that spinlock blocks context switching for the
  current thread, which prevents td_runtime and similar fields from
  changing (updates are done at the mi_switch()).  Replace the p_slock
  by p_statmtx and PROC_STATLOCK().

The split is done mostly for code clarity, and should not affect
scalability.

Tested by: pho
Sponsored by: The FreeBSD Foundation
MFC after: 1 week
15 files changed:
sys/compat/linux/linux_misc.c
sys/compat/svr4/svr4_misc.c
sys/fs/procfs/procfs_status.c
sys/kern/init_main.c
sys/kern/kern_clock.c
sys/kern/kern_exit.c
sys/kern/kern_mutex.c
sys/kern/kern_proc.c
sys/kern/kern_racct.c
sys/kern/kern_resource.c
sys/kern/kern_thread.c
sys/kern/kern_time.c
sys/kern/subr_prof.c
sys/sys/proc.h
sys/sys/resourcevar.h