diff options
Diffstat (limited to 'thumb2startup.s')
-rw-r--r-- | thumb2startup.s | 280 |
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 |