Both of the patches below fix the problem mentioned in PR bin/25110. The
first one fixes it inside of kern_fork.c and would appear to apply the
corrective behaviour regardless of whether the process uses libc_r or not.
The second patch fixes the problem inside of uthread_fork.c. Whether the
first approach imposes an extra cost on non-threaded applications I'm not
kernel-experienced enough to say, but hopefully between two of you gents you
can decide which is the better fix to apply.
As I mentioned in my original post, this is a bug that we are experiencing
in 4.3-BETA, so if this could make it into 4.3-RELEASE it would be of great
help. One note regarding the second (libc_r) patch: the reference to
__sys_sigaltstack needs to be changed to _thread_sys_sigaltstack in order to
prevent undefined symbols on 4.x systems.
Patch #1 (kernel fix):
--- kern_fork.c.orig Sat Mar 10 12:17:40 2001
+++ kern_fork.c Sat Mar 10 12:20:39 2001
@@ -434,7 +434,7 @@
* Preserve some more flags in subprocess. P_PROFIL has already
* been preserved.
*/
- p2->p_flag |= p1->p_flag & P_SUGID;
+ p2->p_flag |= p1->p_flag & (P_SUGID | P_ALTSTACK);
if (p1->p_session->s_ttyvp != NULL && p1->p_flag & P_CONTROLT)
p2->p_flag |= P_CONTROLT;
if (flags & RFPPWAIT)
Patch #2 (libc_r fix):
--- uthread_fork.c 2001/01/24 13:03:33 1.21
+++ uthread_fork.c 2001/03/09 17:53:37
+
@@ -32,6 +32,7 @@
* $FreeBSD: src/lib/libc_r/uthread/uthread_fork.c,v 1.21 2001/01/24 13:03:33
deischen Exp $
*/
#include <errno.h>
+#include <signal.h>
+
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
@@ -110,7 +111,16 @@
else if (_pq_init(&_readyq) != 0) {
/* Abort this application: */
PANIC("Cannot initialize priority ready queue.");
- } else {
+ } else if ((_thread_sigstack.ss_sp == NULL) &&
+
+ ((_thread_sigstack.ss_sp = malloc(SIGSTKSZ)) == NULL))
+
+ PANIC("Unable to allocate alternate signal stack");
+
+ else {
+
+ /* Install the alternate signal stack: */
+
+ _thread_sigstack.ss_size = SIGSTKSZ;
+
+ _thread_sigstack.ss_flags = 0;
+
+ if (__sys_sigaltstack(&_thread_sigstack, NULL) != 0)
+
+ PANIC("Unable to install alternate signal stack");
+
+
+
/*
* Enter a loop to remove all threads other than
* the running thread from the thread list:
Thanks for the help guys.
--
j.
To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-current" in the body of the message