0

こんにちは、私は lc3 アセンブリ言語の初心者で、次の課題があります。

以下に示す印刷、右シフト、およびシフト サブルーチンを実装する必要があります。これらのサブルーチンのいずれかの助けをいただければ幸いです。

また、すべてのサブルーチンは、R7 を含むすべてのワーキング レジスタを保存/復元する必要があります。

LSHR アルゴリズムは次の場所にあります: http://users.cis.fiu.edu/~pestaina/RightShift.pdf。論理右シフト アルゴリズムを実装して RSHIFT サブルーチンを完了します。 RSHIFT をテストするには、MAIN の JSR SHIFT 命令を一時的に JSR RSHIFT に置き換えます。プログラムは、元のデータと右シフトされたデータを 6 回表示するはずです。

SHIFT サブルーチンを完了します。シフトされるデータは R0 で渡されます。R1 の値は次のようにシフト タイプを示します。 R1[0]; 算術シフトは R1[1] で示されます。循環シフトは R1[2] で示されます。ヒント: すべての左シフトは、論理左シフト (LSHL) のマイナーなバリエーションとして実装できます。LSHL は、データムをそれ自体に追加するだけで実行できます。ヒント: すべての右シフトは、RSHIFT サブルーチンに既に実装されている Logical Shift Right のバリエーションとして実装できます。

簡単な印刷アルゴリズムは次のとおりです。

do 16 times 
{
    output ( Reg[15] ?  ‘1’   :  ‘0’ );
    ShiftLeft( Reg  );
}

これは私が完了する必要があるプログラムです

    .ORIG   x3000
MAIN
LEA R3, DATA    ;R3 - Pointer to 1st Test Datum
TEST
LDR R2, R3, #0  ;R2 - Get next Test Datum
BRZ EXIT        ;     Exit if 0

AND R1, R1, #0  ;R1 - Shift Type initially 0
LEA R5, CAPS    ;R5 - Pointer to 1st Caption
NEXT
AND R0, R5, #-1 ;R5 - Display Caption LSHL, etc.
TRAP    x22
LD  R0, CR_LF
TRAP    x21

ADD R0, R2, #0  ;     Display Original Datum
JSR PRINT
LD  R0, CR_LF
TRAP    x21

ADD R0, R2, #0  ;     Shift Original Datum
JSR SHIFT       ;R0 - Shifted Datum

JSR PRINT       ;     Display Shifted Datum
LD  R0, CR_LF
TRAP    x21

ADD R5, R5, #5  ;R5 - Locate next Caption
ADD R1, R1, #1  ;R1 - Sequence to next Shift Type
ADD R4, R1, #-5 ;     Test Shift Type 
BRNZ    NEXT        ;     Exit if > 5

ADD R3, R3, #1  ;R3 - Locate next Test Datum
BRNZP   TEST        ;     Repeat
EXIT
TRAP    x25     ;     Halt
;Variables
DATA    .FILL   x9875       ;Test Datum
        .FILL   x0000       ;Sentinel
CR_LF    .FILL  x000A       ;New-Line \n
CAPS    .STRINGZ "LSHL"     ;Captions
        .STRINGZ "LSHR"
    .STRINGZ "ASHL"
        .STRINGZ "ASHR"
    .STRINGZ "CSHL"
    .STRINGZ "CSHR"
;====================================================================
PRINT   ;Display content of R0 in binary
    RET
;====================================================================
SHIFT   ;Universal Shift Subroutine
;        R0 - Datum to be Shifted
;        R1 - Shift Type: 000(0) - LSHL - Logical Left
;             001(1) - LSHR - Logical Right
;                         010(2) - ASHL - Arithmetic Left
;                         011(3) - ASHR - Arithmetic Right
;                         100(4) - CSHL - Circular Left
;                         101(5) - CSHR - Circular Right
RET
;====================================================================
RSHIFT  ;Perform a Logical Shift Right on R0
    ;Shifted result returned in R0

RET
;====================================================================
.END
4

1 に答える 1