summaryrefslogtreecommitdiffstats
path: root/lib/libc
diff options
context:
space:
mode:
authordeischen <deischen@FreeBSD.org>2003-11-04 19:49:56 +0000
committerdeischen <deischen@FreeBSD.org>2003-11-04 19:49:56 +0000
commit96918b9811a81aec1bc2aaee34a0db88044994ee (patch)
treea33d6c63283c302eaad019257473e23862fdb6d0 /lib/libc
parent07928289515debef8667077b7faedd939af2a8f0 (diff)
downloadFreeBSD-src-96918b9811a81aec1bc2aaee34a0db88044994ee.zip
FreeBSD-src-96918b9811a81aec1bc2aaee34a0db88044994ee.tar.gz
Externalize malloc's spinlock so that a thread library can take
it around an application's fork() call. Our new thread libraries (libthr, libpthread) can now have threads running while another thread calls fork(). In this case, it is possible for malloc to be left in an inconsistent state in the child. Our thread libraries, libpthread in particular, need to use malloc internally after a fork (in the child). Reviewed by: davidxu
Diffstat (limited to 'lib/libc')
-rw-r--r--lib/libc/include/libc_private.h8
-rw-r--r--lib/libc/stdlib/malloc.c1
2 files changed, 9 insertions, 0 deletions
diff --git a/lib/libc/include/libc_private.h b/lib/libc/include/libc_private.h
index f369cc7..d4265e9 100644
--- a/lib/libc/include/libc_private.h
+++ b/lib/libc/include/libc_private.h
@@ -38,6 +38,8 @@
#ifndef _LIBC_PRIVATE_H_
#define _LIBC_PRIVATE_H_
+#include <spinlock.h>
+
/*
* This global flag is non-zero when a process has created one
* or more threads. It is used to avoid calling locking functions
@@ -120,4 +122,10 @@ int _yp_check(char **);
*/
extern const char *__progname;
+/*
+ * This is the lock to make malloc() thread-safe. It is externalized
+ * so that thread libraries can protect malloc across fork().
+ */
+extern spinlock_t *__malloc_lock;
+
#endif /* _LIBC_PRIVATE_H_ */
diff --git a/lib/libc/stdlib/malloc.c b/lib/libc/stdlib/malloc.c
index 7006df2..d99457a 100644
--- a/lib/libc/stdlib/malloc.c
+++ b/lib/libc/stdlib/malloc.c
@@ -74,6 +74,7 @@ __FBSDID("$FreeBSD$");
# include "libc_private.h"
# include "spinlock.h"
static spinlock_t thread_lock = _SPINLOCK_INITIALIZER;
+ spinlock_t *__malloc_lock = &thread_lock;
# define _MALLOC_LOCK() if (__isthreaded) _SPINLOCK(&thread_lock);
# define _MALLOC_UNLOCK() if (__isthreaded) _SPINUNLOCK(&thread_lock);
#endif /* __FreeBSD__ */
OpenPOWER on IntegriCloud