getpid.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /* Copyright (C) 2003, 2004 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. Contributed by Ulrich Drepper <drepper@redhat.com>, 2003.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, see
  14. <http://www.gnu.org/licenses/>. */
  15. #include <unistd.h>
  16. #include <tls.h>
  17. #include <sysdep.h>
  18. #ifdef __NR_getxpid
  19. # undef __NR_getpid
  20. # define __NR_getpid __NR_getxpid
  21. #endif
  22. #ifndef NOT_IN_libc
  23. static inline __attribute__((always_inline)) pid_t really_getpid (pid_t oldval);
  24. static inline __attribute__((always_inline)) pid_t
  25. really_getpid (pid_t oldval)
  26. {
  27. if (__builtin_expect (oldval == 0, 1))
  28. {
  29. pid_t selftid = THREAD_GETMEM (THREAD_SELF, tid);
  30. if (__builtin_expect (selftid != 0, 1))
  31. return selftid;
  32. }
  33. INTERNAL_SYSCALL_DECL (err);
  34. pid_t result = INTERNAL_SYSCALL (getpid, err, 0);
  35. /* We do not set the PID field in the TID here since we might be
  36. called from a signal handler while the thread executes fork. */
  37. if (oldval == 0)
  38. THREAD_SETMEM (THREAD_SELF, tid, result);
  39. return result;
  40. }
  41. #endif
  42. static pid_t
  43. __getpid (void)
  44. {
  45. #ifdef NOT_IN_libc
  46. INTERNAL_SYSCALL_DECL (err);
  47. pid_t result = INTERNAL_SYSCALL (getpid, err, 0);
  48. #else
  49. pid_t result = THREAD_GETMEM (THREAD_SELF, pid);
  50. if (__builtin_expect (result <= 0, 0))
  51. result = really_getpid (result);
  52. #endif
  53. return result;
  54. }
  55. weak_alias(__getpid, getpid)
  56. libc_hidden_weak(getpid)
  57. #if !defined NOT_IN_libc && !defined __NR_getppid
  58. strong_alias(getpid,getppid)
  59. #endif