资料介绍
11.7 异常中断产生指令(断点指令)
Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。
11.7.1 软中断指令SWI
(1)编码格式
软中断指令SWI的编码格式如图11.63所示。
![Thumb指令集之异常中断产生指令解析](/uploads/allimg/171019/2362486-1G01Z95T4R6.png)
图11.63 SWI指令的编码格式
软中断指令SWI(Software Interrupt)用于使处理器产生软中断异常,使用这种机制实现在用户模式对操作系统中特权模式的程序调用。
(2)指令的语法格式
SWI 《immed_8》
其中,immed_8为8位立即数,该立即数被处理器忽略,但可以被操作系统用来判断用户程序请求的服务类型。
(3)指令操作的伪代码
R14_svc = address of next instruction after the SWI instruction
SPSR_svc = CPSR
CPSR[4:0] = 0b10011 /*进入超级模式*/
CPSR[5] = 0 /*进入ARM状态*/
/*CPSR[6] is unchanged*/
CPSR[7] = 1 /*禁止正常中断*/
If high vectors configured then
PC = 0xffff0008
Else
PC = 0x00000008
(4)对应的ARM指令
SWI 《immed_8》
11.7.2 断点中断指令 BKPT
(1)编码格式
断点中断指令BKPT的编码格式如图11.64所示。
![Thumb指令集之异常中断产生指令解析](/uploads/allimg/171019/2362486-1G01Z95U4642.png)
图11.64 BKPT指令的编码格式
断点中断指令BKPT(Breakpoint)可以使处理器产生预取异常(Prefetch Abort),使用这种机制可以在没有调试硬件的情况下,实现程序的软件调试。当系统中使用硬件调试部件时,可忽略该中断。
(2)指令的语法格式
BKPT 《immed_8》
其中,immed_8为8位立即数,该立即数被处理器忽略,但可以向调试系统提供附加的断点信息。
注意当系统中存在调试硬件时,BKPT指令有两种处理方法:一种由调试硬件处理BKPT指令;另一种可以直接由预取异常处理函数来处理BKPT指令,使用这种方法时,由于使用了异常模式下的链接地址寄存器r14_abt和程序状态寄存器SPSR_abt,所有要特别注意程序的嵌套。
(3)指令操作的伪代码
if (not overridden by debug hardware)
R14_abt = address of BKPT instruction +4
SPSR_abt = CPSR
CPSR[4:0] = 0b10111 /*进入异常模式*/
CPSR[5] = 0 /*进入ARM状态*/
/*CPSR[6] is unchanged*/
CPSR[7] = 1
If high vectors configured then
PC = 0xffff000c
Else
PC = 0x0000000c
(4)对应的ARM指令
BKPT 《immed_8》
Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。
11.7.1 软中断指令SWI
(1)编码格式
软中断指令SWI的编码格式如图11.63所示。
![Thumb指令集之异常中断产生指令解析](/uploads/allimg/171019/2362486-1G01Z95T4R6.png)
图11.63 SWI指令的编码格式
软中断指令SWI(Software Interrupt)用于使处理器产生软中断异常,使用这种机制实现在用户模式对操作系统中特权模式的程序调用。
(2)指令的语法格式
SWI 《immed_8》
其中,immed_8为8位立即数,该立即数被处理器忽略,但可以被操作系统用来判断用户程序请求的服务类型。
(3)指令操作的伪代码
R14_svc = address of next instruction after the SWI instruction
SPSR_svc = CPSR
CPSR[4:0] = 0b10011 /*进入超级模式*/
CPSR[5] = 0 /*进入ARM状态*/
/*CPSR[6] is unchanged*/
CPSR[7] = 1 /*禁止正常中断*/
If high vectors configured then
PC = 0xffff0008
Else
PC = 0x00000008
(4)对应的ARM指令
SWI 《immed_8》
11.7.2 断点中断指令 BKPT
(1)编码格式
断点中断指令BKPT的编码格式如图11.64所示。
![Thumb指令集之异常中断产生指令解析](/uploads/allimg/171019/2362486-1G01Z95U4642.png)
图11.64 BKPT指令的编码格式
断点中断指令BKPT(Breakpoint)可以使处理器产生预取异常(Prefetch Abort),使用这种机制可以在没有调试硬件的情况下,实现程序的软件调试。当系统中使用硬件调试部件时,可忽略该中断。
(2)指令的语法格式
BKPT 《immed_8》
其中,immed_8为8位立即数,该立即数被处理器忽略,但可以向调试系统提供附加的断点信息。
![](file:///C:\Users\ADMINI~1\AppData\Local\Temp\ksohtml\wps33E2.tmp.jpg)
(3)指令操作的伪代码
if (not overridden by debug hardware)
R14_abt = address of BKPT instruction +4
SPSR_abt = CPSR
CPSR[4:0] = 0b10111 /*进入异常模式*/
CPSR[5] = 0 /*进入ARM状态*/
/*CPSR[6] is unchanged*/
CPSR[7] = 1
If high vectors configured then
PC = 0xffff000c
Else
PC = 0x0000000c
(4)对应的ARM指令
BKPT 《immed_8》
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 嵌入式系统常用指令集表格整理
- ARM处理器的寻址方式和指令集介绍 33次下载
- PICmicro中档单片机系列之指令集
- ARM和Thumb-2的指令集快速参考卡 21次下载
- 协处理器及其他指令之异常产生指令 1次下载
- Thumb指令集之Thumb跳转指令 1次下载
- Thumb指令集之Thumb编程模型 0次下载
- Thumb指令的特点及实现 0次下载
- Thumb指令集之多寄存器数据传送指令解析 0次下载
- Thumb指令集之ARM和Thumb的混合编程 1次下载
- Thumb指令集之Thumb指令应用 0次下载
- ARM和Thumb-2指令集快速参考卡 21次下载
- arm7指令集
- ARM指令集详解
- ARM指令集下载 arm指令集参考手册
- RISC-V开源指令集全面指南与解析 782次阅读
- 现代处理器的主要指令集架构 4645次阅读
- 讲讲ARM指令集格式以及常用的ARM汇编指令 4054次阅读
- NB-IOT常用AT指令集简介 3362次阅读
- 什么指令集支持原子操作 1425次阅读
- 总结20个超好用的 Unix/Linux 命令指令集 2954次阅读
- ARM异常中断的原因及处理措施 8162次阅读
- Cortex-M系列处理器指令集_指令集特性比较总结 8023次阅读
- SH-3异常中断处理方式 SH7709S的应用 1258次阅读
- risc指令集是什么_有哪些 2w次阅读
- mips指令集指的是什么 1.3w次阅读
- mips汇编指令集功能的介绍 2.2w次阅读
- ZedBoard之中断原理及过程详解 4842次阅读
- esp8266 at指令集详解 14.3w次阅读
- thumb指令集是什么_thumb指令集与arm指令集的区别 1.8w次阅读
下载排行
本周
- 1IP6823 支持 qi 认证的无线充电发射控制 SOC
- 1.01 MB | 1次下载 | 免费
- 2IP6824 全集成QI 无线充电发射控制SOC
- 1.22 MB | 1次下载 | 免费
- 3GD32G5x3 FFT模块用户指南
- 920.15KB | 次下载 | 免费
- 4GD32H73x/H75x的器件限制
- 774.05KB | 次下载 | 免费
- 5PDTA115EU配备PNP电阻的晶体管规格书
- 189.74KB | 次下载 | 免费
- 6带注入电流控制的1.8V通用SP8T-Z和2个SP4T-Z模拟开关
- 847.62KB | 次下载 | 免费
- 7PESD18VY1BBIF保护二极管规格书
- 4.56MB | 次下载 | 免费
- 8视频处理器晶振应用方案
- 515.02 KB | 次下载 | 免费
本月
- 1A7159和A7139射频芯片的资料免费下载
- 0.20 MB | 55次下载 | 5 积分
- 2零死角玩转STM32F103—指南者
- 26.78 MB | 41次下载 | 1 积分
- 3PIC12F629/675 数据手册免费下载
- 2.38 MB | 36次下载 | 5 积分
- 4PIC16F716 数据手册免费下载
- 2.35 MB | 18次下载 | 5 积分
- 5dsPIC33EDV64MC205电机控制开发板用户指南
- 5.78MB | 8次下载 | 免费
- 6STC15系列常用寄存器汇总免费下载
- 1.60 MB | 7次下载 | 5 积分
- 7AN-1267: 使用ADSP-CM408F ADC控制器的电机控制反馈采样时序
- 1.41MB | 5次下载 | 免费
- 8LP9962集成 PFC 和 和的 高压半桥驱动的 LLC 谐振
- 3.30 MB | 4次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935124次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420063次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233088次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191367次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183335次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81581次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73813次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65988次下载 | 10 积分
评论