diff options
author | Jeff Johnston <jjohnstn@redhat.com> | 2011-12-13 22:45:12 +0000 |
---|---|---|
committer | Jeff Johnston <jjohnstn@redhat.com> | 2011-12-13 22:45:12 +0000 |
commit | 50e970d1b16e3eb67a091de05661892f9c1ae77e (patch) | |
tree | 70fdde3f18c1cadcca9bab2f4a92595f4556219f /libgloss | |
parent | e480bc80c30631ee5634b4b3aed63660109091e0 (diff) | |
download | newlib-50e970d1b16e3eb67a091de05661892f9c1ae77e.zip newlib-50e970d1b16e3eb67a091de05661892f9c1ae77e.tar.gz newlib-50e970d1b16e3eb67a091de05661892f9c1ae77e.tar.bz2 |
2011-12-13 Richard Earnshaw <rearnsha@arm.com>
Thomas Klein <th.r.klein@web.de>
* arm/crt0.S: Manually set the target architecture
when compiling for Thumb1 on EABI targets.
Avoid v6-only Thumb-1 MOV instruction.
Diffstat (limited to 'libgloss')
-rw-r--r-- | libgloss/ChangeLog | 7 | ||||
-rw-r--r-- | libgloss/arm/crt0.S | 38 |
2 files changed, 38 insertions, 7 deletions
diff --git a/libgloss/ChangeLog b/libgloss/ChangeLog index b0048e4..ada15f0 100644 --- a/libgloss/ChangeLog +++ b/libgloss/ChangeLog @@ -1,3 +1,10 @@ +2011-12-13 Richard Earnshaw <rearnsha@arm.com> + Thomas Klein <th.r.klein@web.de> + + * arm/crt0.S: Manually set the target architecture + when compiling for Thumb1 on EABI targets. + Avoid v6-only Thumb-1 MOV instruction. + 2011-11-28 DJ Delorie <dj@redhat.com> * configure.in: Add rl78. diff --git a/libgloss/arm/crt0.S b/libgloss/arm/crt0.S index 101041e..92e7648 100644 --- a/libgloss/arm/crt0.S +++ b/libgloss/arm/crt0.S @@ -17,6 +17,30 @@ #define _fini __libc_fini_array #endif +#if defined(__ARM_EABI__) && defined(__thumb__) && !defined(__thumb2__) +/* For Thumb1 we need to force the architecture to be sure that we get the + correct attributes on the object file; otherwise the assembler will get + confused and mark the object as being v6T2. */ +#if defined(__ARM_ARCH_4T__) + .arch armv4t +#elif defined(__ARM_ARCH_5T__) || defined(__ARM_ARCH_5TE__) + /* Nothing in this object requires higher than v5. */ + .arch armv5t +#elif defined(__ARM_ARCH_6__) || defined(__ARM_ARCH_6J__) \ + || defined(__ARM_ARCH_6K__) || defined(__ARM_ARCH_6Z__) \ + || defined(__ARM_ARCH_6ZK__) + /* Nothing in this object requires higher than v6. */ + .arch armv6 +#elif defined(__ARM_ARCH_6M__) +#ifdef ARM_RDP_MONITOR + /* Object file uses SVC, so mark as v6s-m. */ + .arch armv6s-m +#else + .arch armv6-m +#endif +#endif +#endif + /* .text is used instead of .section .text so it works with arm-aout too. */ .text .syntax unified @@ -250,7 +274,7 @@ __change_mode: #ifdef ARM_RDP_MONITOR swi SWI_GetEnv /* sets r0 to point to the command line */ - mov r1, r0 + movs r1, r0 #else movs r0, #AngelSWI_Reason_GetCmdLine adr r1, .LC30 /* Space for command line */ @@ -285,7 +309,7 @@ __change_mode: cmp r3, #'\'' bne .LC21 .LC20: - mov r2, r3 + movs r2, r3 b .LC22 .LC21: @@ -326,7 +350,7 @@ __change_mode: mov r1, sp /* point at stacked arg pointers */ /* We've now got the stacked args in order reverse the */ #ifdef __thumb__ - mov r2, r0 + movs r2, r0 lsls r2, #2 add r2, sp mov r3, sp @@ -364,13 +388,13 @@ __change_mode: to create constructors and destructors, and for these targets we need to call the _init function and arrange for _fini to be called at program exit. */ - mov r4, r0 - mov r5, r1 + movs r4, r0 + movs r5, r1 ldr r0, .Lfini bl FUNCTION (atexit) bl FUNCTION (_init) - mov r0, r4 - mov r1, r5 + movs r0, r4 + movs r1, r5 #endif bl FUNCTION (main) |