Home | History | Annotate | Line # | Download | only in sys
__clone.S revision 1.1.2.2
      1  1.1.2.2  nathanw /*	$NetBSD: __clone.S,v 1.1.2.2 2001/10/08 20:18:06 nathanw Exp $	*/
      2  1.1.2.2  nathanw 
      3  1.1.2.2  nathanw /*-
      4  1.1.2.2  nathanw  * Copyright (c) 2001 Tsubai Masanari.  All rights reserved.
      5  1.1.2.2  nathanw  *
      6  1.1.2.2  nathanw  * Redistribution and use in source and binary forms, with or without
      7  1.1.2.2  nathanw  * modification, are permitted provided that the following conditions
      8  1.1.2.2  nathanw  * are met:
      9  1.1.2.2  nathanw  * 1. Redistributions of source code must retain the above copyright
     10  1.1.2.2  nathanw  *    notice, this list of conditions and the following disclaimer.
     11  1.1.2.2  nathanw  * 2. Redistributions in binary form must reproduce the above copyright
     12  1.1.2.2  nathanw  *    notice, this list of conditions and the following disclaimer in the
     13  1.1.2.2  nathanw  *    documentation and/or other materials provided with the distribution.
     14  1.1.2.2  nathanw  * 3. The name of the author may not be used to endorse or promote products
     15  1.1.2.2  nathanw  *    derived from this software without specific prior written permission.
     16  1.1.2.2  nathanw  *
     17  1.1.2.2  nathanw  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     18  1.1.2.2  nathanw  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     19  1.1.2.2  nathanw  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     20  1.1.2.2  nathanw  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     21  1.1.2.2  nathanw  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     22  1.1.2.2  nathanw  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     23  1.1.2.2  nathanw  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     24  1.1.2.2  nathanw  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     25  1.1.2.2  nathanw  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
     26  1.1.2.2  nathanw  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     27  1.1.2.2  nathanw  */
     28  1.1.2.2  nathanw 
     29  1.1.2.2  nathanw #include <sys/errno.h>
     30  1.1.2.2  nathanw #include "SYS.h"
     31  1.1.2.2  nathanw 
     32  1.1.2.2  nathanw #ifdef WEAK_ALIAS
     33  1.1.2.2  nathanw WEAK_ALIAS(clone,__clone)
     34  1.1.2.2  nathanw #endif
     35  1.1.2.2  nathanw 
     36  1.1.2.2  nathanw /*
     37  1.1.2.2  nathanw  * int __clone(int (*fn)(void *), void *stack, int flags, void *arg);
     38  1.1.2.2  nathanw  */
     39  1.1.2.2  nathanw ENTRY(__clone)
     40  1.1.2.2  nathanw 	/*
     41  1.1.2.2  nathanw 	 * Sanity checks: func and stack may not be NULL.
     42  1.1.2.2  nathanw 	 */
     43  1.1.2.2  nathanw 	tst	r4, r4
     44  1.1.2.2  nathanw 	bt	inval
     45  1.1.2.2  nathanw 	tst	r5, r5
     46  1.1.2.2  nathanw 	bt	inval
     47  1.1.2.2  nathanw 
     48  1.1.2.2  nathanw 	mov	r4, r2
     49  1.1.2.2  nathanw 	mov	r6, r4
     50  1.1.2.2  nathanw 	mov.l	LSYS___clone, r0
     51  1.1.2.2  nathanw 	trapa	#0x80
     52  1.1.2.2  nathanw 	bf	err
     53  1.1.2.2  nathanw 
     54  1.1.2.2  nathanw 	tst	r0, r0
     55  1.1.2.2  nathanw 	bf	1f		/* We're the parent, just return. */
     56  1.1.2.2  nathanw 
     57  1.1.2.2  nathanw 	jsr	@r2		/* Call the clone's entry point. */
     58  1.1.2.2  nathanw 	mov	r7, r4		/* arg */
     59  1.1.2.2  nathanw 
     60  1.1.2.2  nathanw 	mov.l	L__exit, r1
     61  1.1.2.2  nathanw 	jsr	@r1
     62  1.1.2.2  nathanw 	mov	r0, r4
     63  1.1.2.2  nathanw 
     64  1.1.2.2  nathanw inval:
     65  1.1.2.2  nathanw 	mov	#EINVAL, r0
     66  1.1.2.2  nathanw err:
     67  1.1.2.2  nathanw 	mov.l	Lcerror, r1
     68  1.1.2.2  nathanw 	jmp	@r1
     69  1.1.2.2  nathanw 	nop
     70  1.1.2.2  nathanw 1:
     71  1.1.2.2  nathanw 	rts
     72  1.1.2.2  nathanw 	nop
     73  1.1.2.2  nathanw 
     74  1.1.2.2  nathanw 	.align	2
     75  1.1.2.2  nathanw LSYS___clone:
     76  1.1.2.2  nathanw 	.long	SYS___clone
     77  1.1.2.2  nathanw L__exit:
     78  1.1.2.2  nathanw 	.long	_C_LABEL(_exit)
     79  1.1.2.2  nathanw Lcerror:
     80  1.1.2.2  nathanw 	.long	cerror
     81