summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2009-11-22 11:43:57 -0800
committerPetr Baudis <pasky@ucw.cz>2009-12-04 14:45:00 +0100
commit93721a641a55a943363149ed6a77eea4668878ce (patch)
treebc192cf9b07b26ae365dbf6f8e8b7a94f9169c80
parent8d7c09b162cd1687e21549f9aaaa3d4a9b39735c (diff)
Reinitialize _create_xid state after fork.
Programs forking and using RPC in the forks would use the same XIDs. (cherry picked from commit c5a8b997e2de005697a992d8db5c54995bd361a8)
-rw-r--r--ChangeLog4
-rw-r--r--sunrpc/create_xid.c12
2 files changed, 11 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index e0fd11c15e..143c45af39 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2009-11-22 Ulrich Drepper <drepper@redhat.com>
+
+ * sunrpc/create_xid.c (_create_xid): Reinitialize state after fork.
+
2009-11-18 H.J. Lu <hongjiu.lu@intel.com>
[BZ #10162]
diff --git a/sunrpc/create_xid.c b/sunrpc/create_xid.c
index 4e76918644..c247568cee 100644
--- a/sunrpc/create_xid.c
+++ b/sunrpc/create_xid.c
@@ -1,4 +1,4 @@
-/* Copyright (c) 1998, 2000 Free Software Foundation, Inc.
+/* Copyright (c) 1998, 2000, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1998.
@@ -27,7 +27,7 @@
__libc_lock_define_initialized (static, createxid_lock)
-static int is_initialized;
+static pid_t is_initialized;
static struct drand48_data __rpc_lrand48_data;
unsigned long
@@ -37,13 +37,15 @@ _create_xid (void)
__libc_lock_lock (createxid_lock);
- if (!is_initialized)
+ pid_t pid = getpid ();
+ if (is_initialized != pid)
{
struct timeval now;
__gettimeofday (&now, (struct timezone *) 0);
- __srand48_r (now.tv_sec ^ now.tv_usec, &__rpc_lrand48_data);
- is_initialized = 1;
+ __srand48_r (now.tv_sec ^ now.tv_usec ^ pid,
+ &__rpc_lrand48_data);
+ is_initialized = pid;
}
lrand48_r (&__rpc_lrand48_data, &res);