?? 算術和邏輯指令.htm
字號:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0049)http://www.linuxforum.net/books/mhss/arm/mov.html -->
<HTML><HEAD><TITLE>Arithmetic and Logical instructions</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<META http-equiv=Content-Language content=zh-cn>
<META content="MSHTML 6.00.2600.0" name=GENERATOR>
<META content=FrontPage.Editor.Document name=ProgId></HEAD>
<BODY text=#000000 vLink=#002288 link=#0022dd bgColor=#f0f0f0>
<TABLE width="100%" border=0>
<TBODY>
<TR>
<TD align=middle width=100></TD>
<TD>
<H1 align=center><FONT color=#800080>算術和邏輯指令</FONT></H1></TD>
<TD align=middle width=100></TD></TR></TBODY></TABLE>
<UL>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#adc">ADC</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#add">ADD</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#and">AND</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#bic">BIC</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#eor">EOR</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#mov">MOV</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#mvn">MVN</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#orr">ORR</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#rsb">RSB</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#rsc">RSC</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#sbc">SBC</A>
<LI><A href="http://www.linuxforum.net/books/mhss/arm/mov.html#sub">SUB</A>
</LI></UL>
<P><A
href="http://www.linuxforum.net/books/mhss/arm/ARMinstrs.html#Data">指令格式</A>
<P><A name=adc></A></P>
<H2>ADC : 帶進位的加法</H2>
<P>(<FONT color=#0000ff>Ad</FONT>dition with <FONT
color=#0000ff>C</FONT>arry)</P><PRE> ADC{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 + op_2 + carry
</PRE><CODE>ADC</CODE> 將把兩個操作數加起來,并把結果放置到目的寄存器中。它使用一個進位標志位,這樣就可以做比 32
位大的加法。下列例子將加兩個 128 位的數。<BR>128 位結果: 寄存器 0、1、2、和 3<BR>第一個 128 位數: 寄存器 4、5、6、和
7<BR>第二個 128 位數: 寄存器 8、9、10、和 11。 <PRE> ADDS R0, R4, R8 ; 加低端的字
ADCS R1, R5, R9 ; 加下一個字,帶進位
ADCS R2, R6, R10 ; 加第三個字,帶進位
ADCS R3, R7, R11 ; 加高端的字,帶進位
</PRE>如果如果要做這樣的加法,不要忘記設置 S 后綴來更改進位標志。
<P>
<P><A name=add></A>
<H2>ADD : 加法</H2>
<P>(<FONT color=#0000ff>Add</FONT>ition)</P><PRE> ADD{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 + op_2
</PRE><CODE>ADD</CODE> 將把兩個操作數加起來,把結果放置到目的寄存器中。操作數 1 是一個寄存器,操作數 2
可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> ADD R0, R1, R2 ; R0 = R1 + R2
ADD R0, R1, #256 ; R0 = R1 + 256
ADD R0, R2, R3,LSL#1 ; R0 = R2 + (R3 << 1)
</PRE>加法可以在有符號和無符號數上進行。
<P>
<P><A name=and></A>
<H2>AND : 邏輯與</H2>
<P>(logical <FONT color=#0000ff>AND</FONT>)</P><PRE> AND{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 AND op_2
</PRE><CODE>AND</CODE> 將在兩個操作數上進行邏輯與,把結果放置到目的寄存器中;對屏蔽你要在上面工作的位很有用。 操作數 1
是一個寄存器,操作數 2 可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> AND R0, R0, #3 ; R0 = 保持 R0 的位 0 和 1,丟棄其余的位。
</PRE>AND 的真值表(二者都是 1 則結果為 1): <PRE> Op_1 Op_2 結果
0 0 0
0 1 0
1 0 0
1 1 1
</PRE>
<P><A name=bic></A>
<H2>BIC : 位清除</H2>
<P>(<FONT color=#0000ff>Bi</FONT>t <FONT color=#0000ff>C</FONT>lear)</P><PRE> BIC{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 AND (!op_2)
</PRE><CODE>BIC</CODE> 是在一個字中清除位的一種方法,與 OR 位設置是相反的操作。操作數 2 是一個 32
位位掩碼(mask)。如果如果在掩碼中設置了某一位,則清除這一位。未設置的掩碼位指示此位保持不變。 <PRE> BIC R0, R0, #%1011 ; 清除 R0 中的位 0、1、和 3。保持其余的不變。
</PRE>BIC 真值表 : <PRE> Op_1 Op_2 結果
0 0 0
0 1 0
1 0 1
1 1 0</PRE><PRE>譯注:邏輯表達式為 Op_1 AND NOT Op_2</PRE>
<P> </P>
<P><A name=eor></A></P>
<H2>EOR : 邏輯異或</H2>
<P>(logical <FONT color=#0000ff>E</FONT>xclusive <FONT
color=#0000ff>OR</FONT>)</P><PRE> EOR{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 EOR op_2
</PRE><CODE>EOR</CODE> 將在兩個操作數上進行邏輯異或,把結果放置到目的寄存器中;對反轉特定的位有用。操作數 1 是一個寄存器,操作數 2
可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> EOR R0, R0, #3 ; 反轉 R0 中的位 0 和 1
</PRE>EOR 真值表(二者不同則結果為 1): <PRE> Op_1 Op_2 結果
0 0 0
0 1 1
1 0 1
1 1 0
</PRE>
<P><A name=mov></A>
<H2>MOV : 傳送</H2>
<P>(<FONT color=#0000ff>Mov</FONT>e)</P><PRE> MOV{條件}{S} <dest>, <op 1>
dest = op_1
</PRE><CODE>MOV</CODE> 從另一個寄存器、被移位的寄存器、或一個立即值裝載一個值到目的寄存器。你可以指定相同的寄存器來實現 NOP
指令的效果,你還可以專門移位一個寄存器: <PRE> MOV R0, R0 ; R0 = R0... NOP 指令
MOV R0, R0, LSL#3 ; R0 = R0 * 8
</PRE>如果 R15 是目的寄存器,將修改程序計數器或標志。這用于返回到調用代碼,方法是把連接寄存器的內容傳送到 R15: <PRE> MOV PC, R14 ; 退出到調用者
MOVS PC, R14 ; 退出到調用者并恢復標志位
<FONT color=red>(不遵從 32-bit 體系)</FONT>
</PRE>
<P><A name=mvn></A>
<H2>MVN : 傳送取反的值</H2>
<P>(<FONT color=#0000ff>M</FONT>o<FONT color=#0000ff>v</FONT>e<FONT
color=#0000ff> N</FONT>egative)</P><PRE> MVN{條件}{S} <dest>, <op 1>
dest = !op_1
</PRE><CODE>MVN</CODE>
從另一個寄存器、被移位的寄存器、或一個立即值裝載一個值到目的寄存器。不同之處是在傳送之前位被反轉了,所以把一個被取反的值傳送到一個寄存器中。這是邏輯非操作而不是算術操作,這個取反的值加
1 才是它的取負的值: <PRE> MVN R0, #4 ; R0 = -5
MVN R0, #0 ; R0 = -1
</PRE>
<P><A name=orr></A>
<H2>ORR : 邏輯或</H2>
<P>(logical <FONT color=#0000ff>OR</FONT>)</P><PRE> ORR{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 OR op_2
</PRE><CODE>OR</CODE> 將在兩個操作數上進行邏輯或,把結果放置到目的寄存器中;對設置特定的位有用。操作數 1 是一個寄存器,操作數 2
可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> ORR R0, R0, #3 ; 設置 R0 中位 0 和 1
</PRE>OR 真值表(二者中存在 1 則結果為 1): <PRE> Op_1 Op_2 結果
0 0 0
0 1 1
1 0 1
1 1 1
</PRE>
<P><A name=rsb></A>
<H2>RSB : 反向減法</H2>
<P>(<FONT color=#0000ff>R</FONT>everse <FONT color=#0000ff>S</FONT>u<FONT
color=#0000ff>b</FONT>traction)</P><PRE> RSB{條件}{S} <dest>, <op 1>, <op 2>
dest = op_2 - op_1
</PRE><CODE>SUB</CODE> 用操作數 <B>two </B>減去操作數 <B>one</B>,把結果放置到目的寄存器中。操作數 1
是一個寄存器,操作數 2 可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> RSB R0, R1, R2 ; R0 = R2 - R1
RSB R0, R1, #256 ; R0 = 256 - R1
RSB R0, R2, R3,LSL#1 ; R0 = (R3 << 1) - R2
</PRE>反向減法可以在有符號或無符號數上進行。
<P>
<P><A name=rsc></A>
<H2>RSC : 帶借位的反向減法</H2>
<P>(<FONT color=#0000ff>R</FONT>everse <FONT color=#0000ff>S</FONT>ubtraction
with <FONT color=#0000ff>C</FONT>arry)</P><PRE> RSC{條件}{S} <dest>, <op 1>, <op 2>
dest = op_2 - op_1 - !carry
</PRE>同于 <CODE>SBC</CODE>,但倒換了兩個操作數的前后位置。
<P>
<P><A name=sbc></A>
<H2>SBC : 帶借位的減法</H2>
<P>(<FONT color=#0000ff>S</FONT>u<FONT color=#0000ff>b</FONT>traction with <FONT
color=#0000ff>C</FONT>arry)</P><PRE> SBC{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 - op_2 - !carry
</PRE><CODE>SBC</CODE> 做兩個操作數的減法,把結果放置到目的寄存器中。它使用進位標志來表示借位,這樣就可以做大于 32
位的減法。<CODE>SUB</CODE> 和 <CODE>SBC</CODE>
生成進位標志的方式不同于常規,如果需要借位則<B>清除</B>進位標志。所以,指令要對進位標志進行一個<B>非</B>操作 - 在指令執行期間自動的反轉此位。
<P>
<P><A name=sub></A>
<H2>SUB : 減法</H2>
<P>(<FONT color=#0000ff>Sub</FONT>traction)</P><PRE> SUB{條件}{S} <dest>, <op 1>, <op 2>
dest = op_1 - op_2
</PRE><CODE>SUB</CODE> 用操作數 <B>one </B>減去操作數<B></B><B> two</B>,把結果放置到目的寄存器中。操作數
1 是一個寄存器,操作數 2 可以是一個寄存器,被移位的寄存器,或一個立即值: <PRE> SUB R0, R1, R2 ; R0 = R1 - R2
SUB R0, R1, #256 ; R0 = R1 - 256
SUB R0, R2, R3,LSL#1 ; R0 = R2 - (R3 << 1)
</PRE>減法可以在有符號和無符號數上進行。
<P>
<HR SIZE=3>
<A href="http://www.linuxforum.net/books/mhss/arm/index.html">Return to
assembler index</A>
<HR SIZE=3>
<ADDRESS>Copyright © 2001 Richard Murray </ADDRESS></BODY></HTML>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -