日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

匯編語言LDR指令和LDR偽指令詳解_匯編語言

作者:正在起飛的蝸牛 ? 更新時(shí)間: 2023-03-19 編程語言

LDR指令和LDR偽指令詳解

ARM32位指令的構(gòu)成

ARM是RISC結(jié)構(gòu),數(shù)據(jù)從內(nèi)存到CPU之間的移動(dòng)只能通過LDR/STR指令來完成。 32bit = 指令碼 + 數(shù)據(jù)。所以32bit的一條指令不可能表示再帶一個(gè)32bit的數(shù)據(jù),實(shí)際只有其中的12bit來表示立即數(shù),其中4bit表示移位的位數(shù)(循環(huán)右移,且數(shù)值x2),8bit用來表示要移位的一個(gè)基數(shù)。這就產(chǎn)生了非法立即數(shù)和合法立即數(shù)的問題,經(jīng)過移位操作,不為零的部分不能用8bit表示的數(shù)就是非法立即數(shù)。ldr偽指令就是用來解決非法立即數(shù)問題的。

ldr指令和ldr偽指令的使用區(qū)別:

ldr r0, =0xFFF0 @偽指令
ldr r0, 0xFFFF @指令
直觀的區(qū)別就是ldr偽指令使用時(shí),后面的數(shù)據(jù)前會(huì)有"=",實(shí)際使用時(shí),大部分都使用偽指令,這樣就不用考慮合法和非法立即數(shù)的問題。在編譯的時(shí)候,編譯器會(huì)將ldr偽指令進(jìn)行替換,用文字池的方式來解決非法立即數(shù)的問題。文字池就是劃分出一段地址空間用來存放常量或者地址,需要時(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個(gè)字節(jié)(16進(jìn)制是0x9c)。這條指令的作用是將內(nèi)存地址"pc + 156"開頭的4個(gè)字節(jié)讀取到r0中,此時(shí)pc的值等于當(dāng)前執(zhí)行指令的地址+8(因?yàn)榱魉€的原因),因此pc + 156 = 0xa4,而0xa4地址處存的值剛好是0x11111111。這樣就完成了將0x11111111加載到r0。

補(bǔ)充1:

RAM處理器存在流水線,目前已經(jīng)有十幾級流水線,但是ARM為了兼容,無論Soc有多少級流水線,PC的值都是等于當(dāng)前指令地址 + 8。PC = 當(dāng)前指令地址 + 8, 記住就行。

補(bǔ)充2:

匯編語言ldr偽指令

偽指令是用來自動(dòng)拆分代碼值的,會(huì)把一條語句拆分成多條語句。

示例:

/* 匯編點(diǎn)亮一個(gè) LED 燈 */

.text
.global _start

_start:
    ldr r1, =0x56000050
    ldr r0, =0x100  /* 相當(dāng)于 mov r0, #0x100 */
    str r0, [r1]

    ldr r1, =0x56000054
    ldr r0, =0 /* mov r0, #0 */
    str r0, [r1]

halt:
    b halt

ldr r1, =0x56000054就是一條偽指令,假設(shè)我們想把56000054值給r1寄存器,可以用 mov r1, #56000050 ,
但是長度超出了mov 能接收的長度,就要分為高低字節(jié)去發(fā)送,但是在某些時(shí)候我們還要去看開放文檔,才能知道
或者沒有開發(fā)文檔,那就讓偽指令自己去判斷。

原文鏈接:https://blog.csdn.net/weixin_42031299/article/details/114749604

欄目分類
最近更新