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