0

将以下代码翻译成汇编语言并显示最终的 Y 值。(2 分)

    X = 1;
    Y = 2;
    WHILE(X <= 10 ){
    IF((X%2) != 0)
        Y = Y * X;
    ELSE 
        Y++;
    X++;}
    Output Y

请让我知道我做的一切是否正确,因为我不确定我的输出是否正确。结果是 3712

*-----------------------------------------------------------
* Title      :
* Written by :
* Date       :
* Description:
*-----------------------------------------------------------
    ORG    $1000
START:                  ; first instruction of program

* Put program code here

  MOVE.W  #1,D1           ;PUT 0 IN D1 (X)
  MOVE.W  #2,D2           ;PUT 1 IN D2 (Y)

LOOP CLR.W   D3         ;Find the remainder
     MOVE.W  D1,D3
     DIVU    #2,D3
     SWAP    D3


     CMP     #0,D3      ;Compare remainder with 0
     BNE     NOTEQUAL   ;If NOT equal, then go to NOT equal

     ADD.W   #1,D2      ;Y++
     ADD.W   #1,D1      ;X++

     CMP     #11,D1     ;Compare D1 with 11
     BEQ     DONE       ;If D1 equals 11, break loop.      
     BRA     LOOP

NOTEQUAL 
      MULU.W  D1,D2     ;Multiply D1 and D2 and store it in D2
      ADD.W   #1,D1     ;X++
      CMP     #11,D1    ;Compare D1 with 11
      BEQ     DONE      ;If D1 equals 11, break loop. 
      BRA     LOOP


DONE LEA MESSAGE,A1
     MOVE.W #14,D0
     TRAP #15

     MOVE.W  D2,D1

     MOVE.W #3,D0
     TRAP #15    


    SIMHALT             ; halt simulator

* Put variables and constants here

MESSAGE DC.W    'Y is: ',0

    END    START        ; last line of source
4

1 回答 1

3

D3如果 的高位字包含大于 1 的数据,这将导致意外结果。

LOOP CLR.W   D3      ; D3 = [**** 0000]
     MOVE.W  D1,D3   ; D3 = [****    X]
     DIVU    #2,D3   ; if D3.h > 1, division overflows and D3 does not change
     SWAP    D3      ; Lower word is (X%2) or random data

如果您真的想使用,请DIVU确保清除长寄存器(使用clr.l d3或实际上更快moveq #0,d3)。如果您之后将其覆盖,则仅清除较低的单词是没有意义的。

但正如@PeterCordes 所说,DIVU检查低位效率非常低(我不会指出您的代码中的其他低效率)。更好地使用btst #0,d1Z如果该位为空,则设置标志)。替代方案是:

  • and.w带有您要测试的值的数字 1。Z如果最低位为空,还设置- 标志
  • 将值向右移动(C如果设置了最低位,则设置标志)

当然,您也可以部分展开循环,并利用(X%2) != 0每个其他迭代都为真的事实。您可以完全展开循环并将结果直接移动到您的目标中(这是大多数优化编译器能够做到的:https ://godbolt.org/z/VGecJ3 )。

于 2019-07-10T15:18:21.730 回答