久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編----偽指令LTORG

ARM匯編----偽指令LTORG

作者: 時間:2016-11-27 來源:網絡 收藏
LTORG用于聲明一個數據緩沖池,(也稱為文字池)的開始。在使用偽指令LDR時,常常需要在適當的地方加入LTORG聲明數據緩沖池,LDR加載的數據暫時放于數據緩沖池。

語法LTORG

本文引用地址:http://cqxgywz.com/article/201611/322311.htm

使用說明:

當程序中使用LDR之類的指令時,數據緩沖池的使用可能越界。為防止越界發生,可使用LTONG偽操作定義數據緩沖池。通常大的代碼段可以使用多個數據緩沖池。ARM匯編編譯器一般把數據緩沖池放在代碼段的最后面,即下一代碼段開始之前,或者END偽操作之前。LTORG偽操作通常放在無條件跳轉指令之后,或者子程序返回指令之后,這樣處理器就不會錯誤的將數據緩沖池中的數據當作指令來執行。

LDR偽指令在匯編時,如果立即數可以用表示的話就替換為MOV或MVN指令;如果不能用其表示則需要將該立即數放到一個文字池中,并生成一條將該文字池內容加載到目標寄存器的LDR指令。而使用LDR指令必須保證文字池在其可以訪問的地址范圍之內,對于ARM指令集來說就是4KB,所以必須在LDR指令前后4KB的范圍內用LTORG顯式地在代碼段中添加一個文字池。

LTORG是在此指令出現的地方放一個文本池(literal pool).在ARM匯編中常用到

ldr r0, =instruction將地址instruction載入r0.

此時編譯器將ldr盡可能的轉變成mov或mvn指令。

如果轉變不成,將產生一個ldr指令,通過pc相對地址從一塊保存常數的內存區讀出instruction的值。此內存區既是文本池。一般的,文本池放在END指令之后的地方。但是,如果偏移地址大于4k空間, ldr指令會出錯(因為ldr的相對偏移地址為12-bit的值).此時使用LTORG放到會出錯的ldr指令附近,以解決此問題。編譯器會收集沒有分配的ldr的值放到此文本池中。



評論


技術專區

關閉