xref: /minix3/lib/libc/compat/arch/m68k/sys/compat_Ovfork.S (revision 84d9c625bfea59e274550651111ae9edfdc40fbd)
1*84d9c625SLionel Sambuc/*	$NetBSD: compat_Ovfork.S,v 1.3 2013/09/12 15:36:16 joerg Exp $	*/
22fe8fb19SBen Gras
32fe8fb19SBen Gras/*-
42fe8fb19SBen Gras * Copyright (c) 1990 The Regents of the University of California.
52fe8fb19SBen Gras * All rights reserved.
62fe8fb19SBen Gras *
72fe8fb19SBen Gras * This code is derived from software contributed to Berkeley by
82fe8fb19SBen Gras * the Systems Programming Group of the University of Utah Computer
92fe8fb19SBen Gras * Science Department.
102fe8fb19SBen Gras *
112fe8fb19SBen Gras * Redistribution and use in source and binary forms, with or without
122fe8fb19SBen Gras * modification, are permitted provided that the following conditions
132fe8fb19SBen Gras * are met:
142fe8fb19SBen Gras * 1. Redistributions of source code must retain the above copyright
152fe8fb19SBen Gras *    notice, this list of conditions and the following disclaimer.
162fe8fb19SBen Gras * 2. Redistributions in binary form must reproduce the above copyright
172fe8fb19SBen Gras *    notice, this list of conditions and the following disclaimer in the
182fe8fb19SBen Gras *    documentation and/or other materials provided with the distribution.
192fe8fb19SBen Gras * 3. Neither the name of the University nor the names of its contributors
202fe8fb19SBen Gras *    may be used to endorse or promote products derived from this software
212fe8fb19SBen Gras *    without specific prior written permission.
222fe8fb19SBen Gras *
232fe8fb19SBen Gras * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
242fe8fb19SBen Gras * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
252fe8fb19SBen Gras * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
262fe8fb19SBen Gras * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
272fe8fb19SBen Gras * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
282fe8fb19SBen Gras * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
292fe8fb19SBen Gras * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
302fe8fb19SBen Gras * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
312fe8fb19SBen Gras * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
322fe8fb19SBen Gras * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
332fe8fb19SBen Gras * SUCH DAMAGE.
342fe8fb19SBen Gras */
352fe8fb19SBen Gras
362fe8fb19SBen Gras#include "SYS.h"
372fe8fb19SBen Gras
382fe8fb19SBen Gras#if defined(LIBC_SCCS) && !defined(lint)
392fe8fb19SBen Gras#if 0
402fe8fb19SBen Gras	RCSID("from: @(#)Ovfork.s	5.1 (Berkeley) 5/12/90")
412fe8fb19SBen Gras#else
42*84d9c625SLionel Sambuc	RCSID("$NetBSD: compat_Ovfork.S,v 1.3 2013/09/12 15:36:16 joerg Exp $")
432fe8fb19SBen Gras#endif
442fe8fb19SBen Gras#endif /* LIBC_SCCS and not lint */
452fe8fb19SBen Gras
462fe8fb19SBen Gras/*
472fe8fb19SBen Gras * @(#)vfork.s	4.1 (Berkeley) 12/21/80
482fe8fb19SBen Gras * C library -- vfork
492fe8fb19SBen Gras */
502fe8fb19SBen Gras
512fe8fb19SBen GrasWARN_REFERENCES(vfork, \
522fe8fb19SBen Gras    "warning: reference to compatibility vfork(); include <unistd.h> for correct reference")
532fe8fb19SBen Gras
542fe8fb19SBen Gras/*
552fe8fb19SBen Gras * pid = vfork();
562fe8fb19SBen Gras *
572fe8fb19SBen Gras * d1 == 0 in parent process, d1 == 1 in child process.
582fe8fb19SBen Gras * d0 == pid of child in parent, d0 == pid of parent in child.
592fe8fb19SBen Gras *
602fe8fb19SBen Gras * trickery here, due to keith sklower, uses ret to clear the stack,
612fe8fb19SBen Gras * and then returns with a jump indirect, since only one person can return
622fe8fb19SBen Gras * with a ret off this stack... we do the ret before we vfork!
632fe8fb19SBen Gras */
642fe8fb19SBen Gras
652fe8fb19SBen GrasENTRY(vfork)
66*84d9c625SLionel Sambuc	movl	(%sp)+,%a1
67*84d9c625SLionel Sambuc	SYSTRAP(vfork)
682fe8fb19SBen Gras	jcs	err
692fe8fb19SBen Gras	subql	#1,%d1	/* from 1 to 0 in child, 0 to -1 in parent */
702fe8fb19SBen Gras	andl	%d1,%d0
71*84d9c625SLionel Sambuc	jmp	(%a1)
722fe8fb19SBen Graserr:
732fe8fb19SBen Gras#ifdef	_REENTRANT
742fe8fb19SBen Gras	.globl	_C_LABEL(__errno)
75*84d9c625SLionel Sambuc	movl	%a1,-(%sp)
76*84d9c625SLionel Sambuc	movl	%d0,-(%sp)
772fe8fb19SBen Gras	jbsr	PIC_PLT(_C_LABEL(__errno))
782fe8fb19SBen Gras#ifdef	__SVR4_ABI__
79*84d9c625SLionel Sambuc	movl	(%sp)+,(%a0)
802fe8fb19SBen Gras#else
812fe8fb19SBen Gras	movl	%d0,%a1
82*84d9c625SLionel Sambuc	movl	(%sp)+,(%a1)
832fe8fb19SBen Gras#endif	/* __SVR4_ABI__ */
84*84d9c625SLionel Sambuc	movl	(%sp)+,%a1
852fe8fb19SBen Gras#else
862fe8fb19SBen Gras	.globl	_C_LABEL(errno)
87*84d9c625SLionel Sambuc#ifdef __PIC__
88*84d9c625SLionel Sambuc	GOT_SETUP(%a0)
89*84d9c625SLionel Sambuc	movl	_C_LABEL(errno)@GOT:w(%a0),%a0
90*84d9c625SLionel Sambuc	movl	%d0,(%a0)
912fe8fb19SBen Gras#else
922fe8fb19SBen Gras	movl	%d0,_C_LABEL(errno)
93*84d9c625SLionel Sambuc#endif	/* __PIC__ */
942fe8fb19SBen Gras#endif	/* _REENTRANT */
952fe8fb19SBen Gras	moveq	#-1,%d0
96*84d9c625SLionel Sambuc	jmp	(%a1)
97*84d9c625SLionel SambucEND(vfork)
98