1	.global ___setjmp
2	.hidden ___setjmp
3	.global __setjmp
4	.global _setjmp
5	.global setjmp
6	.type   __setjmp,@function
7	.type   _setjmp,@function
8	.type   setjmp,@function
9___setjmp:
10__setjmp:
11_setjmp:
12setjmp:
13	# 0) store IP into 0, then into the jmpbuf pointed to by r3 (first arg)
14	mflr  0
15	std   0,  0*8(3)
16	# 1) store cr
17	mfcr  0
18	std   0,  1*8(3)
19	# 2) store r1-r2 (SP and TOC)
20	std   1,  2*8(3)
21	std   2,  3*8(3)
22	# 3) store r14-31
23	std  14,  4*8(3)
24	std  15,  5*8(3)
25	std  16,  6*8(3)
26	std  17,  7*8(3)
27	std  18,  8*8(3)
28	std  19,  9*8(3)
29	std  20, 10*8(3)
30	std  21, 11*8(3)
31	std  22, 12*8(3)
32	std  23, 13*8(3)
33	std  24, 14*8(3)
34	std  25, 15*8(3)
35	std  26, 16*8(3)
36	std  27, 17*8(3)
37	std  28, 18*8(3)
38	std  29, 19*8(3)
39	std  30, 20*8(3)
40	std  31, 21*8(3)
41	# 4) store floating point registers f14-f31
42	stfd 14, 22*8(3)
43	stfd 15, 23*8(3)
44	stfd 16, 24*8(3)
45	stfd 17, 25*8(3)
46	stfd 18, 26*8(3)
47	stfd 19, 27*8(3)
48	stfd 20, 28*8(3)
49	stfd 21, 29*8(3)
50	stfd 22, 30*8(3)
51	stfd 23, 31*8(3)
52	stfd 24, 32*8(3)
53	stfd 25, 33*8(3)
54	stfd 26, 34*8(3)
55	stfd 27, 35*8(3)
56	stfd 28, 36*8(3)
57	stfd 29, 37*8(3)
58	stfd 30, 38*8(3)
59	stfd 31, 39*8(3)
60
61	# 5) store vector registers v20-v31
62	addi  3, 3, 40*8
63	stvx 20, 0, 3 ; addi 3, 3, 16
64	stvx 21, 0, 3 ; addi 3, 3, 16
65	stvx 22, 0, 3 ; addi 3, 3, 16
66	stvx 23, 0, 3 ; addi 3, 3, 16
67	stvx 24, 0, 3 ; addi 3, 3, 16
68	stvx 25, 0, 3 ; addi 3, 3, 16
69	stvx 26, 0, 3 ; addi 3, 3, 16
70	stvx 27, 0, 3 ; addi 3, 3, 16
71	stvx 28, 0, 3 ; addi 3, 3, 16
72	stvx 29, 0, 3 ; addi 3, 3, 16
73	stvx 30, 0, 3 ; addi 3, 3, 16
74	stvx 31, 0, 3
75
76	# 6) return 0
77	li 3, 0
78	blr
79