ARM匯編指令集之六——加載/存儲指令
1、LDR指令
本文引用地址:http://dyxdggzs.com/article/201611/317603.htmLDR指令的格式為:
LDR{條件}目的寄存器,<存儲器地址>
LDR指令用于從存儲器中將一個(gè)32位的字數據傳送到目的寄存器中。該指令通常用于從存儲器中讀取32位的字數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而可以實(shí)現程序流程的跳轉。該指令在程序設計中比較常用,且尋址方式靈活多樣,請讀者認真掌握。
指令示例:
LDR R0,[R1];將存儲器地址為R1的字數據讀入寄存器R0。
LDR R0,[R1,R2];將存儲器地址為R1+R2的字數據讀入寄存器R0。
LDR R0,[R1,#8] ;將存儲器地址為R1+8的字數據讀入寄存器R0。
LDR R0,[R1,R2]! ;將存儲器地址為R1+R2的字數據讀入寄存器R0,并將新地址R1+R2寫(xiě)入R1。
LDR R0,[R1,#8]! ;將存儲器地址為R1+8的字數據讀入寄存器R0,并將新地址R1+8寫(xiě)入R1。
LDR R0,[R1],R2 ;將存儲器地址為R1的字數據讀入寄存器R0,并將新地址R1+R2寫(xiě)入R1。
LDR R0,[R1,R2,LSL#2]! ;將存儲器地址為R1+R2×4的字數據讀入寄存器R0,并將新地址R1+R2×4寫(xiě)入R1。
LDR R0,[R1],R2,LSL#2 ;將存儲器地址為R1的字數據讀入寄存器R0,并將新地址R1+R2×4寫(xiě)入R1。
2、LDRB指令
LDRB指令的格式為:
LDR{條件}B目的寄存器,<存儲器地址>
LDRB指令用于從存儲器中將一個(gè)8位的字節數據傳送到目的寄存器中,同時(shí)將寄存器的高24位清零。該指令通常用于從存儲器中讀取8位的字節數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而可以實(shí)現程序流程的跳轉。
指令示例:
LDRB R0,[R1];將存儲器地址為R1的字節數據讀入寄存器R0,并將R0的高24位清零。
LDRB R0,[R1,#8];將存儲器地址為R1+8的字節數據讀入寄存器R0,并將R0的高24位清零。
3、LDRH指令
LDRH指令的格式為:
LDR{條件}H目的寄存器,<存儲器地址>
LDRH指令用于從存儲器中將一個(gè)16位的半字數據傳送到目的寄存器中,同時(shí)將寄存器的高16位清零。該指令通常用于從存儲器中讀取16位的半字數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而可以實(shí)現程序流程的跳轉。
指令示例:
LDRH R0,[R1];將存儲器地址為R1的半字數據讀入寄存器R0,并將R0的高16位清零。
LDRH R0,[R1,#8];將存儲器地址為R1+8的半字數據讀入寄存器R0,并將R0的高16位清零。
LDRH R0,[R1,R2];將存儲器地址為R1+R2的半字數據讀入寄存器R0,并將R0的高16位清零。
4、STR指令
STR指令的格式為:
STR{條件}源寄存器,<存儲器地址>
STR指令用于從源寄存器中將一個(gè)32位的字數據傳送到存儲器中。該指令在程序設計中比較常用,且尋址方式靈活多樣,使用方式可參考指令LDR。
指令示例:
STR R0,[R1],#8;將R0中的字數據寫(xiě)入以R1為地址的存儲器中,并將新地址R1+8寫(xiě)入R1。
STR R0,[R1,#8];將R0中的字數據寫(xiě)入以R1+8為地址的存儲器中。
5、STRB指令
STRB指令的格式為:
STR{條件}B源寄存器,<存儲器地址>
STRB指令用于從源寄存器中將一個(gè)8位的字節數據傳送到存儲器中。該字節數據為源寄存器中的低8位。
指令示例:
STRB R0,[R1];將寄存器R0中的字節數據寫(xiě)入以R1為地址的存儲器中。
STRB R0,[R1,#8];將寄存器R0中的字節數據寫(xiě)入以R1+8為地址的存儲器中。
6、STRH指令
STRH指令的格式為:
STR{條件}H源寄存器,<存儲器地址>
STRH指令用于從源寄存器中將一個(gè)16位的半字數據傳送到存儲器中。該半字數據為源寄存器中的低16位。
指令示例:
STRH R0,[R1];將寄存器R0中的半字數據寫(xiě)入以R1為地址的存儲器中。
STRH R0;將寄存器R0中的半字數據寫(xiě)入以R1+8為地址的存儲器中。7、批量數據加載/存儲指令
ARM微處理器所支持批量數據加載/存儲指令可以一次在一片連續的存儲器單元和多個(gè)寄存器之間傳送數據,批量加載指令用于將一片連續的存儲器中的數據傳送到多個(gè)寄存器,批量數據存儲指令則完成相反的操作。常用的加載存儲指令如下:
LDM(或STM)指令
LDM(或STM)指令的格式為:
LDM(或STM){條件}{類(lèi)型}基址寄存器{!},寄存器列表{∧}
LDM(或STM)指令用于從由基址寄存器所指示的一片連續存儲器到寄存器列表所指示的多個(gè)寄存器之間傳送數據,該指令的常見(jiàn)用途是將多個(gè)寄存器的內容入?;虺鰲?。其中,{類(lèi)型}為以下幾種情況:
IA每次傳送后地址加1;
IB每次傳送前地址加1;
DA每次傳送后地址減1;
DB每次傳送前地址減1;
FD滿(mǎn)遞減堆棧;
ED空遞減堆棧;
FA滿(mǎn)遞增堆棧;
EA空遞增堆棧;
{!}為可選后綴,若選用該后綴,則當數據傳送完畢之后,將最后的地址寫(xiě)入基址寄存器,否則基址寄存器的內容不改變。
基址寄存器不允許為R15,寄存器列表可以為R0~R15的任意組合。
{∧}為可選后綴,當指令為L(cháng)DM且寄存器列表中包含R15,選用該后綴時(shí)表示:除了正常的數據傳送之外,還將SPSR復制到CPSR。同時(shí),該后綴還表示傳入或傳出的是用戶(hù)模式下的寄存器,而不是當前模式下的寄存器。
指令示例:
STMFD R13!,{R0,R4-R12,LR};將寄存器列表中的寄存器(R0,R4到R12,LR)存入堆棧。
LDMFD R13!,{R0,R4-R12,PC};將堆棧內容恢復到寄存器(R0,R4到R12,LR)。
評論