summaryrefslogtreecommitdiff
path: root/thumb2startup.s
diff options
context:
space:
mode:
Diffstat (limited to 'thumb2startup.s')
-rw-r--r--thumb2startup.s280
1 files changed, 140 insertions, 140 deletions
diff --git a/thumb2startup.s b/thumb2startup.s
index 57dcb00..a14cae1 100644
--- a/thumb2startup.s
+++ b/thumb2startup.s
@@ -528,41 +528,41 @@ abc_main:
lao r12,start_address,0
sto r4,r12,start_address,0
.endif
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_clean
tst r4,r4
bne init_error
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_timer
lao r12,halt_sp,0
sto sp,r12,halt_sp,0
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_profiler
.endif
.ifdef DLL
lao r12,start_address,1
ldo r4,r12,start_address,1
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
blx r4
.else
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl __start
.endif
.thumb_func
exit:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl exit_clean
.thumb_func
@@ -578,22 +578,22 @@ clean_init:
mov r0,#1
sto r0,r12,dll_initisialised,0
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_clean
tst r4,r4
bne init_dll_error
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_timer
lao r12,halt_sp,1
sto sp,r12,halt_sp,1
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl init_profiler
.endif
@@ -624,8 +624,8 @@ clean_fini:
lao r12,saved_a_stack_p,1
ldo r9,r12,saved_a_stack_p,1
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl exit_clean
.thumb_func
@@ -923,8 +923,8 @@ no_memory_3:
.thumb_func
exit_clean:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_execute_time
lao r4,flags,4
@@ -939,8 +939,8 @@ exit_clean:
lao r12,execute_time,0
ldo r4,r12,execute_time,0
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl print_time
lao r0,time_string_2,0
@@ -950,8 +950,8 @@ exit_clean:
lao r12,garbage_collect_time,0
ldo r4,r12,garbage_collect_time,0
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl print_time
lao r0,time_string_4,0
@@ -967,8 +967,8 @@ exit_clean:
ldo r12,r12,IO_time,0
add r4,r12
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl print_time
mov r0,#10
@@ -985,8 +985,8 @@ no_print_execution_time:
bl free
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl write_profile_information
.endif
@@ -1173,8 +1173,8 @@ end_print:
.thumb_func
dump:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl print
b halt
@@ -1536,8 +1536,8 @@ ItoAC:
.if MY_ITOS
lao r6,sprintf_buffer,2
otoa r6,sprintf_buffer,2
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl int_to_string
lao r12,sprintf_buffer,3
@@ -1768,8 +1768,8 @@ get_time_diff:
.thumb_func
add_execute_time:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl get_time_diff
lao r6,execute_time,3
otoa r6,execute_time,3
@@ -1783,16 +1783,16 @@ add_time:
.thumb_func
add_garbage_collect_time:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl get_time_diff
lao r6,garbage_collect_time,3
otoa r6,garbage_collect_time,3
b add_time
add_IO_time:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl get_time_diff
lao r6,IO_time,2
otoa r6,IO_time,2
@@ -1902,8 +1902,8 @@ collect_3:
.ifdef PROFILE
lao r8,garbage_collector_name,0
otoa r8,garbage_collector_name,0
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_s
.endif
str r6,[r9]
@@ -1925,8 +1925,8 @@ collect_2:
.ifdef PROFILE
lao r8,garbage_collector_name,1
otoa r8,garbage_collector_name,1
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_s
.endif
str r6,[r9]
@@ -1946,8 +1946,8 @@ collect_1:
.ifdef PROFILE
lao r8,garbage_collector_name,2
otoa r8,garbage_collector_name,2
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_s
.endif
str r6,[r9],#4
@@ -1964,8 +1964,8 @@ collect_0:
str lr,[sp,#-4]!
lao r8,garbage_collector_name,3
otoa r8,garbage_collector_name,3
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_s
bl collect_0_
b profile_r
@@ -2136,8 +2136,8 @@ no_mark3:
.thumb_func
collect:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_execute_time
lao r12,flags,7
@@ -2210,8 +2210,8 @@ no_print_stack_sizes:
subs r4,r4,r12
add r4,r4,#63*4
lsr r4,r4,#8
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl zero_bit_vector
lao r12,heap_end_after_copy_gc,2
@@ -2234,8 +2234,8 @@ no_print_stack_sizes:
mov r14,#0
sto r14,r12,heap_end_after_copy_gc,3
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl zero_bit_vector
b end_zero_bit_vector
@@ -2244,8 +2244,8 @@ zero_all:
lao r12,heap_copied_vector_size,3
ldo r4,r12,heap_copied_vector_size,3
lsr r4,r4,#2
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl zero_bit_vector
.thumb_func
@@ -2263,8 +2263,8 @@ end_zero_bit_vector:
ldr r9,[sp],#4
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_garbage_collect_time
lao r12,n_allocated_words,2
@@ -2409,8 +2409,8 @@ no_mark_scan:
str r6,[sp,#-4]!
str r3,[sp,#-4]!
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl _munmap
add sp,sp,#8
@@ -2494,8 +2494,8 @@ end_garbage_collect_:
no_heap_use_message:
.if FINALIZERS
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl call_finalizers
.endif
@@ -2758,8 +2758,8 @@ copy_to_compact_with_alloc_in_extra_heap:
.endif
out_of_memory_4:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_garbage_collect_time
lao r8,out_of_memory_string_4,0
@@ -3144,8 +3144,8 @@ vector_at_end_2:
.thumb_func
no_copy_garbage_collection:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_garbage_collect_time
mov r4,r10
@@ -3159,8 +3159,8 @@ no_copy_garbage_collection:
.thumb_func
stack_overflow:
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl add_execute_time
lao r8,stack_overflow_string,0
@@ -3194,8 +3194,8 @@ halt:
ldo sp,r12,halt_sp,3
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl write_profile_stack
.endif
@@ -3253,8 +3253,8 @@ eval_fill:
str r6,[r9],#4
mov r6,r7
ldr r12,[r7]
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
blx r12
mov r7,r6
ldr r6,[r9,#-4]!
@@ -3311,8 +3311,8 @@ eval_fill2:
add r9,r9,#4
mov r6,r7
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
blx r4
mov r7,r6
ldr r6,[r9,#-4]!
@@ -3327,8 +3327,8 @@ eval_fill2:
.endif
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3340,8 +3340,8 @@ eval_upd_0:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3355,8 +3355,8 @@ eval_upd_1:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3370,8 +3370,8 @@ eval_upd_2:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3387,8 +3387,8 @@ eval_upd_3:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3407,8 +3407,8 @@ eval_upd_4:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3429,8 +3429,8 @@ eval_upd_5:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3453,8 +3453,8 @@ eval_upd_6:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3490,8 +3490,8 @@ eval_upd_n_lp:
mov pc,r11
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3501,8 +3501,8 @@ eval_upd_8:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3512,8 +3512,8 @@ eval_upd_9:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3523,8 +3523,8 @@ eval_upd_10:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3534,8 +3534,8 @@ eval_upd_11:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3545,8 +3545,8 @@ eval_upd_12:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3556,8 +3556,8 @@ eval_upd_13:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3567,8 +3567,8 @@ eval_upd_14:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3578,8 +3578,8 @@ eval_upd_15:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3589,8 +3589,8 @@ eval_upd_16:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3600,8 +3600,8 @@ eval_upd_17:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3611,8 +3611,8 @@ eval_upd_18:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3622,8 +3622,8 @@ eval_upd_19:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3633,8 +3633,8 @@ eval_upd_20:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3644,8 +3644,8 @@ eval_upd_21:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3655,8 +3655,8 @@ eval_upd_22:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3666,8 +3666,8 @@ eval_upd_23:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3677,8 +3677,8 @@ eval_upd_24:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3688,8 +3688,8 @@ eval_upd_25:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3699,8 +3699,8 @@ eval_upd_26:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3710,8 +3710,8 @@ eval_upd_27:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3721,8 +3721,8 @@ eval_upd_28:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3732,8 +3732,8 @@ eval_upd_29:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3743,8 +3743,8 @@ eval_upd_30:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif
@@ -3754,8 +3754,8 @@ eval_upd_31:
b eval_upd_n
.ifdef PROFILE
- mov r12,pc
- str r12,[sp,#-4]!
+ add lr,pc,#9
+ str lr,[sp,#-4]!
bl profile_n
mov r8,r4
.endif