日本a√视频在线,久久青青亚洲国产,亚洲一区欧美二区,免费g片在线观看网站

        <style id="k3y6c"><u id="k3y6c"></u></style>
        <s id="k3y6c"></s>
        <mark id="k3y6c"></mark>
          
          

          <mark id="k3y6c"></mark>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 數(shù)據(jù)傳送指令之:單數(shù)據(jù)交換指令

          數(shù)據(jù)傳送指令之:單數(shù)據(jù)交換指令

          作者: 時間:2013-09-13 來源:網(wǎng)絡 收藏

          本文引用地址:http://yuyingmama.com.cn/article/257078.htm

          5.5

          交換指令是load/store指令的一種特例,它把一個寄存器單元的內(nèi)容與寄存器內(nèi)容交換。交換指令是一個原子操作(atomic operation),也就是說,在連續(xù)的總線操作中讀/寫一個存儲單元,在操作期間阻止其他任何指令對該存儲單元的讀/寫。

          交換指令如表5.4所示。

          表5.4 交換指令SWP

          指 令

          作 用

          操 作

          SWP

          字交換

          Tmp=men32[Rn]

          Mem32[Rn]=Rm

          Rd=tmp

          續(xù)表

          指 令

          作 用

          操 作

          SWPB

          字節(jié)交換

          Tmp=men8[Rn]

          Mem8[Rn]=Rm

          Rd=tmp

          注意

          交換指令在執(zhí)行期間不能被其他任何指令或其他任何總線訪問打斷,在此期間系統(tǒng)占用總線(holds the bus),直至交換完成。

          5.5.1 字交換指令SWP

          (1)指令編碼格式

          SWP指令用于將內(nèi)存中的一個字單元和一個指定寄存器的值相交換。操作過程如下,假設內(nèi)存單元地址存放在寄存器Rn>中,指令將Rn>中的數(shù)據(jù)讀取到目的寄存器Rd中,同時將另一個寄存器Rm>的內(nèi)容寫入到該內(nèi)存單元中。當Rd>和Rm>為同一個寄存器時,指令交換該寄存器和內(nèi)存單元的內(nèi)容。

          指令的編碼格式如圖5.20所示。

          圖5.20 SWP指令編碼格式

          (2)指令的語法格式

          SWP{cond>} Rd>,Rm>,[Rn>]

          ① cond>

          為指令編碼中的條件域。它指示SWP指令在什么條件下執(zhí)行。當cond>忽略時,指令為無條件執(zhí)行(cond=AL(Alway))。

          ② Rd>

          目標寄存器。

          ③ Rm>

          寄存器包含將要存儲到內(nèi)存中的數(shù)據(jù)。

          ④ Rn>

          寄存器中包含將要訪問的內(nèi)存地址。

          (3)指令操作的偽代碼

          指令操作偽代碼如下面程序段所示。

          If ConditionPassed{cond} then

          If Rn[1:0]==0b00 then

          Temp=memory[Rn,4]

          Else if Rn[1:0]==0b01 then

          Temp=memory[Rn,4] Rotate_right 8

          Else if Rn[1:0]==0b10 then

          Temp=memory[Rn,4] Rotate_right 16

          Else /* Rn[1:0]==0b11 */

          Temp=memory[Rn,4] Rotate_right 24

          Memory[Rn,4]=Rm

          Rd=temp


          上一頁 1 2 下一頁

          評論


          相關推薦

          技術專區(qū)

          關閉