_setjmp.S revision 1.6.16.1 1 1.6.16.1 matt /* $NetBSD: _setjmp.S,v 1.6.16.1 2007/08/28 17:36:29 matt Exp $ */
2 1.1 bjh21
3 1.1 bjh21 /*
4 1.1 bjh21 * Copyright (c) 1997 Mark Brinicombe
5 1.1 bjh21 * All rights reserved.
6 1.1 bjh21 *
7 1.1 bjh21 * Redistribution and use in source and binary forms, with or without
8 1.1 bjh21 * modification, are permitted provided that the following conditions
9 1.1 bjh21 * are met:
10 1.1 bjh21 * 1. Redistributions of source code must retain the above copyright
11 1.1 bjh21 * notice, this list of conditions and the following disclaimer.
12 1.1 bjh21 * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 bjh21 * notice, this list of conditions and the following disclaimer in the
14 1.1 bjh21 * documentation and/or other materials provided with the distribution.
15 1.1 bjh21 * 3. All advertising materials mentioning features or use of this software
16 1.1 bjh21 * must display the following acknowledgement:
17 1.1 bjh21 * This product includes software developed by Mark Brinicombe
18 1.1 bjh21 * 4. Neither the name of the University nor the names of its contributors
19 1.1 bjh21 * may be used to endorse or promote products derived from this software
20 1.1 bjh21 * without specific prior written permission.
21 1.1 bjh21 *
22 1.1 bjh21 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
23 1.1 bjh21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 1.1 bjh21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 1.1 bjh21 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
26 1.1 bjh21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 1.1 bjh21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 1.1 bjh21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 1.1 bjh21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 1.1 bjh21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 1.1 bjh21 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 1.1 bjh21 * SUCH DAMAGE.
33 1.1 bjh21 */
34 1.1 bjh21
35 1.1 bjh21 #include <machine/asm.h>
36 1.1 bjh21 #include <machine/setjmp.h>
37 1.1 bjh21
38 1.1 bjh21 /*
39 1.1 bjh21 * C library -- _setjmp, _longjmp
40 1.1 bjh21 *
41 1.1 bjh21 * _longjmp(a,v)
42 1.1 bjh21 * will generate a "return(v)" from the last call to
43 1.1 bjh21 * _setjmp(a)
44 1.1 bjh21 * by restoring registers from the stack.
45 1.1 bjh21 * The previous signal state is NOT restored.
46 1.1 bjh21 *
47 1.1 bjh21 * Note: r0 is the return value
48 1.1 bjh21 * r1-r3 are scratch registers in functions
49 1.1 bjh21 */
50 1.1 bjh21
51 1.1 bjh21 ENTRY(_setjmp)
52 1.6.16.1 matt #ifdef __thumb__
53 1.6.16.1 matt push {r4-r7}
54 1.6.16.1 matt ldr r2, .L_setjmp_magic
55 1.6.16.1 matt add r1, r0, #4
56 1.6.16.1 matt str r2, [r1]
57 1.6.16.1 matt add r0, r0, #52
58 1.6.16.1 matt /* Store integer registers */
59 1.6.16.1 matt stmia r0!, {r4-r7}
60 1.6.16.1 matt mov r4, r8
61 1.6.16.1 matt mov r5, r9
62 1.6.16.1 matt mov r6, r10
63 1.6.16.1 matt mov r7, r11
64 1.6.16.1 matt stmia r0!, {r4-r7}
65 1.6.16.1 matt mov r4, r12
66 1.6.16.1 matt mov r5, r13
67 1.6.16.1 matt mov r6, r14
68 1.6.16.1 matt stmia r0!, {r4-r6}
69 1.6.16.1 matt
70 1.6.16.1 matt mov r0, #0x00000000
71 1.6.16.1 matt #else
72 1.4 thorpej ldr r1, .L_setjmp_magic
73 1.1 bjh21 str r1, [r0], #4
74 1.1 bjh21 #ifdef SOFTFLOAT
75 1.1 bjh21 add r0, r0, #52
76 1.1 bjh21 #else
77 1.1 bjh21 /* Store fp registers */
78 1.1 bjh21 sfm f4, 4, [r0], #48
79 1.1 bjh21 /* Store fpsr */
80 1.1 bjh21 rfs r1
81 1.1 bjh21 str r1, [r0], #0x0004
82 1.1 bjh21 #endif /* SOFTFLOAT */
83 1.1 bjh21 /* Store integer registers */
84 1.1 bjh21 stmia r0, {r4-r14}
85 1.1 bjh21
86 1.1 bjh21 mov r0, #0x00000000
87 1.6.16.1 matt #endif /* __thumb__ */
88 1.6.16.1 matt XPOP {r4-r7}
89 1.6 rearnsha RET
90 1.1 bjh21
91 1.1 bjh21 ENTRY(_longjmp)
92 1.6.16.1 matt #ifdef __thumb__
93 1.6.16.1 matt add r2, r0, #4
94 1.6.16.1 matt ldr r3, [r2]
95 1.6.16.1 matt ldr r2, .L_setjmp_magic
96 1.6.16.1 matt cmp r2, r3
97 1.6.16.1 matt bne .Lbotch
98 1.6.16.1 matt
99 1.6.16.1 matt add r0, r0, #52
100 1.6.16.1 matt /* Restore integer registers */
101 1.6.16.1 matt ldmia r0!, {r4-r7}
102 1.6.16.1 matt push {r4-r7} /* save for later */
103 1.6.16.1 matt ldmia r0!, {r4-r7}
104 1.6.16.1 matt mov r8, r4
105 1.6.16.1 matt mov r9, r5
106 1.6.16.1 matt mov r10, r6
107 1.6.16.1 matt mov r11, r7
108 1.6.16.1 matt ldmia r0!, {r4-r6}
109 1.6.16.1 matt mov r12, r4
110 1.6.16.1 matt
111 1.6.16.1 matt /* Validate sp and r14 */
112 1.6.16.1 matt cmp r5, #0
113 1.6.16.1 matt beq .Lbotch
114 1.6.16.1 matt cmp r6, #0
115 1.6.16.1 matt beq .Lbotch
116 1.6.16.1 matt
117 1.6.16.1 matt mov sp, r5
118 1.6.16.1 matt mov lr, r6
119 1.6.16.1 matt /* Set return value */
120 1.6.16.1 matt mov r0, r1
121 1.6.16.1 matt cmp r0, #0
122 1.6.16.1 matt bne 1f
123 1.6.16.1 matt mov r0, #1
124 1.6.16.1 matt 1: pop {r4-r7}
125 1.6.16.1 matt RET
126 1.6.16.1 matt
127 1.6.16.1 matt /* validation failed, die die die. */
128 1.6.16.1 matt .Lbotch:
129 1.6.16.1 matt bl PLT_SYM(_C_LABEL(longjmperror))
130 1.6.16.1 matt bl PLT_SYM(_C_LABEL(abort))
131 1.6.16.1 matt b . - 8 /* Cannot get here */
132 1.6.16.1 matt
133 1.6.16.1 matt #else
134 1.4 thorpej ldr r2, .L_setjmp_magic
135 1.1 bjh21 ldr r3, [r0], #4
136 1.1 bjh21 teq r2, r3
137 1.6.16.1 matt bne .Lbotch
138 1.1 bjh21
139 1.1 bjh21 #ifdef SOFTFLOAT
140 1.1 bjh21 add r0, r0, #52
141 1.1 bjh21 #else
142 1.1 bjh21 /* Restore fp registers */
143 1.1 bjh21 lfm f4, 4, [r0], #48
144 1.1 bjh21 /* Restore fpsr */
145 1.1 bjh21 ldr r4, [r0], #0x0004
146 1.1 bjh21 wfs r4
147 1.1 bjh21 #endif /* SOFTFLOAT */
148 1.1 bjh21 /* Restore integer registers */
149 1.1 bjh21 ldmia r0, {r4-r14}
150 1.1 bjh21
151 1.3 chris /* Validate sp and r14 */
152 1.3 chris teq sp, #0
153 1.3 chris teqne r14, #0
154 1.6.16.1 matt beq .Lbotch
155 1.1 bjh21
156 1.1 bjh21 /* Set return value */
157 1.1 bjh21 mov r0, r1
158 1.1 bjh21 teq r0, #0x00000000
159 1.1 bjh21 moveq r0, #0x00000001
160 1.6 rearnsha RET
161 1.1 bjh21
162 1.1 bjh21 /* validation failed, die die die. */
163 1.6.16.1 matt .Lbotch:
164 1.6.16.1 matt bl PLT_SYM(_C_LABEL(longjmperror))
165 1.6.16.1 matt bl PLT_SYM(_C_LABEL(abort))
166 1.1 bjh21 b . - 8 /* Cannot get here */
167 1.6.16.1 matt #endif
168 1.6.16.1 matt
169 1.6.16.1 matt .p2align 2
170 1.6.16.1 matt .L_setjmp_magic:
171 1.6.16.1 matt .word _JB_MAGIC__SETJMP
172 1.6.16.1 matt
173