|
@@ -150,10 +150,10 @@ page_not_present:
|
|
|
tlbmiss_restore
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_page_fault
|
|
|
+ call do_page_fault
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
.align 2
|
|
@@ -250,7 +250,7 @@ syscall_badsys:
|
|
|
|
|
|
.global ret_from_fork
|
|
|
ret_from_fork:
|
|
|
- rcall schedule_tail
|
|
|
+ call schedule_tail
|
|
|
|
|
|
/* check for syscall tracing */
|
|
|
get_thread_info r0
|
|
@@ -261,7 +261,7 @@ ret_from_fork:
|
|
|
|
|
|
syscall_trace_enter:
|
|
|
pushm r8-r12
|
|
|
- rcall syscall_trace
|
|
|
+ call syscall_trace
|
|
|
popm r8-r12
|
|
|
rjmp syscall_trace_cont
|
|
|
|
|
@@ -269,14 +269,14 @@ syscall_exit_work:
|
|
|
bld r1, TIF_SYSCALL_TRACE
|
|
|
brcc 1f
|
|
|
unmask_interrupts
|
|
|
- rcall syscall_trace
|
|
|
+ call syscall_trace
|
|
|
mask_interrupts
|
|
|
ld.w r1, r0[TI_flags]
|
|
|
|
|
|
1: bld r1, TIF_NEED_RESCHED
|
|
|
brcc 2f
|
|
|
unmask_interrupts
|
|
|
- rcall schedule
|
|
|
+ call schedule
|
|
|
mask_interrupts
|
|
|
ld.w r1, r0[TI_flags]
|
|
|
rjmp 1b
|
|
@@ -287,7 +287,7 @@ syscall_exit_work:
|
|
|
unmask_interrupts
|
|
|
mov r12, sp
|
|
|
mov r11, r0
|
|
|
- rcall do_notify_resume
|
|
|
+ call do_notify_resume
|
|
|
mask_interrupts
|
|
|
ld.w r1, r0[TI_flags]
|
|
|
rjmp 1b
|
|
@@ -394,7 +394,7 @@ handle_critical:
|
|
|
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_critical_exception
|
|
|
+ call do_critical_exception
|
|
|
|
|
|
/* We should never get here... */
|
|
|
bad_return:
|
|
@@ -407,18 +407,18 @@ bad_return:
|
|
|
do_bus_error_write:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mov r11, 1
|
|
|
rjmp 1f
|
|
|
|
|
|
do_bus_error_read:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mov r11, 0
|
|
|
1: mfsr r12, SYSREG_BEAR
|
|
|
mov r10, sp
|
|
|
- rcall do_bus_error
|
|
|
+ call do_bus_error
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
.align 1
|
|
@@ -433,7 +433,7 @@ do_nmi_ll:
|
|
|
1: pushm r8, r9 /* PC and SR */
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_nmi
|
|
|
+ call do_nmi
|
|
|
popm r8-r9
|
|
|
mtsr SYSREG_RAR_NMI, r8
|
|
|
tst r0, r0
|
|
@@ -457,29 +457,29 @@ do_nmi_ll:
|
|
|
handle_address_fault:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_address_exception
|
|
|
+ call do_address_exception
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
handle_protection_fault:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_page_fault
|
|
|
+ call do_page_fault
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
.align 1
|
|
|
do_illegal_opcode_ll:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
mfsr r12, SYSREG_ECR
|
|
|
mov r11, sp
|
|
|
- rcall do_illegal_opcode
|
|
|
+ call do_illegal_opcode
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
do_dtlb_modified:
|
|
@@ -513,11 +513,11 @@ do_dtlb_modified:
|
|
|
do_fpe_ll:
|
|
|
sub sp, 4
|
|
|
stmts --sp, r0-lr
|
|
|
- rcall save_full_context_ex
|
|
|
+ call save_full_context_ex
|
|
|
unmask_interrupts
|
|
|
mov r12, 26
|
|
|
mov r11, sp
|
|
|
- rcall do_fpe
|
|
|
+ call do_fpe
|
|
|
rjmp ret_from_exception
|
|
|
|
|
|
ret_from_exception:
|
|
@@ -553,7 +553,7 @@ fault_resume_kernel:
|
|
|
lddsp r4, sp[REG_SR]
|
|
|
bld r4, SYSREG_GM_OFFSET
|
|
|
brcs 1f
|
|
|
- rcall preempt_schedule_irq
|
|
|
+ call preempt_schedule_irq
|
|
|
1:
|
|
|
#endif
|
|
|
|
|
@@ -582,7 +582,7 @@ fault_exit_work:
|
|
|
bld r1, TIF_NEED_RESCHED
|
|
|
brcc 1f
|
|
|
unmask_interrupts
|
|
|
- rcall schedule
|
|
|
+ call schedule
|
|
|
mask_interrupts
|
|
|
ld.w r1, r0[TI_flags]
|
|
|
rjmp fault_exit_work
|
|
@@ -593,7 +593,7 @@ fault_exit_work:
|
|
|
unmask_interrupts
|
|
|
mov r12, sp
|
|
|
mov r11, r0
|
|
|
- rcall do_notify_resume
|
|
|
+ call do_notify_resume
|
|
|
mask_interrupts
|
|
|
ld.w r1, r0[TI_flags]
|
|
|
rjmp fault_exit_work
|
|
@@ -616,10 +616,10 @@ handle_debug:
|
|
|
|
|
|
.Ldebug_fixup_cont:
|
|
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
|
|
- rcall trace_hardirqs_off
|
|
|
+ call trace_hardirqs_off
|
|
|
#endif
|
|
|
mov r12, sp
|
|
|
- rcall do_debug
|
|
|
+ call do_debug
|
|
|
mov sp, r12
|
|
|
|
|
|
lddsp r2, sp[REG_SR]
|
|
@@ -643,7 +643,7 @@ handle_debug:
|
|
|
mtsr SYSREG_RSR_DBG, r11
|
|
|
mtsr SYSREG_RAR_DBG, r10
|
|
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
|
|
- rcall trace_hardirqs_on
|
|
|
+ call trace_hardirqs_on
|
|
|
1:
|
|
|
#endif
|
|
|
ldmts sp++, r0-lr
|
|
@@ -676,7 +676,7 @@ debug_resume_kernel:
|
|
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
|
|
bld r11, SYSREG_GM_OFFSET
|
|
|
brcc 1f
|
|
|
- rcall trace_hardirqs_on
|
|
|
+ call trace_hardirqs_on
|
|
|
1:
|
|
|
#endif
|
|
|
mfsr r2, SYSREG_SR
|
|
@@ -747,7 +747,7 @@ irq_level\level:
|
|
|
mov r11, sp
|
|
|
mov r12, \level
|
|
|
|
|
|
- rcall do_IRQ
|
|
|
+ call do_IRQ
|
|
|
|
|
|
lddsp r4, sp[REG_SR]
|
|
|
bfextu r4, r4, SYSREG_M0_OFFSET, 3
|
|
@@ -767,7 +767,7 @@ irq_level\level:
|
|
|
|
|
|
1:
|
|
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
|
|
- rcall trace_hardirqs_on
|
|
|
+ call trace_hardirqs_on
|
|
|
#endif
|
|
|
popm r8-r9
|
|
|
mtsr rar_int\level, r8
|
|
@@ -807,7 +807,7 @@ irq_level\level:
|
|
|
lddsp r4, sp[REG_SR]
|
|
|
bld r4, SYSREG_GM_OFFSET
|
|
|
brcs 1b
|
|
|
- rcall preempt_schedule_irq
|
|
|
+ call preempt_schedule_irq
|
|
|
#endif
|
|
|
rjmp 1b
|
|
|
.endm
|