summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/arm
diff options
context:
space:
mode:
authorEric Andersen <andersen@codepoet.org>2001-02-23 09:19:24 +0000
committerEric Andersen <andersen@codepoet.org>2001-02-23 09:19:24 +0000
commitc2ba9eda4a5cd8fa5f2b176cc75a21c4f671a992 (patch)
tree62205e94bfb7383e05af5469b73a354315285f6b /libc/sysdeps/linux/arm
parent48518a1ae1af1e29d14197b4aa93100e609ea854 (diff)
Update arm for the new way of entering main. BTW, I can now run things on arm
as a shared library, using the glibc shared lib loader. :-) I've updated the pic case but havn't tested it yet. -Erik
Diffstat (limited to 'libc/sysdeps/linux/arm')
-rw-r--r--libc/sysdeps/linux/arm/crt0.S86
-rw-r--r--libc/sysdeps/linux/arm/crt0pic.S69
2 files changed, 54 insertions, 101 deletions
diff --git a/libc/sysdeps/linux/arm/crt0.S b/libc/sysdeps/linux/arm/crt0.S
index 3660f4167..a0fad121c 100644
--- a/libc/sysdeps/linux/arm/crt0.S
+++ b/libc/sysdeps/linux/arm/crt0.S
@@ -12,39 +12,35 @@
a2=argv[0]
a3=argv[argc+1]
-This file now uses the register naming from the ARM Procedure Calling Standard
-
- Name Number APCS Role
-
- a1 0 argument 1 / integer result / scratch register / argc
- a2 1 argument 2 / scratch register / argv
- a3 2 argument 3 / scratch register / envp
- a4 3 argument 4 / scratch register
- v1 4 register variable
- v2 5 register variable
- v3 6 register variable
- v4 7 register variable
- v5 8 register variable
- sb/v6 9 static base / register variable
- sl/v7 10 stack limit / stack chunk handle / reg. variable
- fp 11 frame pointer
- ip 12 scratch register / new-sb in inter-link-unit calls
- sp 13 lower end of current stack frame
- lr 14 link address / scratch register
- pc 15 program counter
+ARM register quick reference:
+
+ Name Number ARM Procedure Calling Standard Role
+
+ a1 r0 argument 1 / integer result / scratch register / argc
+ a2 r1 argument 2 / scratch register / argv
+ a3 r2 argument 3 / scratch register / envp
+ a4 r3 argument 4 / scratch register
+ v1 r4 register variable
+ v2 r5 register variable
+ v3 r6 register variable
+ v4 r7 register variable
+ v5 r8 register variable
+ sb/v6 r9 static base / register variable
+ sl/v7 r10 stack limit / stack chunk handle / reg. variable
+ fp r11 frame pointer
+ ip r12 scratch register / new-sb in inter-link-unit calls
+ sp r13 lower end of current stack frame
+ lr r14 link address / scratch register
+ pc r15 program counter
*/
.text
- .align 2
- .global __environ
.global _start
- .global exit
- .global main
+ .global __uClibc_main
.type _start,%function
- .type exit,%function
- .type main,%function
+ .type __uClibc_main,%function
.text
_start:
@@ -52,35 +48,17 @@ _start:
/* clear the frame pointer */
mov fp, #0
- /* Load register a1 (argc) from the stack to its final resting place */
- ldr a1, [sp], #4
-
- /* Copy argv pointer into a2 -- which its final resting place */
- mov a2, sp
-
- /* Set up environ, skip to the end of argv, and put
- * a pointer to whatever we find there (hopefully the
- environment) in a3 */
- ldr a4, .L3
- add a3, a2, a1, lsl #2
- add a3, a3, #4
- str a3, [a4, #0]
+ /* Load register r0 (argc) from the stack to its final resting place */
+ ldr r0, [sp], #4
- bl main
- bl exit
+ /* Copy argv pointer into r1 -- which its final resting place */
+ mov r1, sp
-.align 2
-.L3:
- .word __environ
-
-
-.data
- .align 2
- .global __environ
-
-__environ:
- .long 0
+ /* Skip to the end of argv and put a pointer to whatever
+ we find there (hopefully the environment) in a3 */
+ add r2, r1, r0, lsl #2
+ add r2, r2, #4
-.weak environ
-environ = __environ
+ /* Ok, now run uClibc's main() -- shouldn't return */
+ bl __uClibc_main
diff --git a/libc/sysdeps/linux/arm/crt0pic.S b/libc/sysdeps/linux/arm/crt0pic.S
index 04b1cb755..7cb26e80e 100644
--- a/libc/sysdeps/linux/arm/crt0pic.S
+++ b/libc/sysdeps/linux/arm/crt0pic.S
@@ -14,37 +14,32 @@
ARM register quick reference:
- Name Number APCS Role
-
- a1 0 argument 1 / integer result / scratch register / argc
- a2 1 argument 2 / scratch register / argv
- a3 2 argument 3 / scratch register / envp
- a4 3 argument 4 / scratch register
- v1 4 register variable
- v2 5 register variable
- v3 6 register variable
- v4 7 register variable
- v5 8 register variable
- sb/v6 9 static base / register variable
- sl/v7 10 stack limit / stack chunk handle / reg. variable
- fp 11 frame pointer
- ip 12 scratch register / new-sb in inter-link-unit calls
- sp 13 lower end of current stack frame
- lr 14 link address / scratch register
- pc 15 program counter
+ Name Number ARM Procedure Calling Standard Role
+
+ a1 r0 argument 1 / integer result / scratch register / argc
+ a2 r1 argument 2 / scratch register / argv
+ a3 r2 argument 3 / scratch register / envp
+ a4 r3 argument 4 / scratch register
+ v1 r4 register variable
+ v2 r5 register variable
+ v3 r6 register variable
+ v4 r7 register variable
+ v5 r8 register variable
+ sb/v6 r9 static base / register variable
+ sl/v7 r10 stack limit / stack chunk handle / reg. variable
+ fp r11 frame pointer
+ ip r12 scratch register / new-sb in inter-link-unit calls
+ sp r13 lower end of current stack frame
+ lr r14 link address / scratch register
+ pc r15 program counter
*/
.text
- .align 2
- .global __environ
.global _start
- .global exit
- .global main
+ .global __uClibc_main
.type _start,%function
- .type exit,%function
- .type main,%function
-
+ .type __uClibc_main,%function
@ r0 = argc
@@ -60,31 +55,11 @@ _start:
sub sl,sl,r3
mov BASEREG,sl
- ldr r3, .L3
- str r2,[BASEREG,r3]
-
/* pull argc, argv and envp off the stack */
ldr r0,[sp, #0]
ldr r1,[sp, #4]
ldr r2,[sp, #8]
- bl main
-/* ldr r0,=0 */
- bl exit
-
-.align 2
-.L3:
- .word __environ
-
-
-.data
- .align 2
- .global __environ
-
-__environ:
- .long 0
-
-.weak environ
-environ = __environ
-
+ /* Ok, now run uClibc's main() -- shouldn't return */
+ bl __uClibc_main