新聞中心

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

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

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

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

        本文引用地址:http://www.104case.com/article/201611/317899.htm

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

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

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

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

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

        1、LDR指令

        LDR指令的格式為:

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

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

        指令演示樣例:

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

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

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

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

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

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

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

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

        2、LDRB指令

        LDRB指令的格式為:

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

        LDRB指令用于從存儲(chǔ)器中將一個(gè)8位的字節(jié)數(shù)據(jù)傳送到目的寄存器中,同一時(shí)候?qū)⒓拇嫫鞯母?4位清零。該指令通經(jīng)常使用于從存儲(chǔ)器中讀取8位的字節(jié)數(shù)據(jù)到通用寄存器,然后對(duì)數(shù)據(jù)進(jìn)行處理。當(dāng)程序計(jì)數(shù)器PC作為目的寄存器時(shí),指令從存儲(chǔ)器中讀取的字?jǐn)?shù)據(jù)被當(dāng)作目的地址,從而能夠?qū)崿F(xiàn)程序流程的跳轉(zhuǎn)。

        指令演示樣例:

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

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

        3、LDRH指令

        LDRH指令的格式為:

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

        LDRH指令用于從存儲(chǔ)器中將一個(gè)16位的半字?jǐn)?shù)據(jù)傳送到目的寄存器中,同一時(shí)候?qū)⒓拇嫫鞯母?6位清零。該指令通經(jīng)常使用于從存儲(chǔ)器中讀取16位的半字?jǐn)?shù)據(jù)到通用寄存器,然后對(duì)數(shù)據(jù)進(jìn)行處理。當(dāng)程序計(jì)數(shù)器PC作為目的寄存器時(shí),指令從存儲(chǔ)器中讀取的字?jǐn)?shù)據(jù)被當(dāng)作目的地址,從而能夠?qū)崿F(xiàn)程序流程的跳轉(zhuǎn)。

        指令演示樣例:

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

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

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

        4、STR指令

        STR指令的格式為:

        STR{條件}源寄存器,<存儲(chǔ)器地址>

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

        指令演示樣例:

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

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

        5、STRB指令

        STRB指令的格式為:

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

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

        指令演示樣例:

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

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

        6、STRH指令

        STRH指令的格式為:

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

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

        指令演示樣例:

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

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



        評(píng)論


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

        關(guān)閉
        主站蜘蛛池模板: 孝义市| 新竹县| 南宫市| 高平市| 于田县| 阳山县| 西昌市| 永年县| 宜良县| 杨浦区| 汝阳县| 申扎县| 集贤县| 安吉县| 霞浦县| 黄山市| 五常市| 定远县| 交口县| 合山市| 衡阳市| 虎林市| 荃湾区| 宁强县| 获嘉县| 区。| 勐海县| 闽侯县| 林芝县| 仙游县| 聂拉木县| 达州市| 塔河县| 峡江县| 禄丰县| 外汇| 鞍山市| 磐安县| 苏州市| 辽中县| 长治市|