Appendix A

The LC-2 ISA

A.1 Overview

The Instruction Set Architecture (ISA) of the LC-2 is defined as follows:

- **Memory address space** 16 bits, corresponding to $2^{16}$ locations, each consisting of one word (16 bits). Addresses are numbered from 0 (i.e., x0000) to 65,535 (i.e., xFFFF). Addresses are used to identify memory locations and memory-mapped I/O device registers. For convenience, these locations are partitioned into $2^7$ pages of $2^9$ words each.

- **General purpose registers** Eight 16-bit registers, numbered from 000 to 111.

- **Program counter** A 16-bit register.

- **Bit numbering** Bits of all quantities are numbered, from right to left, starting with bit 0.

- **Instructions** Instructions are 16 bits wide. Bits [15:12] specify the opcode (operation to be performed), bits [11:0] provide further information that is needed to execute the instruction. Section A.3 provides further information on each of the 16 instructions.

- **Condition codes** The load instructions (LD, LDI, LDR, LEA) and the operate instructions (ADD, AND, and NOT) set the three condition codes, depending on whether the result is negative ($N = 1$, $Z = 0$, $P = 0$), zero ($N = 0$, $Z = 1$, $P = 0$), or positive ($N = 0$, $Z = 0$, $P = 1$).

- **Memory mapped I/O** Input and output are handled by standard load/store instructions using memory addresses to designate each I/O device register.

Table A.1 lists each of the relevant device registers, along with the memory address it has been assigned in the LC-2.
\begin{tabular}{|c|c|p{10cm}|}
\hline
\textbf{Location} & \textbf{I/O Register Name} & \textbf{I/O Register Function} \\
\hline
xF3FC  & CRT status register  & Also known as CRTSR. The ready bit (bit [15]) indicates if the video device is ready to receive another character to print on the screen. \\
xF3FF  & CRT data register     & Also known as CRTDR. A character written in the low byte of this register will be displayed on the screen. \\
xF400  & Keyboard status register & Also known as KBSR. The ready bit (bit [15]) indicates if the keyboard has received a new character. \\
xF401  & Keyboard data register & Also known as KBDR. Bits [7:0] contain the last character typed on the keyboard. \\
xF402  & Machine control register & Also known as MCR. Bit [15] is the clock enable bit. When cleared, instruction processing stops. \\
\hline
\end{tabular}

Table A.1: Device register assignments

A.2 Notation

The notation in Table A.2 will be helpful in understanding the descriptions of the LC-2 instructions (Section A.3).

A.3 The Instruction Set

The 16 LC-2 instructions are summarized in Figure A.1 (page 432). On the following pages, the instructions are described in greater detail. For each instruction, we show the assembly language representation, the actual format of the 16-bit instruction, the operation of the instruction, an English-language description of the operation, and one or more examples of the instruction.
### Notation Meanings

<table>
<thead>
<tr>
<th>Notation</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>xNumber</td>
<td>The number in hexadecimal notation.</td>
</tr>
<tr>
<td>#Number</td>
<td>The number in decimal notation.</td>
</tr>
<tr>
<td>A[:r]</td>
<td>The field delimited by bit[i] on the left and bit[r] on the right, from the datum A. For example, if PC contains 0011001100111111, then PC[15:9] is 0011001. PC[22] is 1. If i and r are the same bit number, the notation is usually abbreviated PC[2].</td>
</tr>
<tr>
<td>A @ B</td>
<td>Concatenation of A and B. For example, if A is 0011 001 and B is 1100 1100, A @ B = 0011 0011 100 1100.</td>
</tr>
<tr>
<td>BaseR</td>
<td>Base Register; one of R0..R7, used in conjunction with a six-bit offset to compute Base+offet addresses.</td>
</tr>
<tr>
<td>page</td>
<td>The set of 2^6 consecutive memory locations whose addresses share the same high seven address bits.</td>
</tr>
<tr>
<td>DR</td>
<td>Destination Register; one of R0..R7, which specifies where the result of an instruction should be written.</td>
</tr>
<tr>
<td>imm5</td>
<td>A five-bit immediate value; bits [4:0] of an instruction, when used as a literal (immediate) value. Taken as a 5-bit, 2's complement integer, it is sign-extended to 16 bits before it is used. Range: -16..15.</td>
</tr>
<tr>
<td>index6</td>
<td>Six-bit immediate value; bits [5:0] of an instruction, when used in a Base-offset instruction. Taken as a six-bit unsigned integer, it is zero-extended to 16 bits before it is used. Range: 0..63.</td>
</tr>
<tr>
<td>LABEL</td>
<td>An assembler construct that identifies a location symbolically (i.e., by means of a name, rather than its 16-bit address).</td>
</tr>
<tr>
<td>L</td>
<td>Link bit; differentiates JSR from JMP and JSRR from JMP R instructions. If L = 1 (JSR, JSRR), the value of the PC will be saved in R7. If L = 0, the PC is not saved in R7.</td>
</tr>
<tr>
<td>mem[address]</td>
<td>Denotes the contents of memory at the given address.</td>
</tr>
<tr>
<td>PC</td>
<td>Program Counter; 16-bit, processor-internal register which contains the memory address of the next instruction to be fetched. For example, during execution of the instruction at address A, the PC contains address A + 1.</td>
</tr>
<tr>
<td>pgoffset9</td>
<td>Nine bits that differentiate the 2^9 locations on a page. PC[15:9] is concatenated with pgoffset9 to form a 16-bit memory address. Range 0..511.</td>
</tr>
<tr>
<td>setcc(X)</td>
<td>Indicates that condition codes N, Z, and P are set based on the value of X. If X is negative, N = 1; Z = 0, P = 0. If X is zero, N = 0, Z = 1, P = 0. If X is positive, N = 0, Z = 0, P = 1.</td>
</tr>
<tr>
<td>SEXT(A)</td>
<td>Sign-extend A. The most significant bit of A is replicated as many times as necessary to extend A to 16 bits. For example, if A = 110000, then SEXT(A) = 1111 1111 1111 0000.</td>
</tr>
<tr>
<td>SR, SR1, SR2</td>
<td>Source Register; one of R0..R7 which specifies from where an instruction operand is obtained.</td>
</tr>
<tr>
<td>trapvect8</td>
<td>Eight-bit trap number used in the TRAP instruction. Range 0-255.</td>
</tr>
<tr>
<td>ZEXT(A)</td>
<td>Zero-extend A. Zeroes are appended to the left-most bit of A to extend it to 16 bits. For example, if A = 110000, then ZEXT(A) = 0000 0000 0011 0000.</td>
</tr>
</tbody>
</table>

**Table A.2: Notational Conventions**
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Opcode</th>
<th>Function</th>
<th>Condition Codes</th>
<th>Flags</th>
<th>Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD*</td>
<td>0001</td>
<td>DR</td>
<td>SR1 0 0</td>
<td>P</td>
<td>SR2</td>
</tr>
<tr>
<td>ADD*</td>
<td>0001</td>
<td>DR</td>
<td>SR1 1</td>
<td>P</td>
<td>imm5</td>
</tr>
<tr>
<td>AND*</td>
<td>0101</td>
<td>DR</td>
<td>SR1 0 0</td>
<td>P</td>
<td>SR2</td>
</tr>
<tr>
<td>AND*</td>
<td>0101</td>
<td>DR</td>
<td>SR1 1</td>
<td>P</td>
<td>imm5</td>
</tr>
<tr>
<td>BR</td>
<td>0000</td>
<td>n</td>
<td>z p</td>
<td>pgoffset9</td>
<td></td>
</tr>
<tr>
<td>JSR</td>
<td>0100</td>
<td>L</td>
<td>00</td>
<td>pgoffset9</td>
<td></td>
</tr>
<tr>
<td>JSRR</td>
<td>1100</td>
<td>L</td>
<td>00 BaseR</td>
<td>index6</td>
<td></td>
</tr>
<tr>
<td>LD*</td>
<td>0010</td>
<td>DR</td>
<td>pgoffset9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LDI*</td>
<td>1010</td>
<td>DR</td>
<td>pgoffset9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>LDR*</td>
<td>0110</td>
<td>DR</td>
<td>BaseR</td>
<td>index6</td>
<td></td>
</tr>
<tr>
<td>LEA*</td>
<td>1110</td>
<td>DR</td>
<td>pgoffset9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>NOT*</td>
<td>1001</td>
<td>DR</td>
<td>SR 1111111</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RET</td>
<td>1101</td>
<td></td>
<td>000000000000</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTI*</td>
<td>1000</td>
<td></td>
<td>000000000000</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ST</td>
<td>0011</td>
<td>SR</td>
<td>pgoffset9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>STI</td>
<td>1011</td>
<td>SR</td>
<td>pgoffset9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>STR</td>
<td>0111</td>
<td>SR</td>
<td>BaseR</td>
<td>index6</td>
<td></td>
</tr>
<tr>
<td>TRAP</td>
<td>1111</td>
<td>0000</td>
<td>trapvect8</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure A.1: Formats of the 16 LC-2 instructions. NOTE: + indicates instructions that modify condition codes; * indicates that meaning and use of RTI is beyond the scope of this book.
A.3. THE INSTRUCTION SET

ADD

Addition

Assembler Formats

ADD DR, SR1, SR2
ADD DR, SR1, imm5

Encodings

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0001</td>
<td>DR</td>
<td>SR1</td>
<td>0</td>
<td>00</td>
<td>SR2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0001</td>
<td>DR</td>
<td>SR1</td>
<td>1</td>
<td>imm5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

if (bit[5] == 0)
    DR = SR1 + SR2;
else
    DR = SR1 + SEXT(imm5);
setcc(DR);

Description

If bit [5] is 0, the second-source operand is obtained from SR2. If bit [5] is 1, the second-source operand is obtained by sign-extend the imm5 field to 16 bits. In both cases, the second source operand is added to the contents of SR1, and the result stored in DR. The condition codes are set, based on whether the result is negative, zero, or positive.

Examples

ADD R2, R3, R4 ; R2 ← R3 + R4
ADD R2, R3, #7  ; R2 ← R3 + 7
AND

Bitwise logical AND

Assembler Formats

AND DR, SR1, SR2
AND DR, SR1, imm5

Encodings

\[
\begin{array}{cccccccc}
15 & 12 & 11 & 9 & 8 & 6 & 5 & 4 & 3 & 2 & 0 \\
0101 & DR & SR1 & 0 & 00 & SR2 \\
\end{array}
\]

\[
\begin{array}{cccccccc}
15 & 12 & 11 & 9 & 8 & 6 & 5 & 4 & 0 \\
0101 & DR & SR1 & 1 & imm5 \\
\end{array}
\]

Operation

if (bit[5] == 0)
    DR = SR1 AND SR2;
else
    DR = SR1 AND SEXT(imm5);
    setcc(DR);

Description

If bit [5] is 0, the second-source operand is obtained from SR2. If bit [5] is 1, the second-source operand is obtained by sign-extending the imm5 field to 16 bits. In either case, the second-source operand and the contents of SR1 are bitwise ANDed, and the result stored in DR. The condition codes are set, based on whether the binary value produced, taken as a 2’s complement integer, is negative, zero, or positive.

Examples

AND R2, R3, R4 ; R2 ← R3 AND R4
AND R2, R3, #7 ; R2 ← R3 AND 7
BR

Conditional Branch

Assembler Formats

BR LABEL
BRn LABEL
BRz LABEL
BRp LABEL
BRnz LABEL
BRnp LABEL
BRzp LABEL
BRnzp LABEL

Encoding

```
   | 15 | 12 | 11 | 10 | 9 | 8 | pgoffset9 |
---|--|--|--|--|--|--|-----------|
 0000 | n | z | p |     |     |     |
```

Operation

if \(((n \text{ AND } N) \text{ OR } (z \text{ AND } Z) \text{ OR } (p \text{ AND } P))\)
PC = PC[15:9] @ pgoffset9;

Description

Test the condition codes specified by the state of bits [11:9]. If bit [11] is set, test N; if bit [11] is clear, do not test N. If bit [10] is set, test Z, etc. If any of the condition codes tested is set, branch to the location specified by pgoffset9 on the same page as the branch instruction.

Example

BRzp LOOP ; Branch to LOOP if the last result was zero or positive.
**JSR**

Jump to Subroutine

**JMP**

Jump

**Assembler Formats**

<table>
<thead>
<tr>
<th>JSR LABEL</th>
<th>(L = 1)</th>
</tr>
</thead>
<tbody>
<tr>
<td>JMP LABEL</td>
<td>(L = 0)</td>
</tr>
</tbody>
</table>

**Encoding**

```
  15  12  11  10  9  8
0100  L  00  pgoffset9
```

**Operation**

if (L == 1)
R7 = PC;
PC = PC[15:9] @ pgoffset9;

**Description**

Unconditionally jump to the location specified by pgoffset9 on the same page as the JSR/JMP instruction. If the link bit L is set, the PC is saved in R7, enabling a subsequent return to the instruction physically following the JSR instruction.

**Examples**

<table>
<thead>
<tr>
<th>JSR</th>
<th>FOO</th>
<th>Jump to FOO, put return PC into R7.</th>
</tr>
</thead>
<tbody>
<tr>
<td>JMP</td>
<td>FOO</td>
<td>Jump to FOO.</td>
</tr>
</tbody>
</table>
A.3. THE INSTRUCTION SET

JSRR  Jump to Subroutine, Base+Offset
JMPR  Jump, Base+Offset

Assembler Formats

JSRR BaseR, index6  \( (L = 1) \)
JMPR BaseR, index6  \( (L = 0) \)

Encoding

```
<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>9</th>
<th>8</th>
<th>6</th>
<th>5</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1100</td>
<td>L</td>
<td>00</td>
<td>BaseR</td>
<td>index6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
```

Operation

```
if (L == 1)
  R7 = PC;
PC = BaseR + ZEXT(index6);
```

Description

Unconditionally jump to the location specified by adding ZEXT(index6) to the contents of the base register. If the link bit \( L \) is set, the PC is saved in R7, enabling a subsequent return to the instruction physically following the JSRR instruction.

Examples

```
JSRR  R2, #10    ; Jump to R2 + #10, put return PC into R7.
JMPR  R2, #10    ; Jump to R2 + #10.
```
LD

Load Direct

Assembler Format

LD DR, LABEL

Encoding

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>offset9</th>
</tr>
</thead>
<tbody>
<tr>
<td>0010</td>
<td>DR</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

DR = mem[PC[15:9] @ pgoffset9];
set cc(DR);

Description

Load the register specified by DR from the location specified by pgoffset9 on the same page as the LD instruction. The condition codes are set, based on whether the value loaded is negative, zero, or positive.

Example

LD R4, COUNT ; R4 ← mem[COUNT].
LDI

Load Indirect

Assembler Format

LDI DR, LABEL

Encoding

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>DR</th>
<th>pg offset9</th>
</tr>
</thead>
<tbody>
<tr>
<td>1010</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>DR</td>
<td>pg offset9</td>
</tr>
</tbody>
</table>

Operation

\[
\text{DR} = \text{mem}[\text{mem}[\text{PC}[15:9] \, @ \, \text{pg offset9}]]; \\
\text{set cc(DR)};
\]

Description

Load the register specified by DR as follows: Construct an address by concatenating the top seven bits of the program counter with the pg offset9 field of the LDI instruction. The contents of memory at that address is the address of the data to be loaded into DR. The condition codes are set, based on whether the value loaded is negative, zero, or positive.

Example

LDI R4, POINTER ; R4 ← mem[mem[POINTER]].
LDR

**Load Base + Index**

**Assembler Format**

LDR DR, BaseR, index6

**Encoding**

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>6</th>
<th>5</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0110</td>
<td>DR</td>
<td>BaseR</td>
<td>index6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Operation**

DR = mem[BaseR + ZEXT(index6)];
set cc(DR);

**Description**

Load the register specified by DR from the location specified by a base register and index, as follows: The index is zero-extended to 16 bits and added to the contents of BaseR to form a memory address. The contents of memory at this address are loaded into DR. The condition codes are set, based on whether the value loaded is negative, zero, or positive.

**Example**

LDR  R4, R2, #10  ;  R4 ← contents of mem[R2 + #10].
A.3. THE INSTRUCTION SET

LEA

Load Effective Address

Assembler Format

LEA DR, LABEL

Encoding

```
15 12 11 9 8 0
1110 DR poffset9
```

Operation

```
DR = PC[15:9] @ poffset9;
setcc(DR);
```

Description

Load the register specified by DR with the address formed by concatenating the top seven bits of the program counter with the poffset9 field of the instruction. The condition codes are set, based on whether the value loaded is negative, zero, or positive.

Example

```
LEA R4, FOO ; R4 ← address of FOO.
```
NOT

Bitwise Complement

Assembler Format

NOT DR, SR

Encoding

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>6</th>
<th>5</th>
<th>4</th>
<th>3</th>
<th>2</th>
<th>1</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1001</td>
<td>DR</td>
<td>SR</td>
<td>11111</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

DR = NOT(SR);
setcc(DR);

Description

Perform the bitwise complement operation on the contents of SR and place the result in DR. The condition codes are set.

Example

NOT R4, R2 ; R4 ← NOT(R2).
A.3. THE INSTRUCTION SET

RET               Return from Subroutine

Assembler Format

RET

Encoding

\[ \begin{array}{c}
15 & 12 & 11 & 0 \\
1101 & & & 00000000000 \\
\end{array} \]

Operation

\[ \text{PC} = \text{R}7; \]

Description

Load the PC with the value in R7. This causes a return from a previous JSR or JSRR instruction.

Example

RET ; PC ← R7.
RTI

Return from Interrupt

Assembler Format

RTI

Encoding

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>10</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1000</td>
<td>0000000000</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

\[
\begin{align*}
NZP &= \text{mem}[R6]; \\
R6 &= R6 - 1; \\
PC &= \text{mem}[R6]; \\
R6 &= R6 - 1;
\end{align*}
\]

Description

Pop the top two elements off the stack; load them into NZP, PC.

Example

RTI ; NZP, PC ← top two values popped off stack.

Notes

On an external interrupt, the initiating sequence pushes the current PC onto the stack before loading the PC with the starting address of the service routine. The last instruction in the service routine is RTI, which returns control to the interrupted program by popping the stack and loading the value popped into the PC. (This instruction is included in this appendix for completeness. Its purpose and use are beyond the scope of what is normally covered in an introductory textbook.)
A.3. THE INSTRUCTION SET

ST                        Store Direct

Assembler Format

ST SR, LABEL

Encoding

Operation

\[
\text{mem}[\text{PC}[15:9] @ \text{pgoffset}9] = \text{SR};
\]

Description

Store the contents of the register specified by SR into the memory location specified by pgoffset9 on the same page as the ST instruction.

Example

\[
\text{ST R4, COUNT} ; \quad \text{mem[COUNT]} \leftarrow \text{R4}.
\]
STI Store Indirect

Assembler Format

STI SR, LABEL

Encoding

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>pgoffset9</th>
</tr>
</thead>
<tbody>
<tr>
<td>1011</td>
<td>SR</td>
<td></td>
<td></td>
<td></td>
<td>pgoffset9</td>
</tr>
</tbody>
</table>

Operation

\[ \text{mem}[\text{mem}[\text{PC}[15:9] \odot \text{pgoffset9}]] = \text{SR}; \]

Description

Store the contents of the register specified by SR into the memory location whose address is obtained as follows: Construct an address by concatenating the top seven bits of the program counter with the pgoffset9 field of the STI instruction. The contents of memory at that address is the address of the location to which the data in SR is to be stored.

Example

STI R4, POINTER ; mem[mem[POINTER]] ← R4.
A.3. THE INSTRUCTION SET

STR  

Store Base+Offset

Assembler Format

STR SR, BaseR, index6

Encoding

<table>
<thead>
<tr>
<th>15</th>
<th>12</th>
<th>11</th>
<th>9</th>
<th>8</th>
<th>6</th>
<th>5</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0111</td>
<td>SR</td>
<td>BaseR</td>
<td>index6</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

\[\text{mem}[	ext{BaseR} + \text{ZEXT(index6)}] = \text{SR};\]

Description

Store the contents of the register specified by SR into the memory location whose address is specified as follows: The six-bit offset is zero-extended to 16 bits and added to the contents of BaseR to form a memory address. This is the address of the location into which the contents of SR is to be stored.

Example

\[\text{STR } R4, R2, \#10 ; \text{ mem}[R2 + \#10] \leftarrow R4.\]
TRAP Operating System Call

Assembler Format

TRAP trapvector8

Encoding

<table>
<thead>
<tr>
<th></th>
<th>15</th>
<th>12, 11</th>
<th>8</th>
<th>7</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1111</td>
<td>0000</td>
<td>trapvector8</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Operation

R7 = PC;  
PC = mem[ZEXT(trapvector8)];

Description

Load the PC with the contents of the memory location obtained by zero-extending trapvector8 to 16 bits. This is the starting address of the system call specified by trapvector8. Load R7 with the PC, which enables a return to the instruction physically following the TRAP instruction in the original program after the service routine has completed.

Example

TRAP x23 ; Direct the operating system to execute the  
         ; IN system call.

Notes

Memory locations x0020 through x00FF, 192 in all, are available to contain starting addresses for system calls specified by their corresponding trapvectors. This region of memory is called the trap vector table. See Table A.3. Memory locations x0000 through x001F are not part of the trap vector table; therefore, x00 through x1F may not be used as trapvectors.
### A.3. THE INSTRUCTION SET

<table>
<thead>
<tr>
<th>TRAP Number</th>
<th>Assembler Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>x20</td>
<td>GETC</td>
<td>Read a single character from the keyboard. The character is not echoed onto the console. Its ASCII code is copied into R0. The high eight bits of R0 are cleared.</td>
</tr>
<tr>
<td>x21</td>
<td>OUT</td>
<td>Write a character in R0[7:0] to the console.</td>
</tr>
<tr>
<td>x22</td>
<td>PUTS</td>
<td>Write a string pointed to by R0 to the console.</td>
</tr>
<tr>
<td>x23</td>
<td>IN</td>
<td>Print a prompt on the screen and read a single character from the keyboard. The character is echoed onto the console, and its ASCII code is copied into R0. The high eight bits of R0 are cleared.</td>
</tr>
<tr>
<td>x25</td>
<td>HALT</td>
<td>Halt execution and print a message on the console.</td>
</tr>
</tbody>
</table>

Table A.3: TRAP vector table