1.软中断?
由软件产生的中断
2.处理器中的寄存器?
ARM架构处理器共40个寄存器:
包括:USER模式下的R0~R15(R13:SP R14:LR R15:PC),CPSR,共17个寄存器,FIQ模式下的R8~R12的5个私有寄存器,SP,LR,,SPSR共8个寄存器,其他5种模式下对应的SP,LR,SPSR共15个,加起来一共40个寄存器
3.软中断处理过程?
流程:当产生中断以后,通过中断向量表的地址找到该中断的入口,去执行该中断,执行之前,需要先将之前模式下对应的寄存器进行压栈,即保存现场,由于除开FIQ模式下的R8~R12的5个私有寄存器以外,其他模式下的R0~R12,FIQ模式下R0~R7都是通用寄存器,所以需要先将寄存器在内存中进行压栈处理,同时还需要将跳转指令的下一条指令地址保存到中断模式下的LR寄存器中,另外还需要把CPSR寄存器保存到中断模式下的SPSR寄存器中,当中断执行完成以后,需要将对应的寄存器进行出栈恢复,另外将LR给到PC寄存器,将SPSR给到CPSR寄存器即可