新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 跳轉指令之:帶狀態切換的連接跳轉指令BLX(2)

        跳轉指令之:帶狀態切換的連接跳轉指令BLX(2)

        作者: 時間:2013-09-13 來源:網絡 收藏

        8.4帶狀態切換的連接

        1.指令編碼格式

        帶連接和狀態切換的BLX(BranchwithLinkExchange)使用一個寄存器中的絕對地址,用于使程序跳轉到Thumb狀態或從Thumb狀態返回。該指令用分支寄存器的最低位來更新CPSR中的T位,將返回地址寫入到連接寄存器LR中。

        本文引用地址:http://www.104case.com/article/257053.htm

        指令編碼格式如圖8.4所示。

        圖8.4BLX(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復位,即把目標地址代碼解釋為代碼。

        3.指令操作的偽代碼

        指令操作的偽代碼如下面程序段所示。

        IfConditionPass{cond}then

        LR=addressoftheinstructionafterthebranchinstruction

        TFlag=Rm[0]

        PC=RmAND0xfffffffe

        注意

        在這種情況下,如果Rm的bit[1∶0]=0b10,指令的執行結果不可預知,因為這將導致在狀態下非對齊的字訪問。

        4.指令舉例

        調用Thumb子程序。

        CODE32 ;代碼

        ……

        BLXTSUB ;調用Thumb子程序

        ……

        CODE16 ;Thumb代碼開始

        TSUB

        ……

        BXr14 ;返回ARM狀態

        注意

        (1)一些不支持Thumb指令集的ARM處理器將捕獲這些指令,允許軟件仿真Thumb指令。

        (2)只有實現ARMv5版本以上的處理器支持BLX指令的兩種格式。



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 凤冈县| 阿克陶县| 麻阳| 桑植县| 仁化县| 奉贤区| 普洱| 洮南市| 灵川县| 湄潭县| 聂荣县| 鹤庆县| 察哈| 陇西县| 阜康市| 宽甸| 甘洛县| 昭觉县| 唐河县| 四平市| 车致| 榆林市| 修文县| 内乡县| 吴桥县| 黄大仙区| 阳西县| 明溪县| 玛沁县| 章丘市| 德钦县| 金山区| 安化县| 耿马| 丰县| 正阳县| 屯门区| 乌拉特前旗| 仁怀市| 江孜县| 台中县|