<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指令集之: Thumb跳轉指令

Thumb指令集之: Thumb跳轉指令

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

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

(3)指令操作的偽代碼

PC=PC+{SignExtend(Signed_immed_8)1}

(4)指令的使用

為了得到正確的signed_immed_11,匯編器需要執行以下的操作步驟。

①首先形成跳轉的基地址。該跳轉的基地址是地址加4。也就是說(shuō),的基地址即當前程序指針寄存器的值。

②從跳轉的目標地址中減去基地址形成跳轉偏移量。該偏移量應為偶數(因為T(mén)humb指令為半字對齊)。

③如果跳轉偏移量超出-2048~+2046B范圍,匯編器產(chǎn)生一個(gè)錯誤。

④將產(chǎn)生的跳轉偏移量除以2放入指令編碼中的signed_immed_11域。

(5)指令集中的

該指令與指令集中Btarget_address>基本相似,所不同的是指令集中偏移量左移兩位,而中偏移量左移一位。另外,處理器在A(yíng)RM和Thumb狀態(tài)下所讀取的PC值也是不同的。

11.3.2帶返回的無(wú)條件跳轉指令BL

(1)編碼格式

帶返回的無(wú)條件跳轉指令的編碼格式如圖11.3所示。

圖11.3BL指令編碼格式

帶返回的跳轉指令BL提供了一種在Thumb狀態(tài)下程序間相互調用的方法,當從子程序返回時(shí),通常使用下面的方式之一:

·MOVPC,LR

·BXLR

·POP{pc}

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

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

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

(2)指令的語(yǔ)法格式

BLtarget_address>

target_address>

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

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

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

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

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

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

(3)指令操作的偽代碼

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

(4)指令的使用

為了能夠正確產(chǎn)生兩條Thumb跳轉指令,匯編器按照如下步驟產(chǎn)生跳轉偏移量。

①形成跳轉基地址。此基地址為H=10時(shí)的BL指令地址加上4,即執行該條指令的PC值。

②從目標地址中減去基地址,形成跳轉偏移量。

根據以上步驟所產(chǎn)生的結果是−222~+222−2之間的一個(gè)偶數,如果結果超出此范圍,匯編器將報錯。

③如果產(chǎn)生的結果在給定范圍內,匯編器將產(chǎn)生下面兩條BL指令:

·H=10,offset_11=offset[22:12]

·H=11,offset_11=offset[11:1]

注意

當H=00時(shí),該指令為無(wú)條件跳轉指令。

(5)ARM指令集中的BL指令

如果調用Thumb子程序,該指令類(lèi)似于BLXtarget_addr>;如果程序調用ARM子程序,該指令類(lèi)似于BLtarget_addr>。



評論


相關(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>