swi 是 arm 的软件中断指令,是 software interrupt 的意思,执行完swi指令后,cpu会做几件事情:
①将swi的下一条指令地址保存到 r14_svc 中
②将当前 cpsr 保存到 spsr_svc 中
③将cpu模式改为特权模式svc_mode, 即更改 cpsr 的低五位, cspr[4:0]=0b10011
④切换到ARM状态, cspr[5]=0
⑤禁止IRQ, cspr[7]=1
⑥将 pc 置为 0x00000008, 即跳到中断向量的地方开始执行
编程异常通常叫做软中断.软中断是通讯进程之间用来模拟硬中断的一种信号通讯方式。中断源发中断请求或软中断信号后,CPU或接收进程在适当的时机自动进行中断处理
或完成软中断信号对应的功能.软中断是软件实现的中断,也就是程序运行时其他程序对它的中断;而硬中断是硬件实现的中断,是程序运行时设备对它的中断。
1.软中断发生的时间是由程序控制的,而硬中断发生的时间是随机的。
2.软中断是由程序调用发生的,而硬中断是由外设引发的。
3.硬件中断处理程序要确保它能快速地完成它的任务,这样程序执行时才不会等待较长时间。