色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 跳轉指令之:帶狀態(tài)切換的跳轉指令BX

          跳轉指令之:帶狀態(tài)切換的跳轉指令BX

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

          8.2帶狀態(tài)切換的

          1.指令編碼格式

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

          本文引用地址:http://cafeforensic.com/article/257055.htm

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

          圖8.2指令編碼格式

          2.指令的語法格式

          BX{cond>}Rm>

          ①cond>

          為指令編碼中的條件域。它指示指令在什么條件下執(zhí)行。當cond>忽略時,指令為無條件執(zhí)行(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時,指令的執(zhí)行結果不可預知。因為在狀態(tài)下,指令是4字節(jié)對齊的。

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

          MOVPC,PC

          或,

          ADDPC,PC,#0

          5.指令舉例

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

          BXr0;

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

          ADRLr0,ThumbFun+1;

          BXr0;



          評論


          相關推薦

          技術專區(qū)

          關閉