aboutsummaryrefslogtreecommitdiff
path: root/libgloss/arm/crt0.S
diff options
context:
space:
mode:
authorJeff Johnston <jjohnstn@redhat.com>2006-02-07 18:46:23 +0000
committerJeff Johnston <jjohnstn@redhat.com>2006-02-07 18:46:23 +0000
commitf9fa511d46228486425d0f85437c71547925195f (patch)
treeef4f815bb69ea64dd1a7461d1a48b595a0533a8e /libgloss/arm/crt0.S
parent9bbe6d5d283de104216238d684e0a46506326706 (diff)
downloadnewlib-f9fa511d46228486425d0f85437c71547925195f.zip
newlib-f9fa511d46228486425d0f85437c71547925195f.tar.gz
newlib-f9fa511d46228486425d0f85437c71547925195f.tar.bz2
2006-02-07 Paul Brook <paul@codesourcery.com>
* arm/crt0.S: Add Thumb-2 startup code. * arm/redboot-crt0.S: Ditto. * arm/libcfunc.c (do_AngelSWI): Use AngelSWIInsn. * arm/swi.h (AngelSWIInsn, AngelSWIAsm): Define. * arm/trap.S: Disable for Thumb-2.
Diffstat (limited to 'libgloss/arm/crt0.S')
-rw-r--r--libgloss/arm/crt0.S38
1 files changed, 27 insertions, 11 deletions
diff --git a/libgloss/arm/crt0.S b/libgloss/arm/crt0.S
index bea2892..823f409 100644
--- a/libgloss/arm/crt0.S
+++ b/libgloss/arm/crt0.S
@@ -18,15 +18,26 @@
/* .text is used instead of .section .text so it works with arm-aout too. */
.text
+#if defined(__thumb2__)
+ .syntax unified
+ .thumb
+.macro FUNC_START name
+ .global \name
+ .thumb_func
+\name:
+.endm
+#else
.code 32
+.macro FUNC_START name
+ .global \name
+\name:
+.endm
+#endif
.align 0
- .global _mainCRTStartup
- .global _start
- .global start
-start:
-_start:
-_mainCRTStartup:
+ FUNC_START _mainCRTStartup
+ FUNC_START _start
+ FUNC_START start
#if defined(__ELF__) && !defined(__USING_SJLJ_EXCEPTIONS__)
/* Annotation for EABI unwinding tables. */
.fnstart
@@ -45,7 +56,12 @@ _mainCRTStartup:
/* Issue Angel SWI to read stack info */
mov r0, #AngelSWI_Reason_HeapInfo
adr r1, .LC0 /* point at ptr to 4 words to receive data */
- swi AngelSWI_ARM /* We are always in ARM mode for startup */
+#if defined(__thumb2__)
+ bkpt AngelSWI
+#else
+ /* We are always in ARM mode for startup */
+ AngelSWIAsm AngelSWI_ARM
+#endif
ldr r0, .LC0 /* point at values read */
ldr sp, [r0, #8]
ldr sl, [r0, #12]
@@ -124,8 +140,8 @@ _mainCRTStartup:
sub a3, a3, a1 /* Third arg: length of block */
-#ifdef __thumb__ /* Enter Thumb mode.... */
-
+#if defined(__thumb__) && !defined(__thumb2__)
+ /* Enter Thumb mode.... */
add a4, pc, #1 /* Get the address of the Thumb block */
bx a4 /* Go there and start Thumb decoding */
@@ -165,7 +181,7 @@ __change_mode:
#else
mov r0, #AngelSWI_Reason_GetCmdLine
adr r1, .LC30 /* Space for command line */
- swi AngelSWI
+ AngelSWIAsm AngelSWI
ldr r1, .LC30
#endif
/* Parse string at r1 */
@@ -287,7 +303,7 @@ __change_mode:
bl FUNCTION (exit) /* Should not return. */
-#ifdef __thumb__
+#if defined(__thumb__) && !defined(__thumb2__)
/* Come out of Thumb mode. This code should be redundant. */
mov a4, pc