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