⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 算术和逻辑指令.htm

📁 ARM指令集
💻 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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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>&nbsp;  
<P><A name=add></A>
<H2>ADD : 加法</H2>
<P>(<FONT color=#0000ff>Add</FONT>ition)</P><PRE>  ADD{条件}{S}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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 &lt;&lt; 1)
</PRE>加法可以在有符号和无符号数上进行。 
<P>  
<P><A name=and></A>
<H2>AND : 逻辑与</H2>
<P>(logical <FONT color=#0000ff>AND</FONT>)</P><PRE>  AND{条件}{S}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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 &lt;&lt; 1) - R2
</PRE>反向减法可以在有符号或无符号数上进行。 
<P>&nbsp;  
<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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                dest = op_2 - op_1 - !carry
</PRE>同于 <CODE>SBC</CODE>,但倒换了两个操作数的前后位置。 
<P>&nbsp;  
<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}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                dest = op_1 - op_2 - !carry
</PRE><CODE>SBC</CODE> 做两个操作数的减法,把结果放置到目的寄存器中。它使用进位标志来表示借位,这样就可以做大于 32 
位的减法。<CODE>SUB</CODE> 和 <CODE>SBC</CODE> 
生成进位标志的方式不同于常规,如果需要借位则<B>清除</B>进位标志。所以,指令要对进位标志进行一个<B>非</B>操作 - 在指令执行期间自动的反转此位。 
<P>&nbsp;  
<P><A name=sub></A>
<H2>SUB : 减法</H2>
<P>(<FONT color=#0000ff>Sub</FONT>traction)</P><PRE>  SUB{条件}{S}  &lt;dest&gt;, &lt;op 1&gt;, &lt;op 2&gt;

                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 &lt;&lt; 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 &copy; 2001 Richard Murray </ADDRESS></BODY></HTML>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -