Skip to content

Commit 3d0d144

Browse files
ILyoanbrson
authored andcommitted
rust morestack assembly for arm
Conflicts: src/rt/arch/arm/morestack.S
1 parent 4b4f482 commit 3d0d144

File tree

2 files changed

+60
-42
lines changed

2 files changed

+60
-42
lines changed

src/rt/arch/arm/morestack.S

Lines changed: 54 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,59 @@
88
.arm
99
.align
1010

11-
.globl __morestack
11+
.global upcall_new_stack
12+
.global upcall_del_stack
13+
.global __morestack
1214
.hidden __morestack
15+
16+
// r4 and r5 are scratch registers for __morestack due to llvm
17+
// ARMFrameLowering::adjustForSegmentedStacks() implementation.
18+
.align 2
19+
.type __morestack,%function
1320
__morestack:
21+
22+
// Save frame pointer and return address
23+
push {fp, lr}
24+
25+
mov fp, sp
26+
27+
// Save argument registers of the original function
28+
push {r0, r1, r2, r3, lr}
29+
30+
mov r0, r4 // The amount of stack needed
31+
add r1, fp, #20 // Address of stack arguments
32+
mov r2, r5 // Size of stack arguments
33+
34+
// Create new stack
35+
bl upcall_new_stack@plt
36+
37+
// Hold new stack pointer
38+
mov r5, r0
39+
40+
// Pop the saved arguments
41+
pop {r0, r1, r2, r3, lr}
42+
43+
// Grab the return pointer
44+
add r4, lr, #16 // Skip past the return
45+
mov sp, r5 // Swich to the new stack
46+
mov lr, pc
47+
mov pc, r4 // Call the original function
48+
49+
// Switch back to rust stack
50+
mov sp, fp
51+
52+
// Save return value
53+
push {r0, r1}
54+
55+
// Remove the new allocated stack
56+
bl upcall_del_stack@plt
57+
58+
// Restore return value
59+
pop {r0, r1}
60+
61+
// Return
62+
pop {fp, lr}
63+
mov pc, lr
64+
.endofmorestack:
65+
.size __morestack, .endofmorestack-__morestack
66+

src/rt/arch/arm/record_sp.S

Lines changed: 6 additions & 41 deletions
Original file line numberDiff line numberDiff line change
@@ -14,53 +14,18 @@
1414
.globl get_sp
1515

1616
record_sp_limit:
17-
mov r3, r0
18-
ldr r0, =my_cpu
19-
mov r1, #0
20-
mov r2, #0
21-
stmfd sp!, {r3, r7}
22-
ldr r7, =345
23-
swi #0
24-
ldmfd sp!, {r3, r7}
25-
movs r0, r0
26-
movmi r0, #0
27-
28-
ldr r1, =my_array
29-
str r3, [r1, r0]
17+
mrc p15, #0, r3, c13, c0, #3
18+
add r3, r3, #252
19+
str r0, [r3]
3020
mov pc, lr
3121

32-
3322
get_sp_limit:
34-
ldr r0, =my_cpu
35-
mov r1, #0
36-
mov r2, #0
37-
stmfd sp!, {r4, r7}
38-
ldr r7, =345
39-
swi #0
40-
ldmfd sp!, {r4, r7}
41-
movs r0, r0
42-
movmi r0, #0
43-
mov r3, r0
44-
45-
ldr r1, =my_array
46-
ldr r0, [r1, r3]
23+
mrc p15, #0, r3, c13, c0, #3
24+
add r3, r3, #252
25+
ldr r0, [r3]
4726
mov pc, lr
4827

49-
5028
get_sp:
5129
mov r0, sp
5230
mov pc, lr
5331

54-
.data
55-
my_cpu: .long 0
56-
.global my_array
57-
my_array:
58-
.long 0
59-
.long 0
60-
.long 0
61-
.long 0
62-
.long 0
63-
.long 0
64-
.long 0
65-
.long 0
66-
.end

0 commit comments

Comments
 (0)