OSDN Git Service

935a4e904cdd256570516fcb3aba5b0eab501dd4
[uclinux-h8/uClibc.git] / libpthread / nptl / sysdeps / unix / sysv / linux / arm / vfork.S
1 /* Copyright (C) 2005 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3
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
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.
13
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.  */
18
19 #include <tcb-offsets.h>
20
21 /* Save the PID value.  */
22 #define SAVE_PID \
23         str     lr, [sp, #-4]!;         /* Save LR.  */                 \
24         mov     r0, #0xffff0fff;        /* Point to the high page.  */  \
25         mov     lr, pc;                 /* Save our return address.  */ \
26         sub     pc, r0, #31;            /* Jump to the TLS entry.  */   \
27         ldr     lr, [sp], #4;           /* Restore LR.  */              \
28         mov     r2, r0;                 /* Save the TLS addr in r2.  */ \
29         ldr     r3, [r2, #PID_OFFSET];  /* Load the saved PID.  */      \
30         rsbs    r0, r3, #0;             /* Negate it.  */               \
31         moveq   r0, #0x80000000;        /* Use 0x80000000 if it was 0.  */ \
32         str     r0, [r2, #PID_OFFSET]   /* Store the temporary PID.  */
33
34 /* Restore the old PID value in the parent.  */
35 #define RESTORE_PID \
36         cmp     r0, #0;                 /* If we are the parent... */   \
37         strne   r3, [r2, #PID_OFFSET]   /* ... restore the saved PID.  */
38
39 #include "../../../../../../../libc/sysdeps/linux/arm/vfork.S"