mirror of git://sourceware.org/git/glibc.git
				
				
				
			
		
			
				
	
	
		
			59 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Groff
		
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Groff
		
	
	
	
| .TH PTHREAD_ATFORK 3 LinuxThreads
 | |
| 
 | |
| .SH NAME
 | |
| pthread_atfork \- register handlers to be called at fork(2) time
 | |
| 
 | |
| .SH SYNOPSIS
 | |
| #include <pthread.h>
 | |
| 
 | |
| int pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void));
 | |
| 
 | |
| .SH DESCRIPTION
 | |
| 
 | |
| !pthread_atfork! registers handler functions to be called just before
 | |
| and just after a new process is created with !fork!(2). The |prepare|
 | |
| handler will be called from the parent process, just before the new
 | |
| process is created. The |parent| handler will be called from the parent
 | |
| process, just before !fork!(2) returns. The |child| handler will be
 | |
| called from the child process, just before !fork!(2) returns.
 | |
| 
 | |
| One or several of the three handlers |prepare|, |parent| and |child|
 | |
| can be given as !NULL!, meaning that no handler needs to be called at
 | |
| the corresponding point.
 | |
| 
 | |
| !pthread_atfork! can be called several times to install several sets
 | |
| of handlers. At !fork!(2) time, the |prepare| handlers are called in
 | |
| LIFO order (last added with !pthread_atfork!, first called before !fork!),
 | |
| while the |parent| and |child| handlers are called in FIFO order
 | |
| (first added, first called).
 | |
| 
 | |
| To understand the purpose of !pthread_atfork!, recall that !fork!(2)
 | |
| duplicates the whole memory space, including mutexes in their current
 | |
| locking state, but only the calling thread: other threads are not
 | |
| running in the child process. Thus, if a mutex is locked by a thread
 | |
| other than the thread calling !fork!, that mutex will remain locked
 | |
| forever in the child process, possibly blocking the execution of the
 | |
| child process. To avoid this, install handlers with !pthread_atfork!
 | |
| as follows: the |prepare| handler locks the global mutexes (in locking
 | |
| order), and the |parent| and |child| handlers unlock them (in
 | |
| reverse order). Alternatively, |prepare| and |parent| can be set to
 | |
| !NULL! and |child| to a function that calls !pthread_mutex_init! on
 | |
| the global mutexes.
 | |
| 
 | |
| .SH "RETURN VALUE"
 | |
| 
 | |
| !pthread_atfork! returns 0 on success and a non-zero error code on error.
 | |
| 
 | |
| .SH ERRORS
 | |
| .TP
 | |
| !ENOMEM!
 | |
| insufficient memory available to register the handlers.
 | |
| 
 | |
| .SH AUTHOR
 | |
| Xavier Leroy <Xavier.Leroy@inria.fr>
 | |
| 
 | |
| .SH "SEE ALSO"
 | |
| !fork!(2),
 | |
| !pthread_mutex_lock!(3),
 | |
| !pthread_mutex_unlock!(3).
 |