libc_private.h revision 122069
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 122069 2003-11-04 19:49:56Z deischen $
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#include <spinlock.h>
42
43/*
44 * This global flag is non-zero when a process has created one
45 * or more threads. It is used to avoid calling locking functions
46 * when they are not required.
47 */
48extern int	__isthreaded;
49
50/*
51 * File lock contention is difficult to diagnose without knowing
52 * where locks were set. Allow a debug library to be built which
53 * records the source file and line number of each lock call.
54 */
55#ifdef	_FLOCK_DEBUG
56#define _FLOCKFILE(x)	_flockfile_debug(x, __FILE__, __LINE__)
57#else
58#define _FLOCKFILE(x)	_flockfile(x)
59#endif
60
61/*
62 * Macros for locking and unlocking FILEs. These test if the
63 * process is threaded to avoid locking when not required.
64 */
65#define	FLOCKFILE(fp)		if (__isthreaded) _FLOCKFILE(fp)
66#define	FUNLOCKFILE(fp)		if (__isthreaded) _funlockfile(fp)
67
68/*
69 * Indexes into the pthread jump table.
70 *
71 * Warning! If you change this type, you must also change the threads
72 * libraries that reference it (libc_r, libpthread).
73 */
74typedef enum {
75	PJT_COND_BROADCAST,
76	PJT_COND_DESTROY,
77	PJT_COND_INIT,
78	PJT_COND_SIGNAL,
79	PJT_COND_WAIT,
80	PJT_GETSPECIFIC,
81	PJT_KEY_CREATE,
82	PJT_KEY_DELETE,
83	PJT_MAIN_NP,
84	PJT_MUTEX_DESTROY,
85	PJT_MUTEX_INIT,
86	PJT_MUTEX_LOCK,
87	PJT_MUTEX_TRYLOCK,
88	PJT_MUTEX_UNLOCK,
89	PJT_MUTEXATTR_DESTROY,
90	PJT_MUTEXATTR_INIT,
91	PJT_MUTEXATTR_SETTYPE,
92	PJT_ONCE,
93	PJT_RWLOCK_DESTROY,
94	PJT_RWLOCK_INIT,
95	PJT_RWLOCK_RDLOCK,
96	PJT_RWLOCK_TRYRDLOCK,
97	PJT_RWLOCK_TRYWRLOCK,
98	PJT_RWLOCK_UNLOCK,
99	PJT_RWLOCK_WRLOCK,
100	PJT_SELF,
101	PJT_SETSPECIFIC,
102	PJT_SIGMASK,
103	PJT_MAX
104} pjt_index_t;
105
106typedef int (*pthread_func_t)(void);
107typedef pthread_func_t pthread_func_entry_t[2];
108
109extern pthread_func_entry_t __thr_jtable[];
110
111/*
112 * yplib internal interfaces
113 */
114#ifdef YP
115int _yp_check(char **);
116#endif
117
118
119/*
120 * This is a pointer in the C run-time startup code. It is used
121 * by getprogname() and setprogname().
122 */
123extern const char *__progname;
124
125/*
126 * This is the lock to make malloc() thread-safe.  It is externalized
127 * so that thread libraries can protect malloc across fork().
128 */
129extern spinlock_t *__malloc_lock;
130
131#endif /* _LIBC_PRIVATE_H_ */
132