你好,我是 lc3 汇编语言的初学者,我有这个任务:
我需要实现下面显示的打印、右移和移位子例程,任何这些子例程的任何帮助都将不胜感激:(不完整的代码在最后)
此外,所有子程序必须保存/恢复所有工作寄存器,包括 R7
此处给出了 LSHR 算法:http: //users.cis.fiu.edu/~pestaina/RightShift.pdf。通过实现逻辑右移算法来完成 RSHIFT 子例程 要测试 RSHIFT,请将 MAIN 中的 JSR SHIFT 指令暂时替换为 JSR RSHIFT。程序现在应该显示原始数据和右移数据六次。
完成 SHIFT 子程序。要移位的数据在 R0 中传递;R1 中的值表示移位类型如下: LSHL LSHR ASHL ASHR CSHL CSHR 0 1 2 3 4 5 .. 0000 .. 0001 .. 0010 .. 0011 .. 0100 ..0101 提示:总是描述移位方向在 R1[0] 中;算术移位由 R1[1] 表示;循环移位由 R1[2] 表示。提示:所有左移都可以作为逻辑左移 LSHL 的微小变化来实现。LSHL 可以通过简单地将基准与自身相加来完成。提示:所有右移都可以实现为逻辑右移的变体,已在您的 RSHIFT 子例程中实现。
这是一个简单的打印算法:
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