libc_private.h revision 154248
1/*
2 * Copyright (c) 1998 John Birrell <jb@cimlogic.com.au>.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 *    notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 *    notice, this list of conditions and the following disclaimer in the
12 *    documentation and/or other materials provided with the distribution.
13 * 3. All advertising materials mentioning features or use of this software
14 *    must display the following acknowledgement:
15 *	This product includes software developed by John Birrell.
16 * 4. Neither the name of the author nor the names of any co-contributors
17 *    may be used to endorse or promote products derived from this software
18 *    without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY JOHN BIRRELL AND CONTRIBUTORS ``AS IS'' AND
21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
32 * $FreeBSD: head/lib/libc/include/libc_private.h 154248 2006-01-12 07:28:21Z jasone $
33 *
34 * Private definitions for libc, libc_r and libpthread.
35 *
36 */
37
38#ifndef _LIBC_PRIVATE_H_
39#define _LIBC_PRIVATE_H_
40
41/*
42 * This global flag is non-zero when a process has created one
43 * or more threads. It is used to avoid calling locking functions
44 * when they are not required.
45 */
46extern int	__isthreaded;
47
48/*
49 * File lock contention is difficult to diagnose without knowing
50 * where locks were set. Allow a debug library to be built which
51 * records the source file and line number of each lock call.
52 */
53#ifdef	_FLOCK_DEBUG
54#define _FLOCKFILE(x)	_flockfile_debug(x, __FILE__, __LINE__)
55#else
56#define _FLOCKFILE(x)	_flockfile(x)
57#endif
58
59/*
60 * Macros for locking and unlocking FILEs. These test if the
61 * process is threaded to avoid locking when not required.
62 */
63#define	FLOCKFILE(fp)		if (__isthreaded) _FLOCKFILE(fp)
64#define	FUNLOCKFILE(fp)		if (__isthreaded) _funlockfile(fp)
65
66/*
67 * Indexes into the pthread jump table.
68 *
69 * Warning! If you change this type, you must also change the threads
70 * libraries that reference it (libc_r, libpthread).
71 */
72typedef enum {
73	PJT_COND_BROADCAST,
74	PJT_COND_DESTROY,
75	PJT_COND_INIT,
76	PJT_COND_SIGNAL,
77	PJT_COND_WAIT,
78	PJT_GETSPECIFIC,
79	PJT_KEY_CREATE,
80	PJT_KEY_DELETE,
81	PJT_MAIN_NP,
82	PJT_MUTEX_DESTROY,
83	PJT_MUTEX_INIT,
84	PJT_MUTEX_LOCK,
85	PJT_MUTEX_TRYLOCK,
86	PJT_MUTEX_UNLOCK,
87	PJT_MUTEXATTR_DESTROY,
88	PJT_MUTEXATTR_INIT,
89	PJT_MUTEXATTR_SETTYPE,
90	PJT_ONCE,
91	PJT_RWLOCK_DESTROY,
92	PJT_RWLOCK_INIT,
93	PJT_RWLOCK_RDLOCK,
94	PJT_RWLOCK_TRYRDLOCK,
95	PJT_RWLOCK_TRYWRLOCK,
96	PJT_RWLOCK_UNLOCK,
97	PJT_RWLOCK_WRLOCK,
98	PJT_SELF,
99	PJT_SETSPECIFIC,
100	PJT_SIGMASK,
101	PJT_MAX
102} pjt_index_t;
103
104typedef int (*pthread_func_t)(void);
105typedef pthread_func_t pthread_func_entry_t[2];
106
107extern pthread_func_entry_t __thr_jtable[];
108
109/*
110 * yplib internal interfaces
111 */
112#ifdef YP
113int _yp_check(char **);
114#endif
115
116/*
117 * Initialise TLS for static programs
118 */
119void _init_tls(void);
120
121/*
122 * Set the TLS thread pointer
123 */
124void _set_tp(void *tp);
125
126/*
127 * This is a pointer in the C run-time startup code. It is used
128 * by getprogname() and setprogname().
129 */
130extern const char *__progname;
131
132/*
133 * These functions are used by the threading libraries in order to protect
134 * malloc across fork().
135 */
136void _malloc_prefork(void);
137void _malloc_postfork(void);
138
139/*
140 * Function to clean up streams, called from abort() and exit().
141 */
142extern void (*__cleanup)(void);
143
144#endif /* _LIBC_PRIVATE_H_ */
145