mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-26 00:57:39 +03:00 
			
		
		
		
	2001-07-06 Paul Eggert <eggert@twinsun.com> * manual/argp.texi: Remove ignored LGPL copyright notice; it's not appropriate for documentation anyway. * manual/libc-texinfo.sh: "Library General Public License" -> "Lesser General Public License". 2001-07-06 Andreas Jaeger <aj@suse.de> * All files under GPL/LGPL version 2: Place under LGPL version 2.1.
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* Copyright (C) 2001 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
 | |
|    modify it under the terms of the GNU Lesser General Public
 | |
|    License as published by the Free Software Foundation; either
 | |
|    version 2.1 of the License, or (at your option) any later version.
 | |
| 
 | |
|    The GNU C Library is distributed in the hope that it will be useful,
 | |
|    but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|    Lesser General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU Lesser General Public
 | |
|    License along with the GNU C Library; if not, write to the Free
 | |
|    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
 | |
|    02111-1307 USA.  */
 | |
| 
 | |
| #include <sysdep.h>
 | |
| #define _ERRNO_H	1
 | |
| #include <bits/errno.h>
 | |
| 
 | |
| /* int clone(int (*fn)(void *arg), void *child_stack, int flags, void *arg); */
 | |
| 
 | |
| 	.syntax no_register_prefix
 | |
| 
 | |
|         .text
 | |
| ENTRY (__clone)
 | |
| 	/* Sanity check arguments: No NULL function pointers.  Allow a NULL
 | |
| 	   stack pointer though; it makes the kernel allocate stack.  */
 | |
| 	test.d	r10
 | |
| 	beq	1f
 | |
| 	nop
 | |
| 
 | |
| 	/* We need to muck with a few registers.  */
 | |
| 	movem	r1,[sp=sp-8]
 | |
| 
 | |
| 	/* Save the function pointer and argument.  We can't save them
 | |
| 	   onto the new stack since it can be NULL.  */
 | |
| 	move.d	r10,r0
 | |
| 	move.d	r13,r1
 | |
| 
 | |
|         /* Move the other arguments into place for the system call.  */
 | |
| 	move.d	r11,r10
 | |
| 	move.d	r12,r11
 | |
| 
 | |
| 	/* Do the system call.  */
 | |
| 	movu.w	SYS_ify (clone),r9
 | |
| 	break	13
 | |
| 	test.d	r10
 | |
| 	beq	.Lthread_start
 | |
| 	nop
 | |
| 
 | |
| 	/* Jump to error handler if we get (unsigned) -4096 .. 0xffffffff.  */
 | |
| 	cmps.w	-4096,r10
 | |
| 	bhs	0f
 | |
| 	movem	[sp+],r1
 | |
| 
 | |
| 	/* In parent, successful return.  (Avoid using "ret" - it's a macro.)  */
 | |
| 	Ret
 | |
| 	nop
 | |
| 
 | |
| .Lthread_start:
 | |
| 	/* Terminate frame pointers here.  */
 | |
| 	moveq	0,r8
 | |
| 
 | |
| 	/* I've told you once.  */
 | |
| 	move.d	r1,r10
 | |
| 	jsr	r0
 | |
| 
 | |
| 	SETUP_PIC
 | |
| 	PLTCALL	(_exit)
 | |
| 
 | |
| 	/* Die horribly.  */
 | |
| 	test.d	[6809]
 | |
| 
 | |
| 	/* Stop the unstoppable.  */
 | |
| 9:
 | |
| 	ba	9b
 | |
| 	nop
 | |
| 
 | |
| /* Local error handler.  */
 | |
| 1:
 | |
| 	movs.w	-EINVAL,r10
 | |
| 	/* Drop through into the ordinary error handler.  */
 | |
| PSEUDO_END (__clone)
 | |
| 
 | |
| weak_alias (__clone, clone)
 |