电子发烧友App

硬声App

0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示
电子发烧友网>电子资料下载>嵌入式开发>Thumb指令集之异常中断产生指令解析

Thumb指令集之异常中断产生指令解析

2017-10-19 | rar | 0.3 MB | 次下载 | 1积分

资料介绍

 11.7 异常中断产生指令(断点指令)
  Thumb异常中断产生指令与ARM指令集下的异常中断指令十分相似。同ARM指令集相同,Thumb指令集中同样包含两条异常中断产生指令:软件中断指令SWI用于产生SWI异常中断;断点中断指令BKPT主要用于产生软件断点,供调试程序使用(只在ARMv5及以上版本中使用)。
  11.7.1 软中断指令SWI
  (1)编码格式
  软中断指令SWI的编码格式如图11.63所示。
  Thumb指令集之异常中断产生指令解析
  图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指令集之异常中断产生指令解析
  图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》
 
下载该资料的人也在下载 下载该资料的人还在阅读
更多 >

评论

查看更多

下载排行

本周

  1. 1IP6823 支持 qi 认证的无线充电发射控制 SOC
  2. 1.01 MB  |  1次下载  |  免费
  3. 2IP6824  全集成QI 无线充电发射控制SOC
  4. 1.22 MB  |  1次下载  |  免费
  5. 3GD32G5x3 FFT模块用户指南
  6. 920.15KB   |  次下载  |  免费
  7. 4GD32H73x/H75x的器件限制
  8. 774.05KB   |  次下载  |  免费
  9. 5PDTA115EU配备PNP电阻的晶体管规格书
  10. 189.74KB   |  次下载  |  免费
  11. 6带注入电流控制的1.8V通用SP8T-Z和2个SP4T-Z模拟开关
  12. 847.62KB   |  次下载  |  免费
  13. 7PESD18VY1BBIF保护二极管规格书
  14. 4.56MB   |  次下载  |  免费
  15. 8视频处理器晶振应用方案
  16. 515.02 KB  |  次下载  |  免费

本月

  1. 1A7159和A7139射频芯片的资料免费下载
  2. 0.20 MB   |  55次下载  |  5 积分
  3. 2零死角玩转STM32F103—指南者
  4. 26.78 MB   |  41次下载  |  1 积分
  5. 3PIC12F629/675 数据手册免费下载
  6. 2.38 MB   |  36次下载  |  5 积分
  7. 4PIC16F716 数据手册免费下载
  8. 2.35 MB   |  18次下载  |  5 积分
  9. 5dsPIC33EDV64MC205电机控制开发板用户指南
  10. 5.78MB   |  8次下载  |  免费
  11. 6STC15系列常用寄存器汇总免费下载
  12. 1.60 MB   |  7次下载  |  5 积分
  13. 7AN-1267: 使用ADSP-CM408F ADC控制器的电机控制反馈采样时序
  14. 1.41MB   |  5次下载  |  免费
  15. 8LP9962集成 PFC 和 和的 高压半桥驱动的 LLC 谐振
  16. 3.30 MB  |  4次下载  |  免费

总榜

  1. 1matlab软件下载入口
  2. 未知  |  935124次下载  |  10 积分
  3. 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
  4. 1.48MB  |  420063次下载  |  10 积分
  5. 3Altium DXP2002下载入口
  6. 未知  |  233088次下载  |  10 积分
  7. 4电路仿真软件multisim 10.0免费下载
  8. 340992  |  191367次下载  |  10 积分
  9. 5十天学会AVR单片机与C语言视频教程 下载
  10. 158M  |  183335次下载  |  10 积分
  11. 6labview8.5下载
  12. 未知  |  81581次下载  |  10 积分
  13. 7Keil工具MDK-Arm免费下载
  14. 0.02 MB  |  73813次下载  |  10 积分
  15. 8LabVIEW 8.6下载
  16. 未知  |  65988次下载  |  10 积分