<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > Thumb指令集之: ARM和Thumb的混合編程

Thumb指令集之: ARM和Thumb的混合編程

作者: 時(shí)間:2013-09-30 來(lái)源:網(wǎng)絡(luò ) 收藏

本文引用地址:http://dyxdggzs.com/article/257035.htm

指令操作的偽代碼如下所示。

TFlag=Rm[0]

PC=Rm[31:1]1

指令集中的BX指令和中的BX指令相差較大,它們分別為不同方向的跳轉。當r15作為目的寄存器使用時(shí),要特別注意該指令在兩個(gè)指令集中的區別。

(2)BLX指令

狀態(tài)下的BLX指令使用一個(gè)寄存器中的絕對地址或標號,用于使程序跳轉到Thumb狀態(tài)或從Thumb狀態(tài)返回,該指令用分支寄存器的最低位來(lái)更新CPSR中的T位,并將返回地址寫(xiě)入到連接寄存器LR中。

指令的語(yǔ)法格式如下所示:

①BLXtarget_addr>

②BLX{cond>}Rm>

第一種格式中,轉移目標按下述方法計算。將指令中指定的24位偏移量進(jìn)行符號擴展,左移兩位形成字偏移量,然后將其累加進(jìn)程序計數器PC中。這時(shí),程序計數器的內容為BX指令地址加8字節。位H(bit[24])也加到結果地址的第一位(bit[1]),使目標地址為半字地址,以執行接下來(lái)的Thumb指令。計算偏移量的工作一般由匯編器來(lái)完成。這種形式的跳轉指令只能實(shí)現±32MB空間的跳轉。

第二種格式中,寄存器Rm指定轉移目標,Rm的第0位拷貝到CPSR中的T位,bit[31:0]移入PC。

·如果Rm的bit[0]=1,則跳轉時(shí)自動(dòng)將CPSR中的標志位T置位,即把目標地址的代碼解釋為T(mén)humb代碼。

·如果Rm的bit[0]=0,則跳轉時(shí)自動(dòng)將CPSR中的標志位T復位,即把目標地址的代碼解釋為ARM代碼。

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

第一種格式BLX指令。

LR=addressoftheinstructionaftertheBLXinstruction

TFlag=1

PC=PC+PC=PC+(SignExtend(signed_immed_24)2)+(H1)

第二種格式BLX指令。

IfConditionPass{cond}then

LR=addressoftheinstructionafterthebranchinstruftion

TFlag=Rm[0]

PC=RmAND0xfffffffe

Thumb狀態(tài)下帶返回鏈接的跳轉指令BLX(1)提供了一種在Thumb狀態(tài)下無(wú)條件調用ARM子程序的方法,當從子程序返回時(shí),通常使用下面的方式之一:

·BXLR

·加載PC的LDR或LDM指令。

BLX指令不可條件執行,可以實(shí)現在大約±4MB的地址空間范圍內跳轉,實(shí)現方法是將一條BLX指令編譯成兩條16位的Thumb指令,從而實(shí)現上述跳轉。對編譯后的兩條指令說(shuō)明如下。

①H=10的跳轉指令。該跳轉包含跳轉偏移量的高位部分。

②H=01的跳轉指令。該跳轉包含跳轉偏移量的低位部分。

指令的語(yǔ)法格式

BLtarget_address>

target_address>

指定程序跳轉的目標地址。指令通過(guò)下面的方法計算目標地址。

·將H=10的BL指令的offset_11域左移12位。

·將結果符號擴展為32位。

·將得到的值加到PC寄存器中。

·與H=11的BL指令的offset_11域相加。

因此BL指令可以實(shí)現在大約±4MB的地址空間范圍內跳轉。

指令操作的偽代碼為:

ifH==10then

LR=PC+(SignExtend(offset_11)12)

ElseifH==11then

PC=LR+(offset_1111)

LR=(addressofnextinstruction)|1

ElseifH==01then

PC=(LR+(offset_111))AND0xFFFFFFFC

LR=(addressofnextinstruction)|1

ElseifH==01then

PC=(LR+(offset_111))AND0Xfffffffc

LR=(addressofnextinstruction)|1

TFlag=0

另外Thumb狀態(tài)下包含另一種格式的BLX指令,該BLX(2)指令用于A(yíng)RM和Thumb子程序間的相互調用。程序狀態(tài)字的T標志位根據目的寄存器的bit[0]位而改變。

c++相關(guān)文章:c++教程




評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>