新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > ARM數據處理指令

        ARM數據處理指令

        作者: 時間:2016-11-21 來源:網絡 收藏
        ARM數據處理指令只訪問寄存器,是ARM指令集中唯一可以修改數據值的指令。所有的操作數都是32位,結果也是32位,被放到寄存器中。

        寄存器傳送指令
        移位指令
        算術運算指令
        邏輯運算指令
        比較指令
        乘法指令

        1. 掌握寄存器傳送指令、算術運算指令,并理解標志位S的作用。
        實驗一:
        根據提示信息完成程序并運行驗證。(exp5_1_1.s)
        AREA lab1,CODE,READONLY
        ENTRY
        START
        MOV R0,#0x3F
        MOV R1,#0x2C
        MOV R2,#0x10
        MOV R3,#0x5
        ;(1)計算R4=R0+R1
        ;(2)計算R5=R0-R1并更新標志位
        ;(3)計算R6=R1-R0并更新標志位
        ;(4)計算R7=R2+8*R3
        STOP
        B STOP
        END

        思考題:
        a) 在程序中執行
        SUBS R4,R0,R1
        SUBS R4,R1,R0
        后,程序狀態寄存器CPSR的標志位各有何變化?為什么?
        b) 在程序中執行
        SUB R4,R0,R1
        SUB R4,R1,R0
        后,程序狀態寄存器CPSR的標志位各有何變化?為什么?


        實驗二:
        編寫ARM匯編程序。有兩個128位數,第一個數0x00000004000000c3000000b2000000a1由高到低存放在寄存器R7~R4中,第二個數0x00000008000000c7000000b6000000a5由高到低存放在寄存器R11~R8中,實現第一個數和第二個數的相減,運算結果由高到低存放到寄存器R3~R0中。(exp5_1_5.s)

        2. 掌握乘法指令
        實驗六:根據提示信息完成程序并運行驗證。(exp5_1_6.s)
        AREA lab3,CODE,READONLY
        ENTRY
        START
        MOV R0,#0x3F
        MOV R1,#0x3D
        MOV R2,#0xFF000000
        MOV R3,#0x3FC0

        ;32位無符號乘法計算R0*R1,R4存結果
        ;32位無符號乘加計算R0*R1+R0,R5存結果
        ;32 位無符號乘法計算R2*R3,R6存結果
        ;64位無符號乘法計算R2*R3,R7存低32位,R8存高32位
        STOP
        B STOP
        END

        思考題:
        在上述程序中,執行語句
        MUL R6,R2,R3
        UMULL R7,R8,R2,R3
        SMULL R9,R10,R2,R3
        后,解析個寄存器的值。


        3. 掌握比較測試指令,懂得使用ARM指令的條件域來標注指令執行的條件。
        實驗三:
        根據提示信息完成程序并運行驗證。(exp)
        AREA lab1,CODE,READONLY
        ENTRY
        START
        MOV R0,#0xFF
        ;反轉R0的0,1位,其余位保持不變,存到R1中
        ;保留寄存器R0的0,1位,其余位清零,存到R1中
        ;比較寄存器R0和R1的值是否相等,并根據結果修改CPSR的標志位
        MOV R0,#0xFB
        ;測試寄存器R0中的第2位是否為1,并根據結果修改CPSR的標志位(若是,跳轉到START)
        END

        實驗四:
        編寫簡單的匯編語言程序,功能是計算1+2+3+。。。。+n的值,并把累加的結果存儲到寄存器中。 (exp3_1_1)

        4. 掌握邏輯運算指令
        實驗五:
        將0x3FC0的第4~11位用0xDD替換,變成0x3DD0。根據提示信息完成程序并運行驗證。 (exp)
        AREA lab2,CODE,READONLY
        ENTRY
        START
        MOV R1,#0x3FC0
        MOV R2,#0xFF0
        MOV R3,#0xDD
        ;清除R1=0x3FC0中對應的位,使其成為0x3000
        ;通過移位,將0x3DD0與要替換的位域對齊
        ;將對應位置寫入目的操作數R1
        STOP
        B STOP
        END

        思考:
        在上述程序中,如果將0x3FC0替換為0xCFC0,應該如何修改程序?


        關鍵詞: ARM數據處理指

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 乌海市| 屯门区| 盘山县| 武鸣县| 远安县| 西丰县| 五莲县| 蓝田县| 玉环县| 三亚市| 沙雅县| 土默特左旗| 乐业县| 开江县| 英德市| 孝感市| 安庆市| 普兰店市| 睢宁县| 黑山县| 子长县| 叙永县| 兴义市| 缙云县| 吕梁市| 谢通门县| 清河县| 民权县| 承德县| 巨野县| 昭苏县| 农安县| 年辖:市辖区| 台湾省| 吉林省| 青岛市| 新晃| 五常市| 铁力市| 漳州市| 上蔡县|