新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM匯編指令集之六——加載/存儲指令

        ARM匯編指令集之六——加載/存儲指令

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

        1、LDR指令

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

        LDR指令的格式為:

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

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

        指令示例:

        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寫入R1。

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

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

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

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

        2、LDRB指令

        LDRB指令的格式為:

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

        LDRB指令用于從存儲器中將一個8位的字節數據傳送到目的寄存器中,同時將寄存器的高24位清零。該指令通常用于從存儲器中讀取8位的字節數據到通用寄存器,然后對數據進行處理。當程序計數器PC作為目的寄存器時,指令從存儲器中讀取的字數據被當作目的地址,從而可以實現程序流程的跳轉。

        指令示例:

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

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

        3、LDRH指令

        LDRH指令的格式為:

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

        LDRH指令用于從存儲器中將一個16位的半字數據傳送到目的寄存器中,同時將寄存器的高16位清零。該指令通常用于從存儲器中讀取16位的半字數據到通用寄存器,然后對數據進行處理。當程序計數器PC作為目的寄存器時,指令從存儲器中讀取的字數據被當作目的地址,從而可以實現程序流程的跳轉。

        指令示例:

        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指令用于從源寄存器中將一個32位的字數據傳送到存儲器中。該指令在程序設計中比較常用,且尋址方式靈活多樣,使用方式可參考指令LDR。

        指令示例:

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

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

        5、STRB指令

        STRB指令的格式為:

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

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

        指令示例:

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

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

        6、STRH指令

        STRH指令的格式為:

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

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

        指令示例:

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

        STRH R0;將寄存器R0中的半字數據寫入以R1+8為地址的存儲器中。

        7、批量數據加載/存儲指令

        ARM微處理器所支持批量數據加載/存儲指令可以一次在一片連續的存儲器單元和多個寄存器之間傳送數據,批量加載指令用于將一片連續的存儲器中的數據傳送到多個寄存器,批量數據存儲指令則完成相反的操作。常用的加載存儲指令如下:

        LDM(或STM)指令

        LDM(或STM)指令的格式為:

        LDM(或STM){條件}{類型}基址寄存器{!},寄存器列表{∧}

        LDM(或STM)指令用于從由基址寄存器所指示的一片連續存儲器到寄存器列表所指示的多個寄存器之間傳送數據,該指令的常見用途是將多個寄存器的內容入棧或出棧。其中,{類型}為以下幾種情況:

        IA每次傳送后地址加1;

        IB每次傳送前地址加1;

        DA每次傳送后地址減1;

        DB每次傳送前地址減1;

        FD滿遞減堆棧;

        ED空遞減堆棧;

        FA滿遞增堆棧;

        EA空遞增堆棧;

        {!}為可選后綴,若選用該后綴,則當數據傳送完畢之后,將最后的地址寫入基址寄存器,否則基址寄存器的內容不改變。

        基址寄存器不允許為R15,寄存器列表可以為R0~R15的任意組合。

        {∧}為可選后綴,當指令為LDM且寄存器列表中包含R15,選用該后綴時表示:除了正常的數據傳送之外,還將SPSR復制到CPSR。同時,該后綴還表示傳入或傳出的是用戶模式下的寄存器,而不是當前模式下的寄存器。

        指令示例:

        STMFD R13!,{R0,R4-R12,LR};將寄存器列表中的寄存器(R0,R4到R12,LR)存入堆棧。

        LDMFD R13!,{R0,R4-R12,PC};將堆棧內容恢復到寄存器(R0,R4到R12,LR)。



        評論


        技術專區

        關閉
        主站蜘蛛池模板: 衢州市| 河东区| 宜丰县| 阿拉善右旗| 治多县| 枞阳县| 定兴县| 墨竹工卡县| 抚顺县| 浑源县| 兴宁市| 汉源县| 玛多县| 东阿县| 中江县| 铜川市| 海伦市| 南和县| 吉林省| 从江县| 凯里市| 翁牛特旗| 宁河县| 博罗县| 凤凰县| 仪征市| 漳浦县| 乐亭县| 社会| 金门县| 邯郸县| 许昌县| 丹巴县| 神池县| 岢岚县| 景德镇市| 吐鲁番市| 将乐县| 遂溪县| 庐江县| 崇左市|