diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-04-12 17:52:14 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-04-12 17:52:14 -0400 |
commit | e2915eeeea244d3818d5eb7532ed35c6cf43c8fd (patch) | |
tree | 9b4038abca8971234ef2d63d9cabef950c6229c7 /src/process | |
parent | 0913560a3ffd4572d926b4f9bed3dbf3e6a1b3f0 (diff) | |
download | musl-e2915eeeea244d3818d5eb7532ed35c6cf43c8fd.tar.gz musl-e2915eeeea244d3818d5eb7532ed35c6cf43c8fd.tar.xz musl-e2915eeeea244d3818d5eb7532ed35c6cf43c8fd.zip |
speed up threaded fork
after fork, we have a new process and the pid is equal to the tid of the new main thread. there is no need to make two separate syscalls to obtain the same number.
Diffstat (limited to 'src/process')
-rw-r--r-- | src/process/fork.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/src/process/fork.c b/src/process/fork.c index 012b7ca5..07fb79ed 100644 --- a/src/process/fork.c +++ b/src/process/fork.c @@ -10,8 +10,7 @@ pid_t fork(void) ret = syscall(SYS_fork); if (libc.lock && !ret) { pthread_t self = __pthread_self(); - self->pid = syscall(SYS_getpid); - self->tid = syscall(SYS_gettid); + self->tid = self->pid = syscall(SYS_getpid); libc.threads_minus_1 = 0; } if (libc.fork_handler) libc.fork_handler(!ret); |