| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 | /* vi: set sw=4 ts=4: *//* * vfork for uClibc * Copyright (C) 2000-2006 by Erik Andersen <andersen@uclibc.org> * Licensed under the LGPL v2.1, see the file COPYING.LIB in this tarball. */#include <features.h>#include <bits/arm_asm.h>#define _ERRNO_H#include <bits/errno.h>#include <sys/syscall.h>#ifdef __NR_fork.text.global	__vfork.hidden	__vfork.type	__vfork,%function.align 4#if defined(__thumb__) && !defined(__thumb2__).thumb_func__vfork:#ifdef __NR_vfork	DO_CALL (vfork)	ldr		r1, =0xfffff000	cmp		r0, r1	bcs		1f	bx		lr1:	/* Check if vfork even exists.  */	ldr		r1, =-ENOSYS	cmp		r0, r1	bne		__error	/* If we don't have vfork, use fork.  */	DO_CALL (fork)	ldr		r1, =0xfffff000	cmp		r0, r1	/* Syscall worked.  Return to child/parent */	bcs		1f	bx		lr1:__error:	push	{r3, lr}	bl	__syscall_error	POP_RET.pool#endif#else__vfork:#ifdef __NR_vfork	DO_CALL (vfork)	cmn	r0, #4096	IT(t, cc)#if defined(__USE_BX__)	bxcc	lr#else	movcc	pc, lr#endif	/* Check if vfork even exists.  */	ldr     r1, =-ENOSYS	teq     r0, r1	bne     __error#endif	/* If we don't have vfork, use fork.  */	DO_CALL (fork)	cmn     r0, #4096	/* Syscall worked.  Return to child/parent */	IT(t, cc)#if defined(__USE_BX__)	bxcc	lr#else	movcc   pc, lr#endif__error:	b	__syscall_error#endif.size __vfork,.-__vforkweak_alias(__vfork,vfork)libc_hidden_weak(vfork)#endif
 |