_setjmp.S revision 1.6 1 1.1 ragge /*
2 1.1 ragge * Copyright (c) 1980, 1993
3 1.1 ragge * The Regents of the University of California. All rights reserved.
4 1.1 ragge *
5 1.1 ragge * Redistribution and use in source and binary forms, with or without
6 1.1 ragge * modification, are permitted provided that the following conditions
7 1.1 ragge * are met:
8 1.1 ragge * 1. Redistributions of source code must retain the above copyright
9 1.1 ragge * notice, this list of conditions and the following disclaimer.
10 1.1 ragge * 2. Redistributions in binary form must reproduce the above copyright
11 1.1 ragge * notice, this list of conditions and the following disclaimer in the
12 1.1 ragge * documentation and/or other materials provided with the distribution.
13 1.1 ragge * 3. All advertising materials mentioning features or use of this software
14 1.1 ragge * must display the following acknowledgement:
15 1.1 ragge * This product includes software developed by the University of
16 1.1 ragge * California, Berkeley and its contributors.
17 1.1 ragge * 4. Neither the name of the University nor the names of its contributors
18 1.1 ragge * may be used to endorse or promote products derived from this software
19 1.1 ragge * without specific prior written permission.
20 1.1 ragge *
21 1.1 ragge * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 1.1 ragge * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 1.1 ragge * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 1.1 ragge * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 1.1 ragge * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 1.1 ragge * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 1.1 ragge * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 1.1 ragge * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 1.1 ragge * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 1.1 ragge * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 1.1 ragge * SUCH DAMAGE.
32 1.1 ragge */
33 1.1 ragge
34 1.1 ragge #if defined(LIBC_SCCS) && !defined(lint)
35 1.1 ragge /* .asciz "@(#)_setjmp.s 8.1 (Berkeley) 6/4/93" */
36 1.6 matt .asciz "$NetBSD: _setjmp.S,v 1.6 2002/03/27 18:38:50 matt Exp $"
37 1.1 ragge #endif /* LIBC_SCCS and not lint */
38 1.1 ragge
39 1.1 ragge /*
40 1.1 ragge * C library -- _setjmp, _longjmp
41 1.1 ragge *
42 1.1 ragge * _longjmp(a,v)
43 1.1 ragge * will generate a "return(v)" from
44 1.1 ragge * the last call to
45 1.1 ragge * _setjmp(a)
46 1.1 ragge * by restoring registers from the stack,
47 1.1 ragge * The previous signal state is NOT restored.
48 1.6 matt *
49 1.6 matt * Even though we don't use sigreturn14, we still store things in a sigcontext
50 1.6 matt * in order to be consistent.
51 1.1 ragge */
52 1.1 ragge
53 1.1 ragge #include "DEFS.h"
54 1.1 ragge
55 1.1 ragge ENTRY(_setjmp, 0)
56 1.4 matt movl 4(%ap),%r0
57 1.6 matt movl 12(%fp),12(%r0) # save frame pointer of caller
58 1.6 matt movl 16(%fp),20(%r0) # save pc of caller
59 1.6 matt #ifdef __ELF__
60 1.6 matt movl 8(%fp),16(%r0) # save ap of caller
61 1.6 matt clrl %r1 # clear arg count
62 1.6 matt bbc $13,6(%fp),1f # was this a callg?
63 1.6 matt addl3 $1,(%ap),%r1 # get real arg count+1 for calls
64 1.6 matt 1: moval 20(%fp)[%r1],8(%r0) # save sp of caller
65 1.6 matt movpsl 24(%r1) # save current psl
66 1.6 matt movw 4(%fp),24(%r1) # save psw of caller
67 1.6 matt movq %r6,44(%r0) # save r6/r7
68 1.6 matt movq %r8,52(%r0) # save r8/r9
69 1.6 matt movq %r10,60(%r0) # save r10/r11
70 1.6 matt #endif
71 1.4 matt clrl %r0
72 1.1 ragge ret
73 1.1 ragge
74 1.1 ragge ENTRY(_longjmp, 0)
75 1.4 matt movl 8(%ap),%r0 # return(v)
76 1.4 matt movl 4(%ap),%r1 # fetch buffer
77 1.6 matt tstl 12(%r1) # is fp null
78 1.1 ragge beql botch
79 1.6 matt #ifdef __ELF__
80 1.6 matt movq 44(%r1),%r6 # restore r6/r7
81 1.6 matt movq 52(%r1),%r8 # restore r8/r9
82 1.6 matt movq 60(%r1),%r10 # restore r10/r11
83 1.6 matt movl 16(%r1),%ap # restore ap
84 1.6 matt movq 8(%r1),%sp # restore sp/fp
85 1.6 matt movq 20(%r1),-(%sp) # save pc/psl to new stack
86 1.6 matt rei # and go back to saved pc/psl
87 1.6 matt #else
88 1.1 ragge loop:
89 1.4 matt bitw $1,6(%fp) # %r0 saved?
90 1.1 ragge beql 1f
91 1.4 matt movl %r0,20(%fp)
92 1.4 matt bitw $2,6(%fp) # was %r1 saved?
93 1.1 ragge beql 2f
94 1.4 matt movl %r1,24(%fp)
95 1.1 ragge brb 2f
96 1.1 ragge 1:
97 1.4 matt bitw $2,6(%fp) # was %r1 saved?
98 1.1 ragge beql 2f
99 1.4 matt movl %r1,20(%fp)
100 1.1 ragge 2:
101 1.6 matt cmpl 12(%r1),12(%fp)
102 1.1 ragge beql done
103 1.1 ragge blssu botch
104 1.4 matt movab loop,16(%fp)
105 1.1 ragge ret # pop another frame
106 1.1 ragge
107 1.1 ragge done:
108 1.4 matt cmpb *16(%fp),$2 # returning to an "rei"?
109 1.1 ragge bneq 1f
110 1.4 matt movab 3f,16(%fp) # do return w/ psl-pc pop
111 1.1 ragge brw 2f
112 1.1 ragge 1:
113 1.4 matt movab 4f,16(%fp) # do standard return
114 1.1 ragge 2:
115 1.1 ragge ret # unwind stack before signals enabled
116 1.1 ragge 3:
117 1.5 matt addl2 $8,%sp # compensate for PSL-PC push
118 1.1 ragge 4:
119 1.6 matt jmp *20(%r1) # done, return....
120 1.6 matt #endif /* !__ELF__ */
121 1.1 ragge
122 1.1 ragge botch:
123 1.3 matt calls $0,_C_LABEL(longjmperror)
124 1.1 ragge halt
125