新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 跳轉指令之:帶狀態切換的跳轉指令BX

        跳轉指令之:帶狀態切換的跳轉指令BX

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

        8.2帶狀態切換的

        1.指令編碼格式

        帶狀態切換的使程序跳轉到指令中指定的參數Rm指定的地址執行程序,Rm的第0位拷貝到CPSR中T位,位[31∶1]移入PC。若Rm的bit[0]為1,則跳轉時自動將CPSR中的標志位T置位,即把目標地址的代碼解釋為Thumb代碼;若Rm的位bit[0]為0,則跳轉時自動將CPSR中的標志位T復位,即把目標地址代碼解釋為代碼。

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

        指令的編碼格式如圖8.2所示。

        圖8.2指令編碼格式

        2.指令的語法格式

        BX{cond>}Rm>

        ①cond>

        為指令編碼中的條件域。它指示指令在什么條件下執行。當cond>忽略時,指令為無條件執行(cond=AL(Alway))。

        ②Rm>

        包含的目標地址。如果Rm的bit[0]=0,目標地址處指令為指令;如果Rm的bit[0]=1,目標地址處指令為Thumb指令。

        3.指令操作的偽代碼

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

        IfconditionPassed{cond}then

        TFlag=Rm[0]

        PC=RmAND0xfffffffe

        4.指令的使用

        ·當Rm[1∶0]=0b10時,指令的執行結果不可預知。因為在狀態下,指令是4字節對齊的。

        ·PC可以作為Rm寄存器使用,但這種用法不推薦使用。當PC作為Rm>使用時,指令“BXPC”將程序跳轉到當前指令下面第二條指令處執行。雖然這樣跳轉可以實現,但最好使用下面的指令完成這種跳轉。

        MOVPC,PC

        或,

        ADDPC,PC,#0

        5.指令舉例

        (1)轉移到r0中的地址,如果r0[0]=1,則進入Thumb狀態。

        BXr0;

        (2)跳轉到r0指定的地址,并根據r0的最低位來切換處理器狀態。

        ADRLr0,ThumbFun+1;

        BXr0;



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 克东县| 资源县| 凌海市| 宁化县| 赤峰市| 丰顺县| 松原市| 广汉市| 集贤县| 金寨县| 齐河县| 布拖县| 南木林县| 建阳市| 邵阳县| 上蔡县| 东山县| 孝义市| 改则县| 灵山县| 衡东县| 黄浦区| 沙雅县| 中江县| 闸北区| 大名县| 琼海市| 松江区| 沙坪坝区| 土默特右旗| 阳曲县| 什邡市| 涞源县| 陆河县| 神木县| 鹿泉市| 西丰县| 福州市| 寻乌县| 灵璧县| 随州市|