DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

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

[待整理] 跳转指令之:带状态切换的连接跳转指令BLX(2)

[复制链接]
跳转到指定楼层
楼主
发表于 2014-10-10 07:29:11 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
        8.4  带状态切换的连接跳转指令BLX(2)

        1.指令编码格式

        带连接和状态切换的跳转指令BLX(Branch with Link Exchange)使用一个寄存器中的绝对地址,用于使程序跳转到Thumb状态或从Thumb状态返回。该指令用分支寄存器的最低位来更新CPSR中的T位,将返回地址写入到连接寄存器LR中。
         
        指令编码格式如图8.4所示。
       

        图8.4  BLX(2)指令编码格式

         
        2.语法格式

        BLX{<cond>}  <Rm>
         
        ① <cond>
        为指令编码中的条件域。它指示指令在什么条件下执行。当<cond>忽略时,指令为无条件执行(cond=AL(Alway))。
         
        ② <Rm>
        寄存器Rm指定转移目标,Rm的第0位拷贝到CPSR中的T位,bit[31∶0]移入PC。
        ·  如果Rm的bit[0]=1,则跳转时自动将CPSR中的标志位T置位,即把目标地址的代码解释为Thumb代码。
        ·  如果Rm的bit[0]=0,则跳转时自动将CPSR中的标志位T复位,即把目标地址代码解释为ARM代码。
         
        3.指令操作的伪代码

        指令操作的伪代码如下面程序段所示。
         
        If  ConditionPass{cond}  then
               LR = address of the instruction after the branch instruction
               T Flag=Rm[0]
               PC=Rm AND 0xfffffffe
         
                                                                         
                       
                                                                        注意
                       
                                                                        在这种情况下,如果Rm的bit[1∶0]=0b10,指令的执行结果不可预知,因为这将导致在ARM状态下非对齐的字访问。
                       
        4.指令举例

        调用Thumb子程序。
         
            CODE32 ;ARM代码
            ……
            BLX      TSUB ;调用Thumb子程序
            ……
            CODE16 ;Thumb代码开始
        TSUB
            ……
            BX       r14 ;返回ARM状态
         
                                                                         
                       
                                                                        注意
                       
                                                                        (1)一些不支持Thumb指令集的ARM处理器将捕获这些指令,允许软件仿真Thumb指令。
                                                                        (2)只有实现ARMv5版本以上的处理器支持BLX指令的两种格式。
                       
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-27 12:45 , 耗时 0.091783 秒, 21 个查询请求 , Gzip 开启.

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

桂公网安备 45031202000115号

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

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

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

QQ:28000622;Email:libyoufer@sina.com

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

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