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
|
/* 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
|