about summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2009-11-22 11:43:57 -0800
committerUlrich Drepper <drepper@redhat.com>2009-11-22 11:43:57 -0800
commitc5a8b997e2de005697a992d8db5c54995bd361a8 (patch)
tree6c6b319e6e4da4a26175aec669ffd9104809909d
parenteb4157390cac6212921ef198353635e138dc0a00 (diff)
downloadglibc-c5a8b997e2de005697a992d8db5c54995bd361a8.tar.gz
glibc-c5a8b997e2de005697a992d8db5c54995bd361a8.tar.xz
glibc-c5a8b997e2de005697a992d8db5c54995bd361a8.zip
Reinitialize _create_xid state after fork.
Programs forking and using RPC in the forks would use the same XIDs.
-rw-r--r--ChangeLog2
-rw-r--r--sunrpc/create_xid.c12
2 files changed, 9 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index 4d3bd8043b..9a733519ae 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
 2009-11-22  Ulrich Drepper  <drepper@redhat.com>
 
+	* sunrpc/create_xid.c (_create_xid): Reinitialize state after fork.
+
 	* sysdeps/unix/sysv/linux/ntp_gettimex.c:  New file.
 	* sysdeps/unix/sysv/linux/Makefile: Add rules to build ntp_gettimex.
 	* sysdeps/unix/sysv/linux/Versions: Export ntp_gettimex for GLIBC_2.12.
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);