/* get FPR and VR use flags with sc 0x7FF3 */ /* get vsave with mfspr reg, 256 */ .text .align 2 .globl _setlabel _setlabel: /* xxx: instruction scheduling */ mflr 0 mfcr 5 mfctr 6 mfxer 7 stw 0, 0*4(3) stw 5, 1*4(3) stw 6, 2*4(3) stw 7, 3*4(3) stw 1, 4*4(3) stw 2, 5*4(3) stw 13, (0+6)*4(3) /* callee-save GPRs */ stw 14, (1+6)*4(3) /* xxx: block move */ stw 15, (2+6)*4(3) stw 16, (3+6)*4(3) stw 17, (4+6)*4(3) stw 18, (5+6)*4(3) stw 19, (6+6)*4(3) stw 20, (7+6)*4(3) stw 21, (8+6)*4(3) stw 22, (9+6)*4(3) stw 23, (10+6)*4(3) stw 24, (11+6)*4(3) stw 25, (12+6)*4(3) stw 26, (13+6)*4(3) stw 27, (14+6)*4(3) stw 28, (15+6)*4(3) stw 29, (16+6)*4(3) stw 30, (17+6)*4(3) stw 31, (18+6)*4(3) li 3, 0 /* return */ blr .globl _gotolabel _gotolabel: lwz 13, (0+6)*4(3) /* callee-save GPRs */ lwz 14, (1+6)*4(3) /* xxx: block move */ lwz 15, (2+6)*4(3) lwz 16, (3+6)*4(3) lwz 17, (4+6)*4(3) lwz 18, (5+6)*4(3) lwz 19, (6+6)*4(3) lwz 20, (7+6)*4(3) lwz 21, (8+6)*4(3) lwz 22, (9+6)*4(3) lwz 23, (10+6)*4(3) lwz 24, (11+6)*4(3) lwz 25, (12+6)*4(3) lwz 26, (13+6)*4(3) lwz 27, (14+6)*4(3) lwz 28, (15+6)*4(3) lwz 29, (16+6)*4(3) lwz 30, (17+6)*4(3) lwz 31, (18+6)*4(3) lwz 1, 4*4(3) lwz 2, 5*4(3) lwz 0, 0*4(3) mtlr 0 lwz 0, 1*4(3) mtcr 0 /* mtcrf 0xFF, r0 */ lwz 0, 2*4(3) mtctr 0 lwz 0, 3*4(3) mtxer 0 li 3, 1 blr