2.9
[glibc/nacl-glibc.git] / nptl / sysdeps / unix / sysv / linux / ia64 / pt-vfork.S
bloba285280038eaf12880aff6c4429f31e56c55a0fc
1 /* Copyright (C) 2000, 2002, 2003, 2004 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
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.
9    The GNU C Library is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12    Lesser General Public License for more details.
14    You should have received a copy of the GNU Lesser General Public
15    License along with the GNU C Library; if not, write to the Free
16    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
17    02111-1307 USA.  */
20 #include <sysdep.h>
21 #define _SIGNAL_H
22 #include <bits/signum.h>
23 #include <tcb-offsets.h>
25 /* The following are defined in linux/sched.h, which unfortunately      */
26 /* is not safe for inclusion in an assembly file.                       */
27 #define CLONE_VM        0x00000100      /* set if VM shared between processes */
28 #define CLONE_VFORK     0x00004000      /* set if the parent wants the child to wake it up on mm_release */
30 /* pid_t vfork(void); */
31 /* Implemented as __clone_syscall(CLONE_VFORK | CLONE_VM | SIGCHLD, 0)  */
33 ENTRY(__vfork)
34         .prologue       // work around a GAS bug which triggers if
35         .body           // first .prologue is not at the beginning of proc.
36         alloc r2=ar.pfs,0,0,2,0
37         adds r14=PID,r13
38         ;;
39         ld4 r16=[r14]
40         ;;
41         sub r15=0,r16
42         mov out0=CLONE_VM+CLONE_VFORK+SIGCHLD
43         mov out1=0              /* Standard sp value.                   */
44         ;;
45         st4 [r14]=r15
46         DO_CALL (SYS_ify (clone))
47         cmp.eq p0,p7=0,r8
48         adds r14=PID,r13
49         ;;
50 (p7)    ld4 r16=[r14]
51         cmp.eq p6,p0=-1,r10
52         ;;
53 (p7)    sub r15=0,r16
54         ;;
55 (p7)    st4 [r14]=r15
56 (p6)    br.cond.spnt.few __syscall_error
57         ret
58 PSEUDO_END(__vfork)
60 weak_alias (__vfork, vfork)