2 * Copyright (c) 1999-2007 Apple Inc. All rights reserved.
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
31 #if defined(__ppc__) || defined(__ppc64__)
39 MI_ENTRY_POINT(___getpid)
40 #if defined(__DYNAMIC__)
41 mflr r0 // note we cannot use MI_GET_ADDRESS...
42 bcl 20,31,1f // ...because we define __current_pid
46 addis r5, r5, ha16(__current_pid - 1b)
47 addi r5, r5, lo16(__current_pid - 1b)
49 lis r5,hi16(__current_pid)
50 ori r5,r5,lo16(__current_pid)
52 lwz r3,0(r5) // get the cached pid
53 cmpwi r3,0 // if positive,
56 SYSCALL_NONAME(getpid, 0)
58 lwarx r4,0,r5 // see if we can cache it
59 cmpwi r4,0 // we can't if there are any...
60 blt-- 1f // ...vforks in progress
62 stwcx. r3,0,r5 // ignore cache conflicts
65 li r6,-4 // on 970, cancel the reservation using red zone...
66 stwcx. r3,r6,r1 // ...to avoid an errata
69 #elif defined(__i386__)
72 .private_extern __current_pid
75 L__current_pid_addr = __current_pid
77 #if defined(__DYNAMIC__)
78 #define GET_CURRENT_PID \
82 leal L__current_pid_addr-0b(%ecx), %ecx
84 #define __current_pid (%ecx)
87 #define GET_CURRENT_PID
91 * If __current_pid is > 0, return it, else make syscall.
92 * If __current_pid is 0, cache result of syscall.
97 movl __current_pid, %eax
102 UNIX_SYSCALL_NONAME(getpid, 0)
107 cmpxchgl %edx, __current_pid
111 #elif defined(__x86_64__)
114 .private_extern __current_pid
119 * If __current_pid is > 0, return it, else make syscall.
120 * If __current_pid is 0, cache result of syscall.
124 movl __current_pid(%rip), %eax
129 UNIX_SYSCALL_NONAME(getpid, 0)
132 leaq __current_pid(%rip), %rcx
134 cmpxchgl %edx, (%rcx)
139 #error Unsupported architecture