summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-12-20 09:58:33 +0000
committerUlrich Drepper <drepper@redhat.com>2003-12-20 09:58:33 +0000
commitbbe35eb57144c081d10e76e35e52e9b400202b72 (patch)
treed3b9790c597dffef635cbce1e01f983e6fc41a98
parent4efdd8d355a378ab85278bef1c00c05c46ab49e4 (diff)
downloadglibc-bbe35eb57144c081d10e76e35e52e9b400202b72.tar.gz
Update.
2003-12-20 Ulrich Drepper <drepper@redhat.com> * sysdeps/unix/sysv/linux/Makefile (CFLAGS-getpid.c): Define. * sysdeps/unix/sysv/linux/getpid.c: New file.
-rw-r--r--elf/rtld.c2
-rw-r--r--nptl/ChangeLog5
-rw-r--r--nptl/sysdeps/unix/sysv/linux/Makefile1
-rw-r--r--nptl/sysdeps/unix/sysv/linux/getpid.c44
4 files changed, 51 insertions, 1 deletions
diff --git a/elf/rtld.c b/elf/rtld.c
index a0a50b10de..392ccb6dcb 100644
--- a/elf/rtld.c
+++ b/elf/rtld.c
@@ -1310,7 +1310,7 @@ of this helper program; chances are you did not intend to run this program.\n\
an old kernel that can't perform TLS_INIT_TP, even if no TLS is ever
used. Trying to do it lazily is too hairy to try when there could be
multiple threads (from a non-TLS-using libpthread). */
- if (GL(dl_tls_max_dtv_idx) > 0 || !TLS_INIT_TP_EXPENSIVE)
+ if (!TLS_INIT_TP_EXPENSIVE || GL(dl_tls_max_dtv_idx) > 0)
{
struct link_map *l;
size_t nelem;
diff --git a/nptl/ChangeLog b/nptl/ChangeLog
index 83d6635c25..5e81694058 100644
--- a/nptl/ChangeLog
+++ b/nptl/ChangeLog
@@ -1,3 +1,8 @@
+2003-12-20 Ulrich Drepper <drepper@redhat.com>
+
+ * sysdeps/unix/sysv/linux/Makefile (CFLAGS-getpid.c): Define.
+ * sysdeps/unix/sysv/linux/getpid.c: New file.
+
2003-12-19 Ulrich Drepper <drepper@redhat.com>
* eintr.c (setup_eintr): Add new parameter. Pass to thread function.
diff --git a/nptl/sysdeps/unix/sysv/linux/Makefile b/nptl/sysdeps/unix/sysv/linux/Makefile
index c2988bc902..ef0b25c605 100644
--- a/nptl/sysdeps/unix/sysv/linux/Makefile
+++ b/nptl/sysdeps/unix/sysv/linux/Makefile
@@ -29,4 +29,5 @@ endif
ifeq ($(subdir),posix)
CFLAGS-fork.c = -D_IO_MTSAFE_IO
+CFLAGS-getpid.c = -fomit-frame-pointer
endif
diff --git a/nptl/sysdeps/unix/sysv/linux/getpid.c b/nptl/sysdeps/unix/sysv/linux/getpid.c
new file mode 100644
index 0000000000..75decc1385
--- /dev/null
+++ b/nptl/sysdeps/unix/sysv/linux/getpid.c
@@ -0,0 +1,44 @@
+/* Copyright (C) 2003 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@redhat.com>, 2003.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ The GNU C Library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <unistd.h>
+#include <tls.h>
+#include <sysdep.h>
+
+
+pid_t
+__getpid (void)
+{
+ pid_t result;
+#ifndef NOT_IN_libc
+ result = THREAD_GETMEM (THREAD_SELF, pid);
+ if (__builtin_expect (result == 0, 0))
+#endif
+ {
+ INTERNAL_SYSCALL_DECL (err);
+ result = INTERNAL_SYSCALL (getpid, err, 0);
+#ifndef NOT_IN_libc
+ THREAD_SETMEM (THREAD_SELF, pid, result);
+#endif
+ }
+ return result;
+}
+libc_hidden_def (__getpid)
+weak_alias (__getpid, getpid)
+libc_hidden_def (getpid)