diff options
| author | Eric Andersen <andersen@codepoet.org> | 2001-02-23 09:19:24 +0000 | 
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2001-02-23 09:19:24 +0000 | 
| commit | c2ba9eda4a5cd8fa5f2b176cc75a21c4f671a992 (patch) | |
| tree | 62205e94bfb7383e05af5469b73a354315285f6b | |
| parent | 48518a1ae1af1e29d14197b4aa93100e609ea854 (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
| -rw-r--r-- | libc/sysdeps/linux/arm/crt0.S | 86 | ||||
| -rw-r--r-- | libc/sysdeps/linux/arm/crt0pic.S | 69 | 
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 | 
