当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。

11.7异常中断产生指令(断点指令)

Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。

11.7.1软中断指令SWI

(1)编码格式

软中断指令SWI的编码格式如图11.63所示。

图11.63SWI指令的编码格式

软中断指令SWI(SoftwareInterrupt)用于使处理器产生软中断异常,使用这种机制实现在用户模式对操作系统中特权模式的程序调用。

(2)指令的语法格式

SWI<immed_8>

其中,immed_8为8位立即数,该立即数被处理器忽略,但可以被操作系统用来判断用户程序请求的服务类型。

(3)指令操作的伪代码

R14_svc=addressofnextinstructionaftertheSWIinstruction

SPSR_svc=CPSR

CPSR[4:0]=0b10011 /*进入超级模式*/

CPSR[5]=0 /*进入ARM状态*/

/*CPSR[6]isunchanged*/

CPSR[7]=1 /*禁止正常中断*/

Ifhighvectorsconfiguredthen

PC=0xffff0008

Else

PC=0x00000008

(4)对应的ARM指令

SWI<immed_8>

11.7.2断点中断指令 BKPT

(1)编码格式

断点中断指令BKPT的编码格式如图11.64所示。

图11.64BKPT指令的编码格式

断点中断指令BKPT(Breakpoint)可以使处理器产生预取异常(PrefetchAbort),使用这种机制可以在没有调试硬件的情况下,实现程序的软件调试。当系统中使用硬件调试部件时,可忽略该中断。

(2)指令的语法格式

BKPT<immed_8>

其中,immed_8为8位立即数,该立即数被处理器忽略,但可以向调试系统提供附加的断点信息。

注意

当系统中存在调试硬件时,BKPT指令有两种处理方法:一种由调试硬件处理BKPT指令;另一种可以直接由预取异常处理函数来处理BKPT指令,使用这种方法时,由于使用了异常模式下的链接地址寄存器r14_abt和程序状态寄存器SPSR_abt,所有要特别注意程序的嵌套。

(3)指令操作的伪代码

if(notoverriddenbydebughardware)

R14_abt=addressofBKPTinstruction+4

SPSR_abt=CPSR

CPSR[4:0]=0b10111 /*进入异常模式*/

CPSR[5]=0 /*进入ARM状态*/

/*CPSR[6]isunchanged*/

CPSR[7]=1

Ifhighvectorsconfiguredthen

PC=0xffff000c

Else

PC=0x0000000c

(4)对应的ARM指令

BKPT<immed_8>

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

ARM系统几乎都采用Linux的操作系统,而且几乎所有的硬件系统都要单独构建自己的系统,与其他系统不能兼容,这也导致其应用软件不能方便移植,这一点一直严重制约了ARM系统的发展和应用。GOOGLE开发了开放式的Andro...

关键字: Linux x86 ARM

随着计算需求的多样化,尤其是随着移动设备、嵌入式系统和云计算的兴起,ARM 和 x86 架构之间的争论变得更加突出。ARM(高级 RISC 机器)和 x86 代表两种不同类型的处理器架构,每种架构都针对不同的工作负载和用...

关键字: Linux x86 ARM

从画质优化 (NSS) 到帧率提升 (NFRU) 和光线追踪(NSSD),Arm 计划覆盖移动端图形处理的多个维度,推动边缘 AI 图形革命。而未来通过持续的技术迭代,Arm也将保持在移动计算领域的技术领先,满足手游、A...

关键字: ARM 神经图形技术 GPU AI ML

7月31日消息,据媒体报道,芯片架构提供商Arm Holdings首席执行官Rene Haas宣布,公司正加大投入开发自有芯片产品,此举标志着其从传统IP授权模式向提供实体芯片的战略重大转变。

关键字: ARM META

7月28日消息,2025年,中国AI硬件市场规模将首次突破万亿元大关。

关键字: AI ARM

受生成式 AI 驱动, RISC-V 芯片市场快速发展。预计到2030年,RISC-V SoC出货量将达到1618.1亿颗,营收将达到927亿美元。其中,用于AI加速器的RISC-V SoC出货量将达到41亿颗,营收将达...

关键字: RISC-V CPU AI CUDA ARM 推理
关闭