如何在lc3汇编语言中实现PRINT子例程?

时间:2013-11-27 03:45:44

标签: assembly subroutine bit-shift lc3

您好我是lc3汇编语言的初学者,我有这个任务:

我需要实现下面显示的print,right shift和shift子程序,任何这些子程序的任何帮助都将受到赞赏:(不完整的代码在最后)

此外,所有子程序都必须保存/恢复所有工作寄存器,包括R7

这里给出了一个LSHR算法:http://users.cis.fiu.edu/~pestaina/RightShift.pdf。 通过实现逻辑右移算法完成RSHIFT子程序要测试RSHIFT,请使用JSR RSHIFT临时替换MAIN中的JSR SHIFT指令。程序现在应该显示原始和右移数据六次。

完成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可以通过简单地添加数据来完成。 提示:所有权利转移都可以作为Logical Shift Right的变体实现,已经在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

1 个答案:

答案 0 :(得分:0)

我认为“打印”命令应该是PUTS。那将打印内存的内容,从R0开始,以null终结符结束(我认为)。