匯編語言LDR指令和LDR偽指令詳解
LDR指令和LDR偽指令詳解
ARM32位指令的構成
ARM是RISC結(jié)構,數(shù)據(jù)從內(nèi)存到CPU之間的移動只能通過LDR/STR指令來完成。 32bit = 指令碼 + 數(shù)據(jù)。所以32bit的一條指令不可能表示再帶一個32bit的數(shù)據(jù),實際只有其中的12bit來表示立即數(shù),其中4bit表示移位的位數(shù)(循環(huán)右移,且數(shù)值x2),8bit用來表示要移位的一個基數(shù)。這就產(chǎn)生了非法立即數(shù)和合法立即數(shù)的問題,經(jīng)過移位操作,不為零的部分不能用8bit表示的數(shù)就是非法立即數(shù)。ldr偽指令就是用來解決非法立即數(shù)問題的。
ldr指令和ldr偽指令的使用區(qū)別:
ldr r0, =0xFFF0 @偽指令
ldr r0, 0xFFFF @指令
直觀的區(qū)別就是ldr偽指令使用時,后面的數(shù)據(jù)前會有"=",實際使用時,大部分都使用偽指令,這樣就不用考慮合法和非法立即數(shù)的問題。在編譯的時候,編譯器會將ldr偽指令進行替換,用文字池的方式來解決非法立即數(shù)的問題。文字池就是劃分出一段地址空間用來存放常量或者地址,需要時用基址+變址的方式去取數(shù)據(jù),這樣就不用受到合法立即數(shù)的限制,可以表示32bit的數(shù)據(jù)。例如:
匯編源代碼:
_start:
ldr r0, =0x11111111
經(jīng)過反匯編:
00000000 <_start>:
0: e59f009c ldr r0, [pc, #156] ; a4 <delay_loop+0x10>
·
·
·
98: e1520003 cmp r2, r3
9c: 1afffffc bne 94 <delay_loop>
a0: e1a0f00e mov pc, lr
a4: 11111111 tstne r1, r1, lsl r1
分析:
通過反匯編可以看到,ldr偽指令被一條寄存器基址變址指令給替代了。其中以pc為基址,偏移156個字節(jié)(16進制是0x9c)。這條指令的作用是將內(nèi)存地址"pc + 156"開頭的4個字節(jié)讀取到r0中,此時pc的值等于當前執(zhí)行指令的地址+8(因為流水線的原因),因此pc + 156 = 0xa4,而0xa4地址處存的值剛好是0x11111111。這樣就完成了將0x11111111加載到r0。
補充1:
RAM處理器存在流水線,目前已經(jīng)有十幾級流水線,但是ARM為了兼容,無論Soc有多少級流水線,PC的值都是等于當前指令地址 + 8。PC = 當前指令地址 + 8, 記住就行。
補充2:
匯編語言ldr偽指令
偽指令是用來自動拆分代碼值的,會把一條語句拆分成多條語句。
示例:
/* 匯編點亮一個 LED 燈 */ .text .global _start _start: ldr r1, =0x56000050 ldr r0, =0x100 /* 相當于 mov r0, #0x100 */ str r0, [r1] ldr r1, =0x56000054 ldr r0, =0 /* mov r0, #0 */ str r0, [r1] halt: b halt
ldr r1, =0x56000054就是一條偽指令,假設我們想把56000054值給r1寄存器,可以用 mov r1, #56000050 ,
但是長度超出了mov 能接收的長度,就要分為高低字節(jié)去發(fā)送,但是在某些時候我們還要去看開放文檔,才能知道
或者沒有開發(fā)文檔,那就讓偽指令自己去判斷。
到此這篇關于匯編語言LDR指令和LDR偽指令詳解的文章就介紹到這了,更多相關匯編語言ldr偽指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
匯編語言XOR指令:對兩個操作數(shù)進行邏輯(按位)異或操作(推薦)
匯編語言(assembly language)是一種用于電子計算機、微處理器、微控制器或其他可編程器件的低級語言,亦稱為符號語言。這篇文章主要介紹了匯編語言XOR指令:對兩個操作數(shù)進行邏輯(按位)異或操作,需要的朋友可以參考下2020-01-01Go 中的循環(huán)是如何轉(zhuǎn)為匯編的(方法詳解)
這篇文章主要介紹了Go 中的循環(huán)是如何轉(zhuǎn)為匯編的,本文通過循環(huán)的匯編代碼給大家講解的非常詳細,代碼簡單易懂,非常不錯,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05os_object_release Crash 排查記錄分析
這篇文章主要為大家介紹了os_object_release Crash 排查記錄分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11