linux-2.6.26內核中ARM中斷實現詳解(2)
#define asmlinkage CPP_ASMLINKAGE __attribute__((regparm(0)))
表示函數的參數傳遞是通過堆棧完成的。
3.7 描述3.3節(jié)中的ret_to_user 中斷返回過程,/arch/arm/kernel/entry-common.S
ENTRY(ret_to_user)
ret_slow_syscall:
disable_irq @ disable interrupts
ldr r1, [tsk, #TI_FLAGS]
tst r1, #_TIF_WORK_MASK
bne work_pending
no_work_pending:
/* perform. architecture specific actions before user return */
arch_ret_to_user r1, lr
@ slow_restore_user_regs
ldr r1, [sp, #S_PSR] @ get calling cpsr
ldr lr, [sp, #S_PC]! @ get pc
msr spsr_cxsf, r1 @ save in spsr_svc
ldmdb sp, {r0 - lr}^ @ get calling r0 - lr
mov r0, r0
add sp, sp, #S_FRAME_SIZE - S_PC
movs pc, lr @ return move spsr_svc into cpsr
第三章主要跟蹤了從中斷發(fā)生到調用到對應中斷號的desc->handle_irq(irq, desc)中斷函數的過程。后面的章節(jié)還會繼續(xù)講解后面的內容。
linux操作系統文章專題:linux操作系統詳解(linux不再難懂)
評論