mirror of
git://sourceware.org/git/glibc.git
synced 2024-12-15 04:20:28 +08:00
Simplify getpid handling of the race case.
This commit is contained in:
parent
0a982a2905
commit
681467942d
@ -1,3 +1,10 @@
|
||||
2014-05-09 Roland McGrath <roland@hack.frob.com>
|
||||
|
||||
* nptl/sysdeps/unix/sysv/linux/getpid.c
|
||||
(really_getpid): Function removed.
|
||||
(__getpid): Rewritten. Under [!NOT_IN_libc], use THREAD_SELF->pid if
|
||||
it's > 0. Otherwise always just make the system call.
|
||||
|
||||
2014-05-09 Roland McGrath <roland@hack.frob.com>
|
||||
|
||||
* sysdeps/arm/armv7/strcmp.S: Use sfi_breg prefix on loads not from sp.
|
||||
|
@ -21,42 +21,17 @@
|
||||
#include <sysdep.h>
|
||||
|
||||
|
||||
#ifndef NOT_IN_libc
|
||||
static inline __attribute__((always_inline)) pid_t really_getpid (pid_t oldval);
|
||||
|
||||
static inline __attribute__((always_inline)) pid_t
|
||||
really_getpid (pid_t oldval)
|
||||
{
|
||||
if (__glibc_likely (oldval == 0))
|
||||
{
|
||||
pid_t selftid = THREAD_GETMEM (THREAD_SELF, tid);
|
||||
if (__glibc_likely (selftid != 0))
|
||||
return selftid;
|
||||
}
|
||||
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
pid_t result = INTERNAL_SYSCALL (getpid, err, 0);
|
||||
|
||||
/* We do not set the PID field in the TID here since we might be
|
||||
called from a signal handler while the thread executes fork. */
|
||||
if (oldval == 0)
|
||||
THREAD_SETMEM (THREAD_SELF, tid, result);
|
||||
return result;
|
||||
}
|
||||
#endif
|
||||
|
||||
pid_t
|
||||
__getpid (void)
|
||||
{
|
||||
#ifdef NOT_IN_libc
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
pid_t result = INTERNAL_SYSCALL (getpid, err, 0);
|
||||
#else
|
||||
#ifndef NOT_IN_libc
|
||||
pid_t result = THREAD_GETMEM (THREAD_SELF, pid);
|
||||
if (__glibc_unlikely (result <= 0))
|
||||
result = really_getpid (result);
|
||||
if (__glibc_likely (result > 0))
|
||||
return result;
|
||||
#endif
|
||||
return result;
|
||||
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
return INTERNAL_SYSCALL (getpid, err, 0);
|
||||
}
|
||||
|
||||
libc_hidden_def (__getpid)
|
||||
|
Loading…
Reference in New Issue
Block a user