In this lab you will construct an assembly routine that puts the ASCII representation of an input string in memory at a specified location. The LC-3 machine language provides several useful TRAP calls for I/O (Patt 2e Appendix A, p 541). For example, GETC (TRAP x20) gets one character from the keyboard and places its ASCII code in RO. OUT (TRAP X21) performs the opposite function - it takes the contents of RO and outputs the specified character (using ASCII encoding) to the display. The LC-3 provides two output TRAPS for strings: PUTS (TRAP x22) and PUTSP (TRAP x24). Both of these expect (in RO) a starting address for a string, and output the encoded string to the display. Your task is to produce two programs that provide the "opposite" function of PUTS and PUTSP- that is, they take a string as input and place the string into memory at a location specified in RO. You will create two separate stand-alone programs: one for GETS and one for GETSP. The programs do not need to be implemented as subroutines or TRAP calls. Using the LC-3 simulator, you will construct an assembly-level program that prompts the user for a string (the end of the string will be delimited by the character xOA, the ASCII character "Enter"). You will store the ASCII string representation of this input (including a terminating NULL character) in memory. The "Enter" character should not be considered part of the string and thus should not be stored. For the purposes of demonstration, I would like you to store the string at address x3100 (add the appropriate code to your program) and show that you have successfully stored the string by printing it back to the display using PUTS or PUTSP. Your program will be located in memory at location x3000. The following is an example output for both GETS.asm and GETSP.asm: Enter string to echo: Go Raiders! Go Raiders!
In this lab you will construct an assembly routine that puts the ASCII representation of an input string in memory at a specified location. The LC-3 machine language provides several useful TRAP calls for I/O (Patt 2e Appendix A, p 541). For example, GETC (TRAP x20) gets one character from the keyboard and places its ASCII code in RO. OUT (TRAP X21) performs the opposite function - it takes the contents of RO and outputs the specified character (using ASCII encoding) to the display. The LC-3 provides two output TRAPS for strings: PUTS (TRAP x22) and PUTSP (TRAP x24). Both of these expect (in RO) a starting address for a string, and output the encoded string to the display. Your task is to produce two programs that provide the "opposite" function of PUTS and PUTSP- that is, they take a string as input and place the string into memory at a location specified in RO. You will create two separate stand-alone programs: one for GETS and one for GETSP. The programs do not need to be implemented as subroutines or TRAP calls. Using the LC-3 simulator, you will construct an assembly-level program that prompts the user for a string (the end of the string will be delimited by the character xOA, the ASCII character "Enter"). You will store the ASCII string representation of this input (including a terminating NULL character) in memory. The "Enter" character should not be considered part of the string and thus should not be stored. For the purposes of demonstration, I would like you to store the string at address x3100 (add the appropriate code to your program) and show that you have successfully stored the string by printing it back to the display using PUTS or PUTSP. Your program will be located in memory at location x3000. The following is an example output for both GETS.asm and GETSP.asm: Enter string to echo: Go Raiders! Go Raiders!
Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
Related questions
Topic Video
Question
-
.ORIG x3000
-
-
; Set up the user stack:
-
LD R6, STKBASE ; Sets up the stack by loading the base address into R6
-
-
; Prompt for the first string:
-
LEA R0, PRMPT1 ; Loads the address of PRMPT1 into R0
-
PUTS
-
-
; Call GETS to get first string:
-
LEA R0, STRNG1 ; Loads the address of STRNG1
-
ADD R6, R6, #-1 ; Push the address to store the string at
-
STR R0, R6, #0
-
JSR GETSP ; Call GETSP
-
ADD R6, R6, #2 ; Clean up (pop parameter & return value)
-
-
; Prompt for second string:
-
LEA R0, PRMPT2 ; Loads the address of PRMPT2
-
PUTS
-
-
; Call GETS to get second string:
-
LEA R0, STRNG2 ; Loads the address of STRNG2
-
ADD R6, R6, #-1 ; Push the second address to store the string at
-
STR R0, R6, #0
-
JSR GETSP ; Call GETSP
-
ADD R6, R6, #2 ; Clean up (pop parameter & return value)
-
-
; Output both strings:
-
LEA R0, OUT1 ; First string...
-
PUTS
-
LEA R0, STRNG1
-
PUTSP
-
LD R0, LF ; Print a linefeed
-
OUT ; Write character to console (TRAP x21)
-
LEA R0, OUT2 ; Second string.
-
PUTS
-
LEA R0, STRNG2
-
PUTSP
-
-
HALT ; We are done
-
-
; GLOBAL VARIABLES
-
; ----------------
-
STKBASE .FILL xFDFF ; The bottom of the stack will be xFDFF
-
LF .FILL x0A ; A linefeed character. Change this to x0D if you are using UNIX desktop sim
-
PRMPT1 .STRINGZ "Please enter the first string: "
-
PRMPT2 .STRINGZ "Please enter the second string: "
-
OUT1 .STRINGZ "The first string was: "
-
OUT2 .STRINGZ "The second string was: "
-
CLU .FILL x00FF ; Clear upper byte of a value in a register
-
CLL .FILL xFF00 ; Clear lower byte of a value in a register
-
STRNG1 .BLKW #80 ; Room for 79 characters (unpacked) + NULL
-
STRNG2 .BLKW #80 ; Room for 79 characters (unpacked) + NULL
-
;=====================================================================================
-
; Place your GETSP subroutine below the notes:
-
;=====================================================================================
-
; Subroutine GETSP
-
; Parameters: Address - the address to store the string at
-
;
-
; Returns: Nothing
-
;
-
; Local variables
-
; Offset Description
-
; 0 Callee-saved register R0
-
; -1 Callee-saved register R1
Expert Solution
This question has been solved!
Explore an expertly crafted, step-by-step solution for a thorough understanding of key concepts.
This is a popular solution!
Trending now
This is a popular solution!
Step by step
Solved in 2 steps
Knowledge Booster
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.Recommended textbooks for you
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education