2.9
[glibc/nacl-glibc.git] / nptl / sysdeps / unix / sysv / linux / sh / vfork.S
blob5433eacbe9e3199a8877551af334819fd96d1050
1 /* Copyright (C) 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.  */
19 #include <sysdep.h>
20 #define _ERRNO_H        1
21 #include <bits/errno.h>
22 #include <tcb-offsets.h>
24 /* Clone the calling process, but without copying the whole address space.
25    The calling process is suspended until the new process exits or is
26    replaced by a call to `execve'.  Return -1 for errors, 0 to the new process,
27    and the process ID of the new process to the old process.  */
29 ENTRY (__vfork)
30         /* Save the PID value.  */
31         stc     gbr, r2
32         mov.w   .L2, r0
33         mov.l   @(r0,r2), r4
34         neg     r4, r1
35         tst     r1, r1
36         bf      1f
37         mov     #1, r1
38         rotr    r1
40         mov.l   r1, @(r0,r2)
42         mov.w   .L1, r3
43         trapa   #0x10
44         mov     r0, r1
46         /* Restore the old PID value in the parent.  */
47         tst     r0, r0
48         bt.s    2f
49          stc    gbr, r2
50         mov.w   .L2, r0
51         mov.l   r4, @(r0,r2)
52         mov     r1, r0
54         mov     #-12, r2
55         shad    r2, r1
56         not     r1, r1                  // r1=0 means r0 = -1 to -4095
57         tst     r1, r1                  // i.e. error in linux
58         bf      .Lpseudo_end
59         SYSCALL_ERROR_HANDLER
60 .Lpseudo_end:
61         rts
62          nop
63 .L1:
64         .word   __NR_vfork
65 .L2:
66         .word   PID - TLS_PRE_TCB_SIZE
67         .align  2
68 PSEUDO_END (__vfork)
69 libc_hidden_def (__vfork)
71 weak_alias (__vfork, vfork)