1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
/* $NetBSD: __setjmp14.S,v 1.3 2014/08/23 02:24:22 matt Exp $ */
#include "SYS.h"
#if defined(LIBC_SCCS)
__RCSID("$NetBSD: __setjmp14.S,v 1.3 2014/08/23 02:24:22 matt Exp $")
#endif
/*
* C library -- _setjmp, _longjmp
*
* longjmp(a,v)
* will generate a "return(v?v:1)" from the last call to
* setjmp(a)
* by restoring registers from the stack.
* The previous signal state is restored.
*/
ENTRY(__setjmp14)
mr %r6,%r3
li %r3,1 # SIG_BLOCK
li %r4,0
addi %r5,%r6,100 # &sigmask
_DOSYSCALL(__sigprocmask14) # assume no error XXX
mflr %r11
mfcr %r12
mr %r10,%r1
mr %r9,%r2
std %r8,8(%r6) # save r8-r31
std %r9,16(%r6)
std %r10,24(%r6)
std %r11,32(%r6)
std %r12,40(%r6)
std %r13,48(%r6)
std %r14,56(%r6)
std %r15,64(%r6)
std %r16,72(%r6)
std %r17,80(%r6)
std %r18,88(%r6)
std %r19,96(%r6)
std %r20,104(%r6)
std %r21,112(%r6)
std %r22,120(%r6)
std %r23,128(%r6)
std %r24,136(%r6)
std %r25,144(%r6)
std %r26,152(%r6)
std %r27,160(%r6)
std %r28,168(%r6)
std %r29,176(%r6)
std %r30,184(%r6)
std %r31,192(%r6)
li %r3,0
blr
END(__setjmp14)
ENTRY(__longjmp14)
ld %r8,8(%r6) # load r8-r31
ld %r9,16(%r6)
ld %r10,24(%r6)
ld %r11,32(%r6)
ld %r12,40(%r6)
ld %r13,48(%r6)
ld %r14,56(%r6)
ld %r15,64(%r6)
ld %r16,72(%r6)
ld %r17,80(%r6)
ld %r18,88(%r6)
ld %r19,96(%r6)
ld %r20,104(%r6)
ld %r21,112(%r6)
ld %r22,120(%r6)
ld %r23,128(%r6)
ld %r24,136(%r6)
ld %r25,144(%r6)
ld %r26,152(%r6)
ld %r27,160(%r6)
ld %r28,168(%r6)
ld %r29,176(%r6)
ld %r30,184(%r6)
ld %r31,192(%r6)
mr %r6,%r4
mtlr %r11
mtcr %r12
mr %r2,%r9
mr %r1,%r10
addi %r4,%r3,100 # &sigmask
li %r3,3 # SIG_SETMASK
li %r5,0
_DOSYSCALL(__sigprocmask14) # assume no error XXX
or. %r3,%r6,%r6
bnelr
li %r3,1
blr
END(__longjmp14)
|