accept4: don't fall back to accept if we got unknown flags
[musl] / src / setjmp / powerpc64 / setjmp.s
1         .global __setjmp
2         .global _setjmp
3         .global setjmp
4         .type   __setjmp,@function
5         .type   _setjmp,@function
6         .type   setjmp,@function
7 __setjmp:
8 _setjmp:
9 setjmp:
10         ld 5, 24(1)   # load from the TOC slot in the caller's stack frame
11         b __setjmp_toc
12
13         .localentry __setjmp,.-__setjmp
14         .localentry _setjmp,.-_setjmp
15         .localentry setjmp,.-setjmp
16         mr 5, 2
17
18         .global __setjmp_toc
19         .hidden __setjmp_toc
20         # same as normal setjmp, except TOC pointer to save is provided in r5.
21         # r4 would normally be the 2nd parameter, but we're using r5 to simplify calling from sigsetjmp.
22         # solves the problem of knowing whether to save the TOC pointer from r2 or the caller's stack frame.
23 __setjmp_toc:
24         # 0) store IP into 0, then into the jmpbuf pointed to by r3 (first arg)
25         mflr  0
26         std   0,  0*8(3)
27         # 1) store cr
28         mfcr  0
29         std   0,  1*8(3)
30         # 2) store SP and TOC
31         std   1,  2*8(3)
32         std   5,  3*8(3)
33         # 3) store r14-31
34         std  14,  4*8(3)
35         std  15,  5*8(3)
36         std  16,  6*8(3)
37         std  17,  7*8(3)
38         std  18,  8*8(3)
39         std  19,  9*8(3)
40         std  20, 10*8(3)
41         std  21, 11*8(3)
42         std  22, 12*8(3)
43         std  23, 13*8(3)
44         std  24, 14*8(3)
45         std  25, 15*8(3)
46         std  26, 16*8(3)
47         std  27, 17*8(3)
48         std  28, 18*8(3)
49         std  29, 19*8(3)
50         std  30, 20*8(3)
51         std  31, 21*8(3)
52         # 4) store floating point registers f14-f31
53         stfd 14, 22*8(3)
54         stfd 15, 23*8(3)
55         stfd 16, 24*8(3)
56         stfd 17, 25*8(3)
57         stfd 18, 26*8(3)
58         stfd 19, 27*8(3)
59         stfd 20, 28*8(3)
60         stfd 21, 29*8(3)
61         stfd 22, 30*8(3)
62         stfd 23, 31*8(3)
63         stfd 24, 32*8(3)
64         stfd 25, 33*8(3)
65         stfd 26, 34*8(3)
66         stfd 27, 35*8(3)
67         stfd 28, 36*8(3)
68         stfd 29, 37*8(3)
69         stfd 30, 38*8(3)
70         stfd 31, 39*8(3)
71
72         # 5) store vector registers v20-v31
73         addi  3, 3, 40*8
74         stvx 20, 0, 3 ; addi 3, 3, 16
75         stvx 21, 0, 3 ; addi 3, 3, 16
76         stvx 22, 0, 3 ; addi 3, 3, 16
77         stvx 23, 0, 3 ; addi 3, 3, 16
78         stvx 24, 0, 3 ; addi 3, 3, 16
79         stvx 25, 0, 3 ; addi 3, 3, 16
80         stvx 26, 0, 3 ; addi 3, 3, 16
81         stvx 27, 0, 3 ; addi 3, 3, 16
82         stvx 28, 0, 3 ; addi 3, 3, 16
83         stvx 29, 0, 3 ; addi 3, 3, 16
84         stvx 30, 0, 3 ; addi 3, 3, 16
85         stvx 31, 0, 3
86
87         # 6) return 0
88         li 3, 0
89         blr