summaryrefslogtreecommitdiffstats
path: root/net/opal
diff options
context:
space:
mode:
authorroger <roger@FreeBSD.org>2000-11-16 11:20:59 +0000
committerroger <roger@FreeBSD.org>2000-11-16 11:20:59 +0000
commitbd78c1bcec4d2493bd2ecd592980cd76d85c69f8 (patch)
tree7acb957c5d65621e8b7f6801e163e2095d328590 /net/opal
parent654f6517149ae64e313bf8fa126dae2c12e4e67c (diff)
downloadFreeBSD-ports-bd78c1bcec4d2493bd2ecd592980cd76d85c69f8.zip
FreeBSD-ports-bd78c1bcec4d2493bd2ecd592980cd76d85c69f8.tar.gz
Add a better fix to make OpenH323 run on FreeBSD 4.2 and on -current
with the new libc_r pthread library
Diffstat (limited to 'net/opal')
-rw-r--r--net/opal/files/patch-aa76
1 files changed, 24 insertions, 52 deletions
diff --git a/net/opal/files/patch-aa b/net/opal/files/patch-aa
index ff2796c..cf26210 100644
--- a/net/opal/files/patch-aa
+++ b/net/opal/files/patch-aa
@@ -1,57 +1,29 @@
-*** ../pwlib/src/ptlib/unix/tlibthrd.cxx.orig Sun Nov 12 08:22:06 2000
---- ../pwlib/src/ptlib/unix/tlibthrd.cxx Sun Nov 12 08:22:17 2000
-*************** static void sigSuspendHandler(int)
-*** 261,266 ****
---- 261,273 ----
- }
-
-
-+ static void sigResumeHandler(int)
-+ {
-+ // do nothing. This is here so the 'signal' is consumed
-+ // and stops the application terminating with "User signal 2"
-+ }
-+
-+
- void HouseKeepingThread::Main()
- {
- PProcess & process = PProcess::Current();
-*************** void * PThread::PX_ThreadStart(void * ar
-*** 437,446 ****
- }
-
- // set the signal handler for SUSPEND_SIG
-! struct sigaction action;
-! memset(&action, 0, sizeof(action));
-! action.sa_handler = sigSuspendHandler;
-! sigaction(SUSPEND_SIG, &action, 0);
-
- // now call the the thread main routine
- //PTRACE(1, "tlibthrd\tAbout to call Main");
---- 444,453 ----
- }
-
- // set the signal handler for SUSPEND_SIG
-! struct sigaction suspend_action;
-! memset(&suspend_action, 0, sizeof(suspend_action));
-! suspend_action.sa_handler = sigSuspendHandler;
-! sigaction(SUSPEND_SIG, &suspend_action, 0);
-
- // now call the the thread main routine
- //PTRACE(1, "tlibthrd\tAbout to call Main");
-*************** void PThread::Suspend(BOOL susp)
-*** 559,564 ****
---- 566,578 ----
- {
- PAssertOS(pthread_mutex_lock(&PX_suspendMutex) == 0);
- BOOL unlock = TRUE;
+*** ../pwlib/src/ptlib/unix/tlibthrd.cxx.orig Thu Nov 16 11:14:48 2000
+--- ../pwlib/src/ptlib/unix/tlibthrd.cxx Thu Nov 16 11:15:21 2000
+*************** void PThread::PX_NewThread(BOOL startSus
+*** 386,391 ****
+--- 386,409 ----
+ // pthread_attr_t threadAttr;
+ // pthread_attr_init(&threadAttr);
+ PAssertOS(pthread_create(&PX_threadId, NULL, PX_ThreadStart, this) == 0);
+
+ #if defined(P_FREEBSD)
-+ struct sigaction resume_action;
-+ memset(&resume_action, 0, sizeof(resume_action));
-+ resume_action.sa_handler = sigResumeHandler;
-+ sigaction(RESUME_SIG, &resume_action, 0);
++ // There is a potential race condition here which shows up with FreeBSD 4.2
++ // and later, but really applies to all pthread libraries.
++ // If a thread is started in suspend mode, we need to make sure
++ // the thread (PX_ThreadStart) has had a chance to execute and block on the
++ // sigwait() (blocking on the Resume Signal) before this function returns.
++ // Otherwise the main program may issue a Resume Signal on the thread
++ // by calling PThread::Resume() before the thread is ready for it.
++ // If that happens the program will abort with an unhandled signal error.
++ // A workaround (not 100% guaranteed) is to yield here, which gives
++ // the newly created thread (PX_ThreadStart) a chance to execute.
++
++ if (startSuspended) {
++ sched_yield();
++ }
+ #endif
++
+ }
- if (pthread_kill(PX_threadId, 0) == 0) {
OpenPOWER on IntegriCloud