From 2586dcb94837b5992fd5265db7760eab0ac0c7b5 Mon Sep 17 00:00:00 2001 From: kurt Date: Fri, 22 Jun 2007 13:37:58 +0000 Subject: [PATCH] Fix a deadlock seen in thunderbird w/engimail caused by safe_pclose() returning without waiting for the child process to complete which causes a deadlock between nspr's WaitPidDaemonThread() and PR_WaitProcess(). Reported upstream w/more details: https://bugzilla.mozilla.org/show_bug.cgi?id=385465 okay martynas@ --- security/nss/Makefile | 3 +- ...ozilla_security_nss_lib_freebl_unix_rand_c | 33 +++++++++++++++++++ 2 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 security/nss/patches/patch-mozilla_security_nss_lib_freebl_unix_rand_c diff --git a/security/nss/Makefile b/security/nss/Makefile index 74fc365a7e4..76c3c86f8c8 100644 --- a/security/nss/Makefile +++ b/security/nss/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.5 2007/03/26 20:45:44 martynas Exp $ +# $OpenBSD: Makefile,v 1.6 2007/06/22 13:37:58 kurt Exp $ SHARED_ONLY= Yes @@ -6,6 +6,7 @@ COMMENT= "libraries to support development of security-enabled apps" VERSION= 3.11.5 DISTNAME= nss-${VERSION} +PKGNAME= ${DISTNAME}p0 SO_VERSION= 19.0 .for _lib in freebl3 nss3 nssckbi smime3 softokn3 ssl3 SHARED_LIBS+= ${_lib} ${SO_VERSION} diff --git a/security/nss/patches/patch-mozilla_security_nss_lib_freebl_unix_rand_c b/security/nss/patches/patch-mozilla_security_nss_lib_freebl_unix_rand_c new file mode 100644 index 00000000000..54a7d3b406f --- /dev/null +++ b/security/nss/patches/patch-mozilla_security_nss_lib_freebl_unix_rand_c @@ -0,0 +1,33 @@ +$OpenBSD: patch-mozilla_security_nss_lib_freebl_unix_rand_c,v 1.1 2007/06/22 13:37:58 kurt Exp $ +--- mozilla/security/nss/lib/freebl/unix_rand.c.orig Thu Jun 21 14:25:55 2007 ++++ mozilla/security/nss/lib/freebl/unix_rand.c Thu Jun 21 14:41:25 2007 +@@ -843,21 +843,19 @@ safe_popen(char *cmd) + static int + safe_pclose(FILE *fp) + { +- pid_t pid; +- int count, status; ++ pid_t pid, ret; ++ int status; + + if ((pid = safe_popen_pid) == 0) + return -1; + safe_popen_pid = 0; + +- /* if the child hasn't exited, kill it -- we're done with its output */ +- count = 0; +- while (waitpid(pid, &status, WNOHANG) == 0) { +- if (kill(pid, SIGKILL) < 0 && errno == ESRCH) +- break; +- if (++count == 1000) +- break; +- } ++ /* kill the child in case it hasn't exited -- we're done with its output */ ++ kill(pid, SIGKILL); ++ ++ do { ++ ret = waitpid(pid, &status, 0); ++ } while (ret == (pid_t) -1 && errno == EINTR); + + /* Reset SIGCHLD signal hander before returning */ + sigaction(SIGCHLD, &oldact, NULL);