ARM處理器的尋址方式


處理器的尋址方式是通過指令給出的地址碼字段來尋找真實操作數地址的方式,ARM處理器支持9中尋址方式。

一 立即尋址

立即尋址指令后面的地址碼部分為立即數(常量或常數),立即尋址多用於給寄存器賦值

舉例

MOV RO, #1234
  • 1

指令執行后,R0=1234。

二 寄存器尋址

寄存器尋址中,操作數在寄存器中,指令執行時直接從寄存器中取值進行操作

舉例

MOV R0, R1
  • 1

指令執行后,R0=R1。

三 寄存器移位尋址

寄存器移位尋址是ARM指令集特有的尋址方式,和寄存器尋址類似,只是操作前需要對寄存器操作數進行移位操作

  • LSL:邏輯左移,移位后寄存器空出的低位補0。
  • LSR:邏輯右移,移位后寄存器空出的高位補0。
  • ASR:算術右移,移位過程中,符號位保持不變,如果源操作數是正數,則空出的高位補0,否則補1.
  • ROR:循環右移,移位后移除的低位填入空出的高位。
  • RRX:帶擴展的循環右移,操作數右移一位,移位空出的高位用C標志的值填充。

舉例

MOV R0, R1, LSL #2
  • 1

R1寄存器左移兩位賦值給R0,指令執行后,R0=R1*4。

四 寄存器間接尋址

寄存器間接尋址中地址碼給出的寄存器是操作數的地址指針,所需的操作數保存在寄存器指定的存儲單元中。

舉例

LDR R0, [R1]
  • 1

R1寄存器的數值作為地址,取出此地址中的值賦給R0寄存器

五 基址尋址

基址尋址是將地址碼給出的基址寄存器和偏移量相加,形成操作數的有效地址,所需的操作數保存在有效地址所指向的存儲單元中。基址尋址多用於查表和數組訪問等操作。

舉例

LDR R0, [R1, #-4]
  • 1

寄存器R1的數組減去4作為地址,取出此地址中的值賦值給R0

六 多寄存器尋址

多寄存器尋址一條指令最多可以完成16個通用寄存器的傳送。

舉例

LDMIA R0, {R1, R2, R3, R4}
  • 1

LDM是數據加載指令,指令的后綴IA表示每次執行完加載操作R0寄存器的值自增1個字。指令執行后,R1=[R0],R2=[R0+#4],R3=[R0+#8],R4=[R0+#12]。

七 堆棧尋址

堆棧尋址是ARM處理器特有的一種尋址方式,堆棧尋址使用特定的指令來完成。

  • LDMFA/STMFA
  • LDMEA/STMEA
  • LDMFD/STMFD
  • LDMED/STMED

舉例

STMFD SP1, {R1-R7, LR}
  • 1

將R1-R7,LR入棧,多用於保存子程序現場

LDMFD SP1, {R1-R7, LR}
  • 1

將數據出棧,放入R0-R7,LR寄存器,多用於恢復程序現場

八 塊拷貝尋址

塊拷貝尋址可實現連續地址數據從存儲器的某一位置拷貝到另一位置。

  • LDMIA/STMIA
  • LDMDA/STMDA
  • LDMIB/STMIB
  • LDMDB/STMDB

舉例

LDMIA R0!, {R1-R3}
  • 1

從R0寄存器的存儲單元中讀取3個字到R1-R3寄存器中

STMIA R0!, {R1-R3}
  • 1

存儲在R1-R3寄存器的內容到R0指向ed存儲單元。

九 相對尋址

相對尋址以程序計數器PC的當前值為基地址,指令中的地址標號作為偏移量,將兩者相加之后得到的操作數作為有效地址。

舉例

BL NEXT
   ...
NEXT:
   ...

BL NEXT是跳到NEXT標號處執行,這里的BL就是采用相對尋址標號NEXT是偏移量


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM