DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1423|回复: 0
打印 上一主题 下一主题

[待整理] Thumb指令集之: 异常中断产生指令(断点指令)

[复制链接]
跳转到指定楼层
楼主
发表于 2014-10-10 07:27:05 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
        11.7  异常中断产生指令(断点指令)

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

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

        图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所示。
       

        图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>
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-11-14 14:24 , 耗时 0.095444 秒, 22 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表