在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM數(shù)據(jù)處理指令

            ARM數(shù)據(jù)處理指令

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

            寄存器傳送指令
            移位指令
            算術(shù)運(yùn)算指令
            邏輯運(yùn)算指令
            比較指令
            乘法指令

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

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


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

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

            ;32位無符號(hào)乘法計(jì)算R0*R1,R4存結(jié)果
            ;32位無符號(hào)乘加計(jì)算R0*R1+R0,R5存結(jié)果
            ;32 位無符號(hào)乘法計(jì)算R2*R3,R6存結(jié)果
            ;64位無符號(hào)乘法計(jì)算R2*R3,R7存低32位,R8存高32位
            STOP
            B STOP
            END

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


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

            實(shí)驗(yàn)四:
            編寫簡(jiǎn)單的匯編語言程序,功能是計(jì)算1+2+3+。。。。+n的值,并把累加的結(jié)果存儲(chǔ)到寄存器中。 (exp3_1_1)

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

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


            關(guān)鍵詞: ARM數(shù)據(jù)處理指

            評(píng)論


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

            關(guān)閉