18238b87bSPeter Grehan/*- 28238b87bSPeter Grehan * Copyright (c) 2002 Peter Grehan. 38238b87bSPeter Grehan * All rights reserved. 48238b87bSPeter Grehan * 58238b87bSPeter Grehan * Redistribution and use in source and binary forms, with or without 68238b87bSPeter Grehan * modification, are permitted provided that the following conditions 78238b87bSPeter Grehan * are met: 88238b87bSPeter Grehan * 1. Redistributions of source code must retain the above copyright 98238b87bSPeter Grehan * notice, this list of conditions and the following disclaimer. 108238b87bSPeter Grehan * 2. Redistributions in binary form must reproduce the above copyright 118238b87bSPeter Grehan * notice, this list of conditions and the following disclaimer in the 128238b87bSPeter Grehan * documentation and/or other materials provided with the distribution. 138238b87bSPeter Grehan * 148238b87bSPeter Grehan * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 158238b87bSPeter Grehan * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 168238b87bSPeter Grehan * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 178238b87bSPeter Grehan * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 188238b87bSPeter Grehan * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 198238b87bSPeter Grehan * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 208238b87bSPeter Grehan * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 218238b87bSPeter Grehan * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 228238b87bSPeter Grehan * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 238238b87bSPeter Grehan * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 248238b87bSPeter Grehan * SUCH DAMAGE. 258238b87bSPeter Grehan */ 268238b87bSPeter Grehan/* $NetBSD: setjmp.S,v 1.3 1998/10/03 12:30:38 tsubai Exp $ */ 278238b87bSPeter Grehan 288238b87bSPeter Grehan#include <machine/asm.h> 298238b87bSPeter Grehan#include <sys/syscall.h> 308238b87bSPeter Grehan 318238b87bSPeter Grehan/* 328238b87bSPeter Grehan * C library -- setjmp, longjmp 338238b87bSPeter Grehan * 348238b87bSPeter Grehan * longjmp(a,v) 358238b87bSPeter Grehan * will generate a "return(v?v:1)" from the last call to 368238b87bSPeter Grehan * setjmp(a) 378238b87bSPeter Grehan * by restoring registers from the stack. 388238b87bSPeter Grehan * The previous signal state is restored. 398238b87bSPeter Grehan * 408238b87bSPeter Grehan * jmpbuf layout: 418238b87bSPeter Grehan * +------------+ 428238b87bSPeter Grehan * | unused | 438238b87bSPeter Grehan * +------------+ 448238b87bSPeter Grehan * | sig state | 458238b87bSPeter Grehan * | | 468238b87bSPeter Grehan * | (4 words) | 478238b87bSPeter Grehan * | | 488238b87bSPeter Grehan * +------------+ 498238b87bSPeter Grehan * | saved regs | 508238b87bSPeter Grehan * | ... | 518238b87bSPeter Grehan */ 528238b87bSPeter Grehan 538238b87bSPeter GrehanENTRY(setjmp) 548238b87bSPeter Grehan mr %r6,%r3 558238b87bSPeter Grehan li %r3,1 /* SIG_BLOCK, but doesn't matter */ 568238b87bSPeter Grehan /* since set == NULL */ 578238b87bSPeter Grehan li %r4,0 /* set = NULL */ 588238b87bSPeter Grehan mr %r5,%r6 /* &oset */ 598238b87bSPeter Grehan addi %r5,%r5,4 608238b87bSPeter Grehan li %r0, SYS_sigprocmask /*sigprocmask(SIG_BLOCK, NULL, &oset)*/ 618238b87bSPeter Grehan sc /*assume no error XXX */ 628238b87bSPeter Grehan mflr %r11 /* r11 <- link reg */ 638238b87bSPeter Grehan mfcr %r12 /* r12 <- condition reg */ 648238b87bSPeter Grehan mr %r10,%r1 /* r10 <- stackptr */ 658238b87bSPeter Grehan mr %r9,%r2 /* r9 <- global ptr */ 668238b87bSPeter Grehan stmw %r9,20(%r6) 671ee35324SNathan Whitehorn 681ee35324SNathan Whitehorn /* FPRs */ 69*6554d5b4SJustin Hibbits stfd %f14,112+0*8(%r6) 70*6554d5b4SJustin Hibbits stfd %f15,112+1*8(%r6) 71*6554d5b4SJustin Hibbits stfd %f16,112+2*8(%r6) 72*6554d5b4SJustin Hibbits stfd %f17,112+3*8(%r6) 73*6554d5b4SJustin Hibbits stfd %f18,112+4*8(%r6) 74*6554d5b4SJustin Hibbits stfd %f19,112+5*8(%r6) 75*6554d5b4SJustin Hibbits stfd %f20,112+6*8(%r6) 76*6554d5b4SJustin Hibbits stfd %f21,112+7*8(%r6) 77*6554d5b4SJustin Hibbits stfd %f22,112+8*8(%r6) 78*6554d5b4SJustin Hibbits stfd %f23,112+9*8(%r6) 79*6554d5b4SJustin Hibbits stfd %f24,112+10*8(%r6) 80*6554d5b4SJustin Hibbits stfd %f25,112+11*8(%r6) 81*6554d5b4SJustin Hibbits stfd %f26,112+12*8(%r6) 82*6554d5b4SJustin Hibbits stfd %f27,112+13*8(%r6) 83*6554d5b4SJustin Hibbits stfd %f28,112+14*8(%r6) 84*6554d5b4SJustin Hibbits stfd %f29,112+15*8(%r6) 85*6554d5b4SJustin Hibbits stfd %f30,112+16*8(%r6) 86*6554d5b4SJustin Hibbits stfd %f31,112+17*8(%r6) 871ee35324SNathan Whitehorn 888238b87bSPeter Grehan li %r3,0 /* return (0) */ 898238b87bSPeter Grehan blr 90ad9bbe98SBaptiste DaroussinEND(setjmp) 918238b87bSPeter Grehan 9254558cdcSAndreas Tobler WEAK_REFERENCE(CNAME(__longjmp), longjmp) 938238b87bSPeter GrehanENTRY(__longjmp) 948238b87bSPeter Grehan lmw %r9,20(%r3) /* restore regs */ 951ee35324SNathan Whitehorn 961ee35324SNathan Whitehorn /* FPRs */ 97*6554d5b4SJustin Hibbits lfd %f14,112+0*8(%r3) 98*6554d5b4SJustin Hibbits lfd %f15,112+1*8(%r3) 99*6554d5b4SJustin Hibbits lfd %f16,112+2*8(%r3) 100*6554d5b4SJustin Hibbits lfd %f17,112+3*8(%r3) 101*6554d5b4SJustin Hibbits lfd %f18,112+4*8(%r3) 102*6554d5b4SJustin Hibbits lfd %f19,112+5*8(%r3) 103*6554d5b4SJustin Hibbits lfd %f20,112+6*8(%r3) 104*6554d5b4SJustin Hibbits lfd %f21,112+7*8(%r3) 105*6554d5b4SJustin Hibbits lfd %f22,112+8*8(%r3) 106*6554d5b4SJustin Hibbits lfd %f23,112+9*8(%r3) 107*6554d5b4SJustin Hibbits lfd %f24,112+10*8(%r3) 108*6554d5b4SJustin Hibbits lfd %f25,112+11*8(%r3) 109*6554d5b4SJustin Hibbits lfd %f26,112+12*8(%r3) 110*6554d5b4SJustin Hibbits lfd %f27,112+13*8(%r3) 111*6554d5b4SJustin Hibbits lfd %f28,112+14*8(%r3) 112*6554d5b4SJustin Hibbits lfd %f29,112+15*8(%r3) 113*6554d5b4SJustin Hibbits lfd %f30,112+16*8(%r3) 114*6554d5b4SJustin Hibbits lfd %f31,112+17*8(%r3) 1151ee35324SNathan Whitehorn 1168238b87bSPeter Grehan mr %r6,%r4 /* save val param */ 1178238b87bSPeter Grehan mtlr %r11 /* r11 -> link reg */ 1188238b87bSPeter Grehan mtcr %r12 /* r12 -> condition reg */ 1198238b87bSPeter Grehan mr %r1,%r10 /* r10 -> stackptr */ 1208238b87bSPeter Grehan mr %r4,%r3 1218238b87bSPeter Grehan li %r3,3 /* SIG_SETMASK */ 1228238b87bSPeter Grehan addi %r4,%r4,4 /* &set */ 1238238b87bSPeter Grehan li %r5,0 /* oset = NULL */ 1248238b87bSPeter Grehan li %r0,SYS_sigprocmask /* sigprocmask(SIG_SET, &set, NULL) */ 1258238b87bSPeter Grehan sc /* assume no error XXX */ 1268238b87bSPeter Grehan or. %r3,%r6,%r6 1278238b87bSPeter Grehan bnelr 1288238b87bSPeter Grehan li %r3,1 1298238b87bSPeter Grehan blr 130ad9bbe98SBaptiste DaroussinEND(__longjmp) 1318238b87bSPeter Grehan 1328f861da9SKonstantin Belousov .section .note.GNU-stack,"",%progbits 133