ARM匯編
宗旨:技術(shù)的學(xué)習(xí)是有限的,分享的精神是無限的。
1、寄存器組
ARM 處理器一般共有37個(gè)寄存器,其中包括:
(1)31 個(gè)通用寄存器,包括PC(程序計(jì)數(shù)器)在內(nèi),都是32位的寄存器。
(2) 6 個(gè)狀態(tài)寄存器,都是 32 位的寄存器。
ARM處理器的工作模式:用戶模式(User),快速中斷模式(FIQ),外部中斷模式(IRQ),特權(quán)模式(Supervisor),數(shù)據(jù)訪問終止模式(Abort),未定義指令中止模式(Undef),系統(tǒng)模式(System)
其中r0~r3主要用于子程序間傳遞參數(shù),r4~r11主要用于保存局部變量,但在Thumb 程序中,通常只能使用 r4~r7 來保存局部變量;r12 用作子程序間 scratch 寄存器,即 ip 寄存器;r13 通常用做棧指針,即sp; r14 寄存器又被稱為連接寄存器(lr),用于保存子程序的返回地址; r15 用作程序計(jì)數(shù)器(pc), 由于 ARM 采用了流水線機(jī)制,當(dāng)正確讀取了 PC 的值后,該值為當(dāng)前指令地址加 8 個(gè)字節(jié),即 PC 指向當(dāng)前指令的下兩條指令地址。
?
2、ARM尋址方式
2.1、立即尋址
ADD R0, R0, #0x3f ; R0<- R0 + 0x3f(大寫小寫都是一樣的)
?????? 第二個(gè)源操作數(shù)為立即數(shù),要求以“#”為前綴,對(duì)于十六進(jìn)制數(shù)需在緊跟“#”后加上“ 0x”。匯編中,“;”表示注釋。
2.2、寄存器尋址
ADDR0,R1, R2;將寄存器 R1 和 R2 存放的內(nèi)容相加存放到R0 中
2.3、寄存器間接尋址
ldr r0, [r1] ??; 將 R1 的值作為地址,取出存儲(chǔ)器中的數(shù)據(jù)傳送到 R0 中
str r0, [r1]?? ; 將 R0 的數(shù)據(jù)存儲(chǔ)到R1的值為地址的存儲(chǔ)器里面
2.4、多寄存器尋址
LDMIA R0,{R1,R2,R3,R4} ; R1 <-[R0],R2 <- [R0 + 4],
; R3 <- [R0 +8], R3 <- [R0 + 12]
?
3、ARM指令集
3.1、ARM指令的條件碼表
3.2、常用指令集
? ? ?mov?把值存入寄存器(MOV PC, R14; 退出到調(diào)用者)
? ? ?mvn 取反 ?(MVN R0, #4 ; R0 = -5) ? ?
? ? ?sub ??減法操作(SUB R0, R1, R2;R0 = R1 - R2)
? ? ?add? 加法操作(?ADD R0, R1, R2;R0 = R1 + R2)
? ? ?and? 邏輯與(AND R0, R0, #3;R0 = 保持 R0 的位 0 和 1,丟棄其余的位。)
? ? ?bic?是在一個(gè)字中清除位的一種方法 (BIC R0, R0, #%1011 ; 清除 R0 中的位 0、1、和 3。保持其余的不變。)
? ? ?cmp 比較?
? ? ?b 一旦遇到一個(gè)?B?指令,ARM 處理器將立即跳轉(zhuǎn)到給定的地址,從那里繼續(xù)執(zhí)行
? ? ?bl?就在分支之前,在寄存器 14 中裝載上 R15 的內(nèi)容? ?
? ? ?lsl 邏輯或者算算左移 (MOV R1, #12? MOV R0, R1, LSL#2)
? ? ?ror 循環(huán)右移
? ? ?msr 搬回 (MSR CPSR, R0;復(fù)制 R0 到 CPSR 中)
? ? ?mrs 搬出 ?(MRS R0, CPSR ;復(fù)制 CPSR 到 R0 中)
? ? ?ldr ?使用單一數(shù)據(jù)傳送指令(STR 和 LDR)來裝載和存儲(chǔ)單一字節(jié)或字的數(shù)據(jù)從/到內(nèi)存
? ? ?str ?寄存器內(nèi)容保存到內(nèi)存 ?ldr把內(nèi)存的數(shù)據(jù)讀到寄存器
?