Properly handle PID cache.
authordrepper <drepper>
Wed, 10 Mar 2004 18:43:03 +0000 (18:43 +0000)
committerdrepper <drepper>
Wed, 10 Mar 2004 18:43:03 +0000 (18:43 +0000)
nptl/sysdeps/unix/sysv/linux/ia64/pt-vfork.S

index a8e2e49..f59227c 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2000, 2002, 2003 Free Software Foundation, Inc.
+/* Copyright (C) 2000, 2002, 2003, 2004 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
 ENTRY(__vfork)
        .prologue       // work around a GAS bug which triggers if
        .body           // first .prologue is not at the beginning of proc.
-       alloc r2=ar.pfs,0,0,2,0
+       alloc r2=ar.pfs,0,1,2,0
+       adds r14=PID,r13
+       ;; 
+       ld4 loc0=[r14]
+       ;;
+       sub r15=0,loc0
        mov out0=CLONE_VM+CLONE_VFORK+SIGCHLD
        mov out1=0              /* Standard sp value.                   */
        ;;
+       st4 [r14]=r15
        DO_CALL (SYS_ify (clone))
+       cmp.eq p0,p7=0,r8
        cmp.eq p6,p0=-1,r10
+       adds r14=PID,r13
        ;;
+(p7)   st4 [r14]=loc0
 (p6)   br.cond.spnt.few __syscall_error
        ret
 PSEUDO_END(__vfork)