こんにちは、私は 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