<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > ARM指令集中經(jīng)常使用的存儲和載入指令

ARM指令集中經(jīng)常使用的存儲和載入指令

作者: 時(shí)間:2016-11-09 來(lái)源:網(wǎng)絡(luò ) 收藏
ARM微處理器支持載入/存儲指令用于在寄存器和存儲器之間傳送數據,載入指令用于將存儲器中的數據傳送到寄存器,存儲指令則完畢相反的操作。經(jīng)常使用的載入存儲指令例如以下:

—LDR字數據載入指令

本文引用地址:http://dyxdggzs.com/article/201611/317899.htm

—LDRB字節數據載入指令

—LDRH半字數據載入指令

—STR字數據存儲指令

—STRB字節數據存儲指令

—STRH半字數據存儲指令

1、LDR指令

LDR指令的格式為:

LDR{條件}目的寄存器,<存儲器地址>

LDR指令用于從存儲器中將一個(gè)32位的字數據傳送到目的寄存器中。該指令通經(jīng)常使用于從存儲器中讀取32位的字數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而能夠實(shí)現程序流程的跳轉。該指令在程序設計中比較經(jīng)常使用,且尋址方式靈活多樣,請讀者認真掌握。

指令演示樣例:

LDRR0,[R1];將存儲器地址為R1的字數據讀入寄存器R0。

LDRR0,[R1,R2];將存儲器地址為R1+R2的字數據讀入寄存器R0。

LDRR0,[R1,#8];將存儲器地址為R1+8的字數據讀入寄存器R0。

LDRR0,[R1,R2]??;將存儲器地址為R1+R2的字數據讀入寄存器R0,并將新地址R1+R2寫(xiě)入R1。

LDRR0,[R1,#8]??;將存儲器地址為R1+8的字數據讀入寄存器R0,并將新地址R1+8寫(xiě)入R1。

LDRR0,[R1],R2;將存儲器地址為R1的字數據讀入寄存器R0,并將新地址R1+R2寫(xiě)入R1。

LDRR0,[R1,R2,LSL#2]??;將存儲器地址為R1+R2×4的字數據讀入寄存器R0,并將新地址R1+R2×4寫(xiě)入R1。

LDRR0,[R1],R2,LSL#2;將存儲器地址為R1的字數據讀入寄存器R0,并將新地址R1+R2×4寫(xiě)入R1。

2、LDRB指令

LDRB指令的格式為:

LDR{條件}B目的寄存器,<存儲器地址>

LDRB指令用于從存儲器中將一個(gè)8位的字節數據傳送到目的寄存器中,同一時(shí)候將寄存器的高24位清零。該指令通經(jīng)常使用于從存儲器中讀取8位的字節數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而能夠實(shí)現程序流程的跳轉。

指令演示樣例:

LDRBR0,[R1];將存儲器地址為R1的字節數據讀入寄存器R0,并將R0的高24位清零。

LDRBR0,[R1,#8];將存儲器地址為R1+8的字節數據讀入寄存器R0,并將R0的高24位清零。

3、LDRH指令

LDRH指令的格式為:

LDR{條件}H目的寄存器,<存儲器地址>

LDRH指令用于從存儲器中將一個(gè)16位的半字數據傳送到目的寄存器中,同一時(shí)候將寄存器的高16位清零。該指令通經(jīng)常使用于從存儲器中讀取16位的半字數據到通用寄存器,然后對數據進(jìn)行處理。當程序計數器PC作為目的寄存器時(shí),指令從存儲器中讀取的字數據被當作目的地址,從而能夠實(shí)現程序流程的跳轉。

指令演示樣例:

LDRHR0,[R1];將存儲器地址為R1的半字數據讀入寄存器R0,并將R0的高16位清零。

LDRHR0,[R1,#8];將存儲器地址為R1+8的半字數據讀入寄存器R0,并將R0的高16位清零。

LDRHR0,[R1,R2];將存儲器地址為R1+R2的半字數據讀入寄存器R0,并將R0的高16位清零。

4、STR指令

STR指令的格式為:

STR{條件}源寄存器,<存儲器地址>

STR指令用于從源寄存器中將一個(gè)32位的字數據傳送到存儲器中。該指令在程序設計中比較經(jīng)常使用,且尋址方式靈活多樣,使用方式可參考指令LDR。

指令演示樣例:

STRR0,[R1],#8;將R0中的字數據寫(xiě)入以R1為地址的存儲器中,并將新地址R1+8寫(xiě)入R1。

STRR0,[R1,#8];將R0中的字數據寫(xiě)入以R1+8為地址的存儲器中。

5、STRB指令

STRB指令的格式為:

STR{條件}B源寄存器,<存儲器地址>

STRB指令用于從源寄存器中將一個(gè)8位的字節數據傳送到存儲器中。該字節數據為源寄存器中的低8位。

指令演示樣例:

STRBR0,[R1];將寄存器R0中的字節數據寫(xiě)入以R1為地址的存儲器中。

STRBR0,[R1,#8];將寄存器R0中的字節數據寫(xiě)入以R1+8為地址的存儲器中。

6、STRH指令

STRH指令的格式為:

STR{條件}H源寄存器,<存儲器地址>

STRH指令用于從源寄存器中將一個(gè)16位的半字數據傳送到存儲器中。該半字數據為源寄存器中的低16位。

指令演示樣例:

STRHR0,[R1];將寄存器R0中的半字數據寫(xiě)入以R1為地址的存儲器中。

STRHR0,[R1,#8];將寄存器R0中的半字數據寫(xiě)入以R1+8為地址的存儲器中。



關(guān)鍵詞: ARM指令集存儲和載入指

評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>