色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

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

          ARM指令集中常用的存儲和加載指令

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

          —LDR字?jǐn)?shù)據(jù)加載指令

          本文引用地址:http://cafeforensic.com/article/201611/317900.htm

          —LDRB字節(jié)數(shù)據(jù)加載指令

          —LDRH半字?jǐn)?shù)據(jù)加載指令

          —STR字?jǐn)?shù)據(jù)存儲指令

          —STRB字節(jié)數(shù)據(jù)存儲指令

          —STRH半字?jǐn)?shù)據(jù)存儲指令

          1、LDR指令

          LDR指令的格式為:

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

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

          指令示例:

          LDRR0,[R1];將存儲器地址為R1的字?jǐn)?shù)據(jù)讀入寄存器R0。

          LDRR0,[R1,R2];將存儲器地址為R1+R2的字?jǐn)?shù)據(jù)讀入寄存器R0。

          LDRR0,[R1,#8];將存儲器地址為R1+8的字?jǐn)?shù)據(jù)讀入寄存器R0。

          LDRR0,[R1,R2]!;將存儲器地址為R1+R2的字?jǐn)?shù)據(jù)讀入寄存器R0,并將新地址R1+R2寫入R1。

          LDRR0,[R1,#8]!;將存儲器地址為R1+8的字?jǐn)?shù)據(jù)讀入寄存器R0,并將新地址R1+8寫入R1。

          LDRR0,[R1],R2;將存儲器地址為R1的字?jǐn)?shù)據(jù)讀入寄存器R0,并將新地址R1+R2寫入R1。

          LDRR0,[R1,R2,LSL#2]!;將存儲器地址為R1+R2×4的字?jǐn)?shù)據(jù)讀入寄存器R0,并將新地址R1+R2×4寫入R1。

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

          2、LDRB指令

          LDRB指令的格式為:

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

          LDRB指令用于從存儲器中將一個8位的字節(jié)數(shù)據(jù)傳送到目的寄存器中,同時將寄存器的高24位清零。該指令通常用于從存儲器中讀取8位的字節(jié)數(shù)據(jù)到通用寄存器,然后對數(shù)據(jù)進(jìn)行處理。當(dāng)程序計數(shù)器PC作為目的寄存器時,指令從存儲器中讀取的字?jǐn)?shù)據(jù)被當(dāng)作目的地址,從而可以實(shí)現(xiàn)程序流程的跳轉(zhuǎn)。

          指令示例:

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

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

          3、LDRH指令

          LDRH指令的格式為:

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

          LDRH指令用于從存儲器中將一個16位的半字?jǐn)?shù)據(jù)傳送到目的寄存器中,同時將寄存器的高16位清零。該指令通常用于從存儲器中讀取16位的半字?jǐn)?shù)據(jù)到通用寄存器,然后對數(shù)據(jù)進(jìn)行處理。當(dāng)程序計數(shù)器PC作為目的寄存器時,指令從存儲器中讀取的字?jǐn)?shù)據(jù)被當(dāng)作目的地址,從而可以實(shí)現(xiàn)程序流程的跳轉(zhuǎn)。

          指令示例:

          LDRHR0,[R1];將存儲器地址為R1的半字?jǐn)?shù)據(jù)讀入寄存器R0,并將R0的高16位清零。

          LDRHR0,[R1,#8];將存儲器地址為R1+8的半字?jǐn)?shù)據(jù)讀入寄存器R0,并將R0的高16位清零。

          LDRHR0,[R1,R2];將存儲器地址為R1+R2的半字?jǐn)?shù)據(jù)讀入寄存器R0,并將R0的高16位清零。

          4、STR指令

          STR指令的格式為:

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

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

          指令示例:

          STRR0,[R1],#8;將R0中的字?jǐn)?shù)據(jù)寫入以R1為地址的存儲器中,并將新地址R1+8寫入R1。

          STRR0,[R1,#8];將R0中的字?jǐn)?shù)據(jù)寫入以R1+8為地址的存儲器中。

          5、STRB指令

          STRB指令的格式為:

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

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

          指令示例:

          STRBR0,[R1];將寄存器R0中的字節(jié)數(shù)據(jù)寫入以R1為地址的存儲器中。

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

          6、STRH指令

          STRH指令的格式為:

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

          STRH指令用于從源寄存器中將一個16位的半字?jǐn)?shù)據(jù)傳送到存儲器中。該半字?jǐn)?shù)據(jù)為源寄存器中的低16位。

          指令示例:

          STRHR0,[R1];將寄存器R0中的半字?jǐn)?shù)據(jù)寫入以R1為地址的存儲器中。

          STRHR0,[R1,#8];將寄存器R0中的半字?jǐn)?shù)據(jù)寫入以R1+8為地址的存儲器中。



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

          評論


          技術(shù)專區(qū)

          關(guān)閉