1*84d9c625SLionel Sambuc/* $NetBSD: swapcontext.S,v 1.5 2013/09/12 15:36:16 joerg Exp $ */ 22fe8fb19SBen Gras 32fe8fb19SBen Gras/*- 42fe8fb19SBen Gras * Copyright (c) 2001 The NetBSD Foundation, Inc. 52fe8fb19SBen Gras * All rights reserved. 62fe8fb19SBen Gras * 72fe8fb19SBen Gras * This code is derived from software contributed to The NetBSD Foundation 82fe8fb19SBen Gras * by Klaus Klein. 92fe8fb19SBen Gras * 102fe8fb19SBen Gras * Redistribution and use in source and binary forms, with or without 112fe8fb19SBen Gras * modification, are permitted provided that the following conditions 122fe8fb19SBen Gras * are met: 132fe8fb19SBen Gras * 1. Redistributions of source code must retain the above copyright 142fe8fb19SBen Gras * notice, this list of conditions and the following disclaimer. 152fe8fb19SBen Gras * 2. Redistributions in binary form must reproduce the above copyright 162fe8fb19SBen Gras * notice, this list of conditions and the following disclaimer in the 172fe8fb19SBen Gras * documentation and/or other materials provided with the distribution. 182fe8fb19SBen Gras * 192fe8fb19SBen Gras * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 202fe8fb19SBen Gras * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 212fe8fb19SBen Gras * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 222fe8fb19SBen Gras * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 232fe8fb19SBen Gras * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 242fe8fb19SBen Gras * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 252fe8fb19SBen Gras * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 262fe8fb19SBen Gras * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 272fe8fb19SBen Gras * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 282fe8fb19SBen Gras * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 292fe8fb19SBen Gras * POSSIBILITY OF SUCH DAMAGE. 302fe8fb19SBen Gras */ 312fe8fb19SBen Gras 322fe8fb19SBen Gras#include "SYS.h" 332fe8fb19SBen Gras 342fe8fb19SBen Gras#if defined(LIBC_SCCS) && !defined(lint) 35*84d9c625SLionel Sambuc RCSID("$NetBSD: swapcontext.S,v 1.5 2013/09/12 15:36:16 joerg Exp $") 362fe8fb19SBen Gras#endif /* LIBC_SCCS && !lint */ 372fe8fb19SBen Gras 382fe8fb19SBen GrasENTRY(swapcontext) 392fe8fb19SBen Gras mov %o0, %o2 ! must save pointer 402fe8fb19SBen Gras mov %o1, %o3 ! must save pointer 412fe8fb19SBen Gras mov SYS_getcontext, %g1 422fe8fb19SBen Gras t ST_SYSCALL 432fe8fb19SBen Gras bcc,a 1f 442fe8fb19SBen Gras st %g0, [%o2 + 40 + 11 * 4] ! gr[_REG_O0] = 0 452fe8fb19SBen Gras ERROR() 462fe8fb19SBen Gras1: 472fe8fb19SBen Gras add %o7, 12, %o1 482fe8fb19SBen Gras st %o1, [%o2 + 40 + 2 * 4] ! gr[_REG_nPC] = retaddr + 4 492fe8fb19SBen Gras add %o7, 8, %o1 502fe8fb19SBen Gras st %o1, [%o2 + 40 + 1 * 4] ! gr[_REG_PC] = retaddr 512fe8fb19SBen Gras 52*84d9c625SLionel Sambuc#ifdef __PIC__ 53e415d488SLionel Sambuc PIC_PROLOGUE(%g1, %g2) ! %g1 = _GLOBAL_OFFSET_TABLE 54e415d488SLionel Sambuc set _C_LABEL(setcontext), %g2 55e415d488SLionel Sambuc ld [%g1 + %g2], %g1 56e415d488SLionel Sambuc jmp %g1 572fe8fb19SBen Gras mov %o3, %o0 58e415d488SLionel Sambuc#else 59e415d488SLionel Sambuc jmp _C_LABEL(setcontext) 60e415d488SLionel Sambuc mov %o3, %o0 61e415d488SLionel Sambuc#endif 62