新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > Thumb指令集之: Thumb跳轉指令

        Thumb指令集之: Thumb跳轉指令

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

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

        (3)指令操作的偽代碼

        PC=PC+{SignExtend(Signed_immed_8)1}

        (4)指令的使用

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

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

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

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

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

        (5)指令集中的

        該指令與指令集中Btarget_address>基本相似,所不同的是指令集中偏移量左移兩位,而中偏移量左移一位。另外,處理器在ARM和Thumb狀態下所讀取的PC值也是不同的。

        11.3.2帶返回的無條件跳轉指令BL

        (1)編碼格式

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

        圖11.3BL指令編碼格式

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

        ·MOVPC,LR

        ·BXLR

        ·POP{pc}

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

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

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

        (2)指令的語法格式

        BLtarget_address>

        target_address>

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

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

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

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

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

        因此BL指令可以實現在大約±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)指令的使用

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

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

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

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

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

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

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

        注意

        當H=00時,該指令為無條件跳轉指令。

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

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



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 孟连| 鄂伦春自治旗| 唐山市| 洪雅县| 高安市| 民丰县| 建瓯市| 当雄县| 二手房| 齐齐哈尔市| 定南县| 红河县| 那曲县| 青海省| 泽州县| 新乐市| 赞皇县| 花莲县| 陆良县| 化州市| 佛山市| 宜黄县| 任丘市| 延川县| 洛浦县| 郴州市| 海兴县| 青龙| 乐业县| 龙胜| 宁海县| 区。| 永州市| 调兵山市| 嵩明县| 分宜县| 威远县| 汽车| 明星| 林口县| 兴化市|