2.9
[glibc/nacl-glibc.git] / nptl / sysdeps / unix / sysv / linux / alpha / vfork.S
blobf4ed9311b081f902f51090e95be9912ad7a0a833
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 #include <tcb-offsets.h>
22 #undef PSEUDO_PREPARE_ARGS
23 #define PSEUDO_PREPARE_ARGS                                             \
24         /* Load the current cached pid value across the vfork.  */      \
25         rduniq;                                                         \
26         ldl     a2, PID_OFFSET(v0);                                     \
27         mov     v0, a1;                                                 \
28         /* If the cached value is initialized (nonzero), then write     \
29            back its negation, or INT_MIN, to indicate that the pid      \
30            value is uninitialized in the the child, and in the window   \
31            between here and the point at which we restore the value.  */ \
32         ldah    t0, -0x8000;                                            \
33         negl    a2, t1;                                                 \
34         cmovne  a2, t1, t0;                                             \
35         stl     t0, PID_OFFSET(v0);
37 PSEUDO (__vfork, vfork, 0)
39         /* If we're back in the parent, restore the saved pid.  */
40         beq     v0, 1f
41         stl     a2, PID_OFFSET(a1)
42 1:      ret
44 PSEUDO_END (__vfork)
45 libc_hidden_def (__vfork)
46 weak_alias (__vfork, vfork)