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 r0
mfcr r5
mfctr r6
mfxer r7
stw r0, 0*4(r3)
stw r5, 1*4(r3)
stw r6, 2*4(r3)
stw r7, 3*4(r3)
stw r1, 4*4(r3)
stw r2, 5*4(r3)
stw r13, (0+6)*4(r3) /* callee-save GPRs */
stw r14, (1+6)*4(r3) /* xxx: block move */
stw r15, (2+6)*4(r3)
stw r16, (3+6)*4(r3)
stw r17, (4+6)*4(r3)
stw r18, (5+6)*4(r3)
stw r19, (6+6)*4(r3)
stw r20, (7+6)*4(r3)
stw r21, (8+6)*4(r3)
stw r22, (9+6)*4(r3)
stw r23, (10+6)*4(r3)
stw r24, (11+6)*4(r3)
stw r25, (12+6)*4(r3)
stw r26, (13+6)*4(r3)
stw r27, (14+6)*4(r3)
stw r28, (15+6)*4(r3)
stw r29, (16+6)*4(r3)
stw r30, (17+6)*4(r3)
stw r31, (18+6)*4(r3)
li r3, 0 /* return */
blr
.globl __gotolabel
__gotolabel:
lwz r13, (0+6)*4(r3) /* callee-save GPRs */
lwz r14, (1+6)*4(r3) /* xxx: block move */
lwz r15, (2+6)*4(r3)
lwz r16, (3+6)*4(r3)
lwz r17, (4+6)*4(r3)
lwz r18, (5+6)*4(r3)
lwz r19, (6+6)*4(r3)
lwz r20, (7+6)*4(r3)
lwz r21, (8+6)*4(r3)
lwz r22, (9+6)*4(r3)
lwz r23, (10+6)*4(r3)
lwz r24, (11+6)*4(r3)
lwz r25, (12+6)*4(r3)
lwz r26, (13+6)*4(r3)
lwz r27, (14+6)*4(r3)
lwz r28, (15+6)*4(r3)
lwz r29, (16+6)*4(r3)
lwz r30, (17+6)*4(r3)
lwz r31, (18+6)*4(r3)
lwz r1, 4*4(r3)
lwz r2, 5*4(r3)
lwz r0, 0*4(r3)
mtlr r0
lwz r0, 1*4(r3)
mtcr r0 /* mtcrf 0xFF, r0 */
lwz r0, 2*4(r3)
mtctr r0
lwz r0, 3*4(r3)
mtxer r0
li r3, 1
blr
|