| Table A.2           | Notational Conventions                                                                                                                                                                                                                                                                                                                                                           |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Notation            | Meaning                                                                                                                                                                                                                                                                                                                                                                          |
| xNumber             | The number in hexadecimal notation. Example: xF2A1                                                                                                                                                                                                                                                                                                                               |
| #Number             | The number in decimal notation. Example #793                                                                                                                                                                                                                                                                                                                                     |
| bNumber             | The number in binary. Example b10011                                                                                                                                                                                                                                                                                                                                             |
| A[l:r]              | The field delimited by bit [i] on the left and bit [r] on the right, of the datum A. For example, if PC contains 00110011001111111, then PC[15:9] is 0011001. PC[2:2] is 1. If I and r are the same bit number, we generally write PC[2].                                                                                                                                        |
| BaseR               | Base Register; one of RO.R7, specified by bits [8:6] of the instruction, used in conjunction with a six-bit offset to compute Base+offset addresses (LDR and STR), or alone to identify the target address of a control instruction (JMP and JSRR).                                                                                                                              |
| DR                  | Destination Register; one of R0R7, which specifies the register a result should be written to.                                                                                                                                                                                                                                                                                   |
| mm5                 | A five-bit immediate value (bits [4:0] of an instruction), when used as a literal (immediate) value. Taken as a five-bit, 2's complement integer, it is sign-extended to 16 bits before it is used. Range: -1615.                                                                                                                                                                |
| INTV                | An eight-bit value, supplied along with an interrupting event; used to determine the starting address of an interrupt service routine. The eight bits form an offset from the starting address of the interrupt vector table. The corresponding location in the interrupt vector table contains the starting address of the corresponding interrupt service routine. Range 0255. |
| LABEL               | An assembly language construct that identifies a location symbolically (i.e., by means of a name, rather than its 16-bit address).                                                                                                                                                                                                                                               |
| mem[address]        | Denotes the contents of memory at the given address.                                                                                                                                                                                                                                                                                                                             |
| offset6             | A six-bit signed 2's complement integer (bits [5:0] of an instruction), used with the Base+offset addressing mode. Bits [5:0] are sign-extended to 16 bits and then added to the Base Register to form an address. Range: -3231.                                                                                                                                                 |
| PC                  | Program Counter; 16-bit register that contains the memory address of the next instruction to be fetched. For example, if the instruction at address A is not a control instruction, during its execution, the PC contains the address A + 1, indicating that the next instruction to be executed is contained in memory location A + 1.                                          |
| PCoffset9           | A nine-bit signed 2's complement integer (bits [8:0] of an instruction), used with the PC+offset addressing mode. Bits [8:0] are sign-extended to 16 bits and then added to the incremented PC to form an address. Range –256255.                                                                                                                                                |
| PCoffset11          | An eleven-bit signed 2's complement integer (bits [10:0] of an instruction), used with the JSR opcode                                                                                                                                                                                                                                                                            |
| Conserv             | to compute the target address of a subroutine call. Bits [10:0] are sign-extended to 16 bits and then added to the incremented PC to form the target address. Range –10241023.                                                                                                                                                                                                   |
| PSR                 | Processor Status Register. A 16-bit register that contains status information of the process that is executing. Seven bits of the PSR have been specified. PSR[15] = privilege mode. PSR[10:8] = Priority Level. PSR[2:0] contains the condition codes. PSR[2] = N, PSR[1] = Z, PSR[0] = P.                                                                                      |
| Saved_SSP           | Saved Supervisor Stack Pointer. The processor is executing in either Supervisor mode or User mode. If in User mode, R6, the stack pointer, is the User Stack Pointer (USP). The Supervisor Stack Pointer (SSP) is stored in Saved_SSP. When the privilege mode changes from User mode to Supervisor mode, Saved_USP is loaded with R6 and R6 is loaded with Saved_SSP.           |
| Saved_USP           | Saved User Stack Pointer. The User Stack Pointer is stored in Saved_USP when the processor is executing in Supervisor mode. See Saved_SSP.                                                                                                                                                                                                                                       |
| setcc()<br>SEXT(A)  | Indicates that condition codes N, Z, and P are set based on the value of the result written to DR.  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.                                                                                                |
| SP                  | The current stack pointer. R6 is the current stack pointer. There are two stacks, one for each privilege mode. SP is SSP if PSR[15] = 0; SP is USP if PSR[15] = 1.                                                                                                                                                                                                               |
| SR, SR1, SR2<br>SSP | Source register; one of R0R7 that specifies the register from which a source operand is obtained. The Supervisor Stack Pointer.                                                                                                                                                                                                                                                  |
| trapvect8           | An eight-bit value (bits [7:0] of an instruction), used with the TRAP opcode to determine the starting address of a trap service routine. Bits [7:0] are taken as an unsigned integer and zero-extended to 16 bits. This is the address of the memory location containing the starting address of the corresponding service routine. Range 0255.                                 |
| USP                 | The User Stack Pointer.                                                                                                                                                                                                                                                                                                                                                          |
| ZEXT(A)             | Zero-extend A. Zeros are appended to the leftmost bit of A to extend it to 16 bits. For example, if $A = 110000$ , then ZEXT(A) = 0000 0000 0011 0000.                                                                                                                                                                                                                           |

ADD Addition

#### Assembler Formats

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

### Encodings



#### Operation

## 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 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.

```
ADD R2, R3, R4 ; R2 \leftarrow R3 + R4
ADD R2, R3, #7 ; R2 \leftarrow R3 + 7
```

# Bit-wise Logical AND



#### Assembler Formats

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

#### **Encodings**



#### Operation

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

## 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.

```
AND R2, R3, R4 ;R2 \leftarrow R3 AND R4
AND R2, R3, #7 ;R2 \leftarrow R3 AND 7
```

# BR

#### Conditional Branch

#### Assembler Formats

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

#### Encoding

| 15   | 12 | 11   | 10     | 9  | 8  |   |       |       |    | 0  |
|------|----|------|--------|----|----|---|-------|-------|----|----|
| 0000 |    | n    | z      | р  | 1. | 1 | PCoff | fset9 | 10 | 1  |
| 1    | 1  | 1000 | 375.00 | P. | 10 | 1 |       | 1     | 15 | 31 |

#### Operation

```
if ((n AND N) OR (z AND Z) OR (p AND P))
PC=PC*+ SEXT(PCoffset9);
```

#### Description

The condition codes specified by bits [11:9] are tested. If bit [11] is 1, N is tested; if bit [11] is 0, N is not tested. If bit [10] is 1, Z is tested, etc. If any of the condition codes tested is 1, the program branches to the memory location specified by adding the sign-extended PCoffset9 field to the incremented PC.

#### Examples

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

BR<sup>†</sup> NEXT ; Unconditionally branch to NEXT.

 $<sup>^{\</sup>dagger}$ The assembly language opcode BR is interpreted the same as BRnzp; that is, always branch to the target address.

<sup>&</sup>lt;sup>‡</sup>This is the incremented PC.

# JMP RET

## Jump

#### Return from Subroutine

#### Assembler Formats

JMP BaseR RET

#### Encoding



### Operation

PC = BaseR;

## Description

The program unconditionally jumps to the location specified by the contents of the base register. Bits [8:6] identify the base register.

## Examples

JMP R2 ; PC  $\leftarrow$  R2 RET ; PC  $\leftarrow$  R7

#### Note

The RET instruction is a special case of the JMP instruction, normally used in the return from a subroutine. The PC is loaded with the contents of R7, which contains the linkage back to the instruction following the subroutine call instruction.

#### Jump to Subroutine

# JSR JSRR

#### Assembler Formats

JSR LABEL JSRR BaseR

#### Encoding



#### Operation

```
R7 = PC;
if (bit[11] == 0)
    PC = BaseR;
else
    PC = PC<sup>†</sup> + SEXT(PCoffset11);
```

#### Description

First, the incremented PC is saved in R7. This is the linkage back to the calling routine. Then the PC is loaded with the address of the first instruction of the subroutine, causing an unconditional jump to the address after the current instruction completes execution. The address of the subroutine is obtained from the base register (if bit [11] is 0), or the address is computed by sign-extending bits [10:0] and adding this value to the incremented PC (if bit[11] is 1).

#### Examples

JSR QUEUE; Put the address of the instruction following JSR into R7; ; Jump to QUEUE.

JSRR R3; Put the address of the instruction following JSRR into R7; ; Jump to the address contained in R3.

<sup>&</sup>lt;sup>†</sup>This is the incremented PC.

LD

#### Assembler Format

LD DR, LABEL

### Encoding



# Operation

```
DR = mem[PC<sup>†</sup> + SEXT(PCoffset9)];
setcc();
```

## Description

An address is computed by sign-extending bits [8:0] to 16 bits and adding this value to the incremented PC. 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.

```
LD R4, VALUE ; R4 \leftarrow mem[VALUE]
```

<sup>&</sup>lt;sup>†</sup>This is the incremented PC.

LDI Load Indirect

#### Assembler Format

LDI DR, LABEL

## Encoding



# Operation

```
DR = mem[mem[PC<sup>†</sup> + SEXT(PCoffset9)]];
setcc();
```

# Description

An address is computed by sign-extending bits [8:0] to 16 bits and adding this value to the incremented PC. What is stored in memory at this 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, ONEMORE ; R4  $\leftarrow$  mem[mem[ONEMORE]]

<sup>&</sup>lt;sup>†</sup>This is the incremented PC.

## Load Base+offset

# **LDR**

#### Assembler Format

LDR DR, BaseR, offset6

#### Encoding



# Operation

```
DR = mem[BaseR + SEXT(offset6)];
setcc();
```

## Description

An address is computed by sign-extending bits [5:0] to 16 bits and adding this value to the contents of the register specified by bits [8:6]. 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.

```
LDR R4, R2, \#-5; R4 \leftarrow mem[R2 - 5]
```

# LEA

## Load Effective Address

#### Assembler Format

LEA DR, LABEL

## Encoding



## Operation

 $DR = PC^{\dagger} + SEXT(PCoffset9);$ 

## Description

An address is computed by sign-extending bits [8:0] to 16 bits and adding this value to the incremented PC. This address is loaded into DR.<sup>‡</sup>

# Example

LEA R4, TARGET ; R4 ← address of TARGET.

<sup>†</sup>This is the incremented PC.

<sup>&</sup>lt;sup>‡</sup>The LEA instruction computes an address but does NOT read memory. Instead, the address itself is loaded into DR.

### Assembler Format

NOT DR, SR

### Encoding



## Operation

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

## Description

The bit-wise complement of the contents of SR is 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.

```
NOT R4, R2 ; R4 \leftarrow NOT(R2)
```

# **RET**

# Return from Subroutine

### Assembler Format

**RET**†

# Encoding



## Operation

PC = R7;

# Description

The PC is loaded with the value in R7. Its normal use is to cause a return from a previous JSR(R) instruction.

## Example

RET ; PC  $\leftarrow$  R7

<sup>&</sup>lt;sup>†</sup>The RET instruction is a specific encoding of the JMP instruction. See also JMP.

Store

### Assembler Format

ST SR, LABEL

## Encoding



# Operation

```
mem[PC^{\dagger} + SEXT(PCoffset9)] = SR;
```

# Description

The contents of the register specified by SR are stored in the memory location whose address is computed by sign-extending bits [8:0] to 16 bits and adding this value to the incremented PC.

ST R4, HERE ; mem[HERE] 
$$\leftarrow$$
 R4

<sup>&</sup>lt;sup>†</sup>This is the incremented PC.

STI Store Indirect

#### Assembler Format

STI SR, LABEL

### Encoding



### Operation

```
mem[mem[PC^{\dagger} + SEXT(PCoffset9)]] = SR;
```

### Description

The contents of the register specified by SR are stored in the memory location whose address is obtained as follows: Bits [8:0] are sign-extended to 16 bits and added to the incremented PC. What is in memory at this address is the address of the location to which the data in SR is stored.

STI R4, NOT\_HERE ; mem[mem[NOT\_HERE]] 
$$\leftarrow$$
 R4

<sup>&</sup>lt;sup>†</sup>This is the incremented PC.

## Store Base+offset

# **STR**

#### Assembler Format

STR SR, BaseR, offset6

## Encoding



# Operation

# Description

The contents of the register specified by SR is stored in the memory location whose address is computed by sign-extending bits [5:0] to 16 bits and adding this value to the contents of the register specified by bits [8:6].

STR R4, R2, #5; mem[R2+5] 
$$\leftarrow$$
 R4