summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authordavidxu <davidxu@FreeBSD.org>2003-08-10 22:30:20 +0000
committerdavidxu <davidxu@FreeBSD.org>2003-08-10 22:30:20 +0000
commit4d41804986579927b11b034be46979d4110e0452 (patch)
tree85766a71e30d5cc8985e5a2229048173d356d929 /lib
parentb614f44d781a853409b62290cda1b2e3e0245b86 (diff)
downloadFreeBSD-src-4d41804986579927b11b034be46979d4110e0452.zip
FreeBSD-src-4d41804986579927b11b034be46979d4110e0452.tar.gz
Initialize rtld lock just before turning on thread mode and
uninitialize rtld lock after thread mode shutdown.
Diffstat (limited to 'lib')
-rw-r--r--lib/libkse/thread/thr_init.c2
-rw-r--r--lib/libkse/thread/thr_kern.c52
-rw-r--r--lib/libkse/thread/thr_sig.c18
-rw-r--r--lib/libpthread/thread/thr_init.c2
-rw-r--r--lib/libpthread/thread/thr_kern.c52
-rw-r--r--lib/libpthread/thread/thr_sig.c18
6 files changed, 74 insertions, 70 deletions
diff --git a/lib/libkse/thread/thr_init.c b/lib/libkse/thread/thr_init.c
index f9e0d9b..be3ad80 100644
--- a/lib/libkse/thread/thr_init.c
+++ b/lib/libkse/thread/thr_init.c
@@ -309,8 +309,6 @@ _libpthread_init(struct pthread *curthread)
_kcb_set(_thr_initial->kse->k_kcb);
_tcb_set(_thr_initial->kse->k_kcb, _thr_initial->tcb);
_thr_initial->kse->k_flags |= KF_INITIALIZED;
-
- _thr_rtld_init();
}
/*
diff --git a/lib/libkse/thread/thr_kern.c b/lib/libkse/thread/thr_kern.c
index 6b87dee..a940697 100644
--- a/lib/libkse/thread/thr_kern.c
+++ b/lib/libkse/thread/thr_kern.c
@@ -213,16 +213,17 @@ _kse_single_thread(struct pthread *curthread)
kse_critical_t crit;
int i;
-
- /*
- * Disable upcalls and clear the threaded flag.
- * XXX - I don't think we need to disable upcalls after a fork().
- * but it doesn't hurt.
- */
- crit = _kse_critical_enter();
+ if (__isthreaded) {
+ _thr_rtld_fini();
+ _thr_signal_deinit();
+ }
__isthreaded = 0;
+ /*
+ * Restore signal mask early, so any memory problems could
+ * dump core.
+ */
+ sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
active_threads = 1;
- _thr_signal_deinit();
/*
* Enter a loop to remove and free all threads other than
@@ -359,11 +360,18 @@ _kse_single_thread(struct pthread *curthread)
_kse_initial = NULL;
_libpthread_init(curthread);
#else
- if (__isthreaded)
+ if (__isthreaded) {
+ _thr_rtld_fini();
_thr_signal_deinit();
+ }
+ __isthreaded = 0;
+ /*
+ * Restore signal mask early, so any memory problems could
+ * dump core.
+ */
+ sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
curthread->kse->k_kcb->kcb_kmbx.km_curthread = NULL;
- __isthreaded = 0;
- active_threads = 0;
+ active_threads = 1;
#endif
}
@@ -410,18 +418,13 @@ _kse_isthreaded(void)
int
_kse_setthreaded(int threaded)
{
- if ((threaded != 0) && (__isthreaded == 0)) {
- /*
- * Locking functions in libc are required when there are
- * threads other than the initial thread.
- */
- __isthreaded = 1;
+ sigset_t sigset;
+ if ((threaded != 0) && (__isthreaded == 0)) {
/*
* Tell the kernel to create a KSE for the initial thread
* and enable upcalls in it.
*/
- _thr_signal_init();
_kse_initial->k_flags |= KF_STARTED;
#ifdef SYSTEM_SCOPE_ONLY
@@ -433,7 +436,17 @@ _kse_setthreaded(int threaded)
KSE_SET_MBOX(_kse_initial, _thr_initial);
_kse_initial->k_kcb->kcb_kmbx.km_flags |= KMF_BOUND;
#endif
+ SIGFILLSET(sigset);
+ __sys_sigprocmask(SIG_SETMASK, &sigset, &_thr_initial->sigmask);
+ _thr_signal_init();
+
+ /*
+ * Locking functions in libc are required when there are
+ * threads other than the initial thread.
+ */
+ _thr_rtld_init();
+ __isthreaded = 1;
if (kse_create(&_kse_initial->k_kcb->kcb_kmbx, 0) != 0) {
_kse_initial->k_flags &= ~KF_STARTED;
__isthreaded = 0;
@@ -447,8 +460,9 @@ _kse_setthreaded(int threaded)
KSE_SET_MBOX(_kse_initial, _thr_initial);
_thr_start_sig_daemon();
_thr_setmaxconcurrency();
+#else
+ __sys_sigprocmask(SIG_SETMASK, &_thr_initial->sigmask, NULL);
#endif
-
}
return (0);
}
diff --git a/lib/libkse/thread/thr_sig.c b/lib/libkse/thread/thr_sig.c
index 77654de..782e3e7 100644
--- a/lib/libkse/thread/thr_sig.c
+++ b/lib/libkse/thread/thr_sig.c
@@ -1050,13 +1050,10 @@ thr_sigframe_save(struct pthread *thread, struct pthread_sigframe *psf)
void
_thr_signal_init(void)
{
- sigset_t sigset;
struct sigaction act;
__siginfohandler_t *sigfunc;
int i;
- SIGFILLSET(sigset);
- __sys_sigprocmask(SIG_SETMASK, &sigset, &_thr_initial->sigmask);
/* Enter a loop to get the existing signal status: */
for (i = 1; i <= _SIG_MAXSIG; i++) {
/* Check for signals which cannot be trapped: */
@@ -1078,7 +1075,8 @@ _thr_signal_init(void)
((__sighandler_t *)sigfunc) != SIG_IGN) {
act = _thread_sigact[i - 1];
act.sa_flags |= SA_SIGINFO;
- act.sa_sigaction = (__siginfohandler_t *)_thr_sig_handler;
+ act.sa_sigaction =
+ (__siginfohandler_t *)_thr_sig_handler;
__sys_sigaction(i, &act, NULL);
}
}
@@ -1097,21 +1095,13 @@ _thr_signal_init(void)
*/
PANIC("Cannot initialize signal handler");
}
-#ifdef SYSTEM_SCOPE_ONLY
- __sys_sigprocmask(SIG_SETMASK, &_thr_initial->sigmask, NULL);
-#endif
}
void
_thr_signal_deinit(void)
{
- struct pthread *curthread = _get_curthread();
- sigset_t tmpmask;
int i;
- SIGFILLSET(tmpmask);
- SIG_CANTMASK(tmpmask);
- __sys_sigprocmask(SIG_SETMASK, &tmpmask, NULL);
/* Enter a loop to get the existing signal status: */
for (i = 1; i <= _SIG_MAXSIG; i++) {
/* Check for signals which cannot be trapped: */
@@ -1119,7 +1109,8 @@ _thr_signal_deinit(void)
}
/* Set the signal handler details: */
- else if (__sys_sigaction(i, &_thread_sigact[i - 1], NULL) != 0) {
+ else if (__sys_sigaction(i, &_thread_sigact[i - 1],
+ NULL) != 0) {
/*
* Abort this process if signal
* initialisation fails:
@@ -1127,6 +1118,5 @@ _thr_signal_deinit(void)
PANIC("Cannot set signal handler info");
}
}
- __sys_sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
}
diff --git a/lib/libpthread/thread/thr_init.c b/lib/libpthread/thread/thr_init.c
index f9e0d9b..be3ad80 100644
--- a/lib/libpthread/thread/thr_init.c
+++ b/lib/libpthread/thread/thr_init.c
@@ -309,8 +309,6 @@ _libpthread_init(struct pthread *curthread)
_kcb_set(_thr_initial->kse->k_kcb);
_tcb_set(_thr_initial->kse->k_kcb, _thr_initial->tcb);
_thr_initial->kse->k_flags |= KF_INITIALIZED;
-
- _thr_rtld_init();
}
/*
diff --git a/lib/libpthread/thread/thr_kern.c b/lib/libpthread/thread/thr_kern.c
index 6b87dee..a940697 100644
--- a/lib/libpthread/thread/thr_kern.c
+++ b/lib/libpthread/thread/thr_kern.c
@@ -213,16 +213,17 @@ _kse_single_thread(struct pthread *curthread)
kse_critical_t crit;
int i;
-
- /*
- * Disable upcalls and clear the threaded flag.
- * XXX - I don't think we need to disable upcalls after a fork().
- * but it doesn't hurt.
- */
- crit = _kse_critical_enter();
+ if (__isthreaded) {
+ _thr_rtld_fini();
+ _thr_signal_deinit();
+ }
__isthreaded = 0;
+ /*
+ * Restore signal mask early, so any memory problems could
+ * dump core.
+ */
+ sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
active_threads = 1;
- _thr_signal_deinit();
/*
* Enter a loop to remove and free all threads other than
@@ -359,11 +360,18 @@ _kse_single_thread(struct pthread *curthread)
_kse_initial = NULL;
_libpthread_init(curthread);
#else
- if (__isthreaded)
+ if (__isthreaded) {
+ _thr_rtld_fini();
_thr_signal_deinit();
+ }
+ __isthreaded = 0;
+ /*
+ * Restore signal mask early, so any memory problems could
+ * dump core.
+ */
+ sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
curthread->kse->k_kcb->kcb_kmbx.km_curthread = NULL;
- __isthreaded = 0;
- active_threads = 0;
+ active_threads = 1;
#endif
}
@@ -410,18 +418,13 @@ _kse_isthreaded(void)
int
_kse_setthreaded(int threaded)
{
- if ((threaded != 0) && (__isthreaded == 0)) {
- /*
- * Locking functions in libc are required when there are
- * threads other than the initial thread.
- */
- __isthreaded = 1;
+ sigset_t sigset;
+ if ((threaded != 0) && (__isthreaded == 0)) {
/*
* Tell the kernel to create a KSE for the initial thread
* and enable upcalls in it.
*/
- _thr_signal_init();
_kse_initial->k_flags |= KF_STARTED;
#ifdef SYSTEM_SCOPE_ONLY
@@ -433,7 +436,17 @@ _kse_setthreaded(int threaded)
KSE_SET_MBOX(_kse_initial, _thr_initial);
_kse_initial->k_kcb->kcb_kmbx.km_flags |= KMF_BOUND;
#endif
+ SIGFILLSET(sigset);
+ __sys_sigprocmask(SIG_SETMASK, &sigset, &_thr_initial->sigmask);
+ _thr_signal_init();
+
+ /*
+ * Locking functions in libc are required when there are
+ * threads other than the initial thread.
+ */
+ _thr_rtld_init();
+ __isthreaded = 1;
if (kse_create(&_kse_initial->k_kcb->kcb_kmbx, 0) != 0) {
_kse_initial->k_flags &= ~KF_STARTED;
__isthreaded = 0;
@@ -447,8 +460,9 @@ _kse_setthreaded(int threaded)
KSE_SET_MBOX(_kse_initial, _thr_initial);
_thr_start_sig_daemon();
_thr_setmaxconcurrency();
+#else
+ __sys_sigprocmask(SIG_SETMASK, &_thr_initial->sigmask, NULL);
#endif
-
}
return (0);
}
diff --git a/lib/libpthread/thread/thr_sig.c b/lib/libpthread/thread/thr_sig.c
index 77654de..782e3e7 100644
--- a/lib/libpthread/thread/thr_sig.c
+++ b/lib/libpthread/thread/thr_sig.c
@@ -1050,13 +1050,10 @@ thr_sigframe_save(struct pthread *thread, struct pthread_sigframe *psf)
void
_thr_signal_init(void)
{
- sigset_t sigset;
struct sigaction act;
__siginfohandler_t *sigfunc;
int i;
- SIGFILLSET(sigset);
- __sys_sigprocmask(SIG_SETMASK, &sigset, &_thr_initial->sigmask);
/* Enter a loop to get the existing signal status: */
for (i = 1; i <= _SIG_MAXSIG; i++) {
/* Check for signals which cannot be trapped: */
@@ -1078,7 +1075,8 @@ _thr_signal_init(void)
((__sighandler_t *)sigfunc) != SIG_IGN) {
act = _thread_sigact[i - 1];
act.sa_flags |= SA_SIGINFO;
- act.sa_sigaction = (__siginfohandler_t *)_thr_sig_handler;
+ act.sa_sigaction =
+ (__siginfohandler_t *)_thr_sig_handler;
__sys_sigaction(i, &act, NULL);
}
}
@@ -1097,21 +1095,13 @@ _thr_signal_init(void)
*/
PANIC("Cannot initialize signal handler");
}
-#ifdef SYSTEM_SCOPE_ONLY
- __sys_sigprocmask(SIG_SETMASK, &_thr_initial->sigmask, NULL);
-#endif
}
void
_thr_signal_deinit(void)
{
- struct pthread *curthread = _get_curthread();
- sigset_t tmpmask;
int i;
- SIGFILLSET(tmpmask);
- SIG_CANTMASK(tmpmask);
- __sys_sigprocmask(SIG_SETMASK, &tmpmask, NULL);
/* Enter a loop to get the existing signal status: */
for (i = 1; i <= _SIG_MAXSIG; i++) {
/* Check for signals which cannot be trapped: */
@@ -1119,7 +1109,8 @@ _thr_signal_deinit(void)
}
/* Set the signal handler details: */
- else if (__sys_sigaction(i, &_thread_sigact[i - 1], NULL) != 0) {
+ else if (__sys_sigaction(i, &_thread_sigact[i - 1],
+ NULL) != 0) {
/*
* Abort this process if signal
* initialisation fails:
@@ -1127,6 +1118,5 @@ _thr_signal_deinit(void)
PANIC("Cannot set signal handler info");
}
}
- __sys_sigprocmask(SIG_SETMASK, &curthread->sigmask, NULL);
}
OpenPOWER on IntegriCloud