]>
Commit | Line | Data |
---|---|---|
e9ce8d39 A |
1 | /* |
2 | * Copyright (c) 1999 Apple Computer, Inc. All rights reserved. | |
3 | * | |
4 | * @APPLE_LICENSE_HEADER_START@ | |
5 | * | |
734aad71 A |
6 | * This file contains Original Code and/or Modifications of Original Code |
7 | * as defined in and that are subject to the Apple Public Source License | |
8 | * Version 2.0 (the 'License'). You may not use this file except in | |
9 | * compliance with the License. Please obtain a copy of the License at | |
10 | * http://www.opensource.apple.com/apsl/ and read it before using this | |
11 | * file. | |
12 | * | |
13 | * The Original Code and all software distributed under the License are | |
14 | * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER | |
e9ce8d39 A |
15 | * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, |
16 | * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, | |
734aad71 A |
17 | * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. |
18 | * Please see the License for the specific language governing rights and | |
19 | * limitations under the License. | |
e9ce8d39 A |
20 | * |
21 | * @APPLE_LICENSE_HEADER_END@ | |
22 | */ | |
23 | /* | |
24 | * Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved | |
25 | * | |
26 | * HISTORY | |
27 | * 20-Apr-92 Bruce Martin (bmartin@next.com) | |
28 | * Created from M68K sources. | |
29 | */ | |
30 | ||
31 | /* | |
32 | * C library -- _setjmp, _longjmp | |
33 | * | |
34 | * _longjmp(a,v) | |
35 | * will generate a "return(v)" from | |
36 | * the last call to | |
37 | * _setjmp(a) | |
38 | * by restoring registers from the stack, | |
39 | * The previous signal state is NOT restored. | |
40 | * | |
41 | */ | |
42 | ||
43 | #include <architecture/i386/asm_help.h> | |
44 | ||
8e029c65 A |
45 | // The FP control word is actually two bytes, but there's no harm in |
46 | // using four bytes for it and keeping the struct aligned. | |
47 | #define JB_FPCW 0 | |
e9ce8d39 | 48 | #define JB_MASK 4 |
8e029c65 | 49 | #define JB_MXCSR 8 |
e9ce8d39 | 50 | #define JB_EBX 12 |
224c7076 | 51 | #define JB_ONSTACK 16 |
e9ce8d39 A |
52 | #define JB_EDX 20 |
53 | #define JB_EDI 24 | |
54 | #define JB_ESI 28 | |
55 | #define JB_EBP 32 | |
56 | #define JB_ESP 36 | |
57 | #define JB_SS 40 | |
58 | #define JB_EFLAGS 44 | |
59 | #define JB_EIP 48 | |
60 | #define JB_CS 52 | |
61 | #define JB_DS 56 | |
62 | #define JB_ES 60 | |
63 | #define JB_FS 64 | |
64 | #define JB_GS 68 | |
65 | ||
eb1cde05 | 66 | #define SAVE_SEG_REGS 1 |
e9ce8d39 A |
67 | |
68 | LEAF(__setjmp, 0) | |
69 | movl 4(%esp), %ecx // jmp_buf (struct sigcontext *) | |
70 | ||
8e029c65 A |
71 | // Build the jmp_buf |
72 | fnstcw JB_FPCW(%ecx) // Save the FP control word | |
73 | stmxcsr JB_MXCSR(%ecx) // Save the MXCSR | |
e9ce8d39 A |
74 | movl %ebx, JB_EBX(%ecx) |
75 | movl %edi, JB_EDI(%ecx) | |
76 | movl %esi, JB_ESI(%ecx) | |
77 | movl %ebp, JB_EBP(%ecx) | |
78 | ||
79 | // EIP is set to the frame return address value | |
80 | movl (%esp), %eax | |
81 | movl %eax, JB_EIP(%ecx) | |
82 | // ESP is set to the frame return address plus 4 | |
83 | movl %esp, %eax | |
84 | addl $4, %eax | |
85 | movl %eax, JB_ESP(%ecx) | |
86 | ||
87 | #if SAVE_SEG_REGS | |
88 | // segment registers | |
89 | mov %ss, JB_SS(%ecx) | |
90 | mov %cs, JB_CS(%ecx) | |
91 | mov %ds, JB_DS(%ecx) | |
92 | mov %es, JB_ES(%ecx) | |
93 | mov %fs, JB_FS(%ecx) | |
94 | mov %gs, JB_GS(%ecx) | |
95 | #endif | |
96 | ||
97 | // save eflags - you can't use movl | |
98 | pushf | |
99 | popl %eax | |
100 | movl %eax, JB_EFLAGS(%ecx) | |
101 | ||
102 | // return 0 | |
103 | xorl %eax, %eax | |
104 | ret | |
105 | ||
106 | ||
107 | LEAF(__longjmp, 0) | |
e9ce8d39 | 108 | fninit // reset FP coprocessor |
e9ce8d39 | 109 | |
8e029c65 | 110 | movl 4(%esp), %ecx // jmp_buf (struct sigcontext *) |
e9ce8d39 A |
111 | movl 8(%esp), %eax // return value |
112 | testl %eax, %eax | |
113 | jnz 1f | |
114 | incl %eax | |
115 | ||
116 | // general registers | |
117 | 1: movl JB_EBX(%ecx), %ebx | |
118 | movl JB_ESI(%ecx), %esi | |
119 | movl JB_EDI(%ecx), %edi | |
120 | movl JB_EBP(%ecx), %ebp | |
121 | movl JB_ESP(%ecx), %esp | |
8e029c65 A |
122 | fldcw JB_FPCW(%ecx) // Restore FP control word |
123 | ldmxcsr JB_MXCSR(%ecx) // Restore the MXCSR | |
e9ce8d39 A |
124 | |
125 | #if SAVE_SEG_REGS | |
126 | // segment registers | |
127 | mov JB_SS(%ecx), %ss | |
eb1cde05 | 128 | // mov JB_CS(%ecx), %cs // can't set cs? |
e9ce8d39 A |
129 | mov JB_DS(%ecx), %ds |
130 | mov JB_ES(%ecx), %es | |
131 | mov JB_FS(%ecx), %fs | |
132 | mov JB_GS(%ecx), %gs | |
133 | #endif | |
134 | ||
135 | // eflags | |
136 | pushl JB_EFLAGS(%ecx) | |
137 | popf | |
138 | ||
139 | jmp *JB_EIP(%ecx) |