table of contents
| PHOLD(9) | Kernel Developer's Manual | PHOLD(9) |
NAME¶
PHOLD — hold a
process
SYNOPSIS¶
#include
<sys/proc.h>
PHOLD(struct
proc *p);
_PHOLD(struct
proc *p);
PRELE(struct
proc *p);
_PRELE(struct
proc *p);
PROC_ASSERT_HELD(struct
proc *p);
PROC_ASSERT_NOT_HELD(struct
proc *p);
DESCRIPTION¶
The
PHOLD()
macro increments the hold count of a process, and the
PRELE()
macro decrements the hold count of a process.
If a process with a non-zero hold count attempts to exit, it will
sleep until its hold count has reached zero before the kernel begins
releasing resources associated with the process. Once a process has started
exiting, it is invalid to increase its hold count. Thus, callers must not
attempt to hold a process that has the P_WEXIT flag
set. The VM daemon will not swap out the kernel stack of a thread belonging
to a process with a non-zero hold count.
The
_PHOLD() and
_PRELE()
macros are identical to PHOLD() and
PRELE(), except that they must be called with the
process lock held.
AUTHORS¶
This manual page was written by Mark Johnston <markj@FreeBSD.org>.
| November 7, 2015 | Debian |