# ELEC6027 - VLSI Design Project : Programmers Guide

Team R4

28<sup>th</sup> April, 2014

# Todo list

| A register window could also be done for this section too          | 58 |
|--------------------------------------------------------------------|----|
| Sim.py needs a fair bit of change. If we have time, this could be  |    |
| altered to use Iains dir structure. This section highlights how to |    |
| use his script and our assembler                                   | 58 |
| Make these more accurate when AJR has finished playing around .    | 61 |

# Contents

| 1 | Introduction                       | 5  |
|---|------------------------------------|----|
| 2 | Architecture                       | 5  |
| 3 | Register Description               | 5  |
| 4 | Instruction Set                    | 7  |
|   | 4.1 General Instruction Formatting | 8  |
|   | 4.2 ADD                            | 10 |
|   | 4.3 ADDI                           | 11 |
|   | 4.4 ADDIB                          | 12 |
|   | 4.5 ADC                            | 13 |
|   | 4.6 ADCI                           | 14 |
|   | 4.7 NEG                            | 15 |
|   | 4.8 SUB                            | 16 |
|   | 4.9 SUBI                           | 17 |
|   | 4.10 SUBIB                         | 18 |
|   | 4.11 SUC                           | 19 |
|   | 4.12 SUCI                          | 20 |
|   | 4.13 CMP                           | 21 |
|   | 4.14 CMPI                          | 22 |
|   | 4.15 AND                           | 23 |
|   | 4.16 OR                            | 24 |
|   | 4.17 XOR                           | 25 |
|   | 4.18 NOT                           | 26 |
|   | 4.19 NAND                          | 27 |
|   | 4.20 NOR                           | 28 |
|   | 4.21 LSL                           | 29 |
|   | 4.22 LSR                           | 30 |
|   | 4.23 ASR                           | 31 |
|   | 4.24 LDW                           | 32 |
|   | 4.25 STW                           | 33 |
|   | 4.26 LUI                           | 34 |
|   | 4.27 LLI                           | 35 |
|   | 4.28 BR                            |    |
|   | 4.20 BNE                           | 37 |

|              | 4.30 | BE                      |
|--------------|------|-------------------------|
|              | 4.31 | BLT 39                  |
|              | 4.32 | BGE                     |
|              | 4.33 | BWL                     |
|              | 4.34 | RET                     |
|              | 4.35 | JMP                     |
|              | 4.36 | PUSH                    |
|              | 4.37 | POP                     |
|              | 4.38 | RETI                    |
|              | 4.39 | ENAI                    |
|              | 4.40 | DISI                    |
|              | 4.41 | STF 49                  |
|              | 4.42 | LDF                     |
| 5            | Prog | gramming Tips 51        |
| 6            | Asse | embler 51               |
| •            | 6.1  | Instruction Formatting  |
|              | 6.2  | Assembler Directives    |
|              | 6.3  | Running The Assembler   |
|              | 6.4  | Error Messages          |
| 7            | Pro  | grams 54                |
|              | 7.1  | Multiply                |
|              | 7.2  | Factorial               |
|              | 7.3  | Random                  |
|              | 7.4  | Interrupt               |
| 8            | Sim  | ulation 58              |
|              | 8.1  | Running the simulations |
| $\mathbf{A}$ | Cod  | e Listings 62           |
|              |      | Multiply                |
|              |      | Factorial               |
|              | A.3  | Random                  |
|              | A.4  | Interrupt               |

## 1 Introduction

Lorem Ipsum...

## 2 Architecture

Lorem Ipsum...

# 3 Register Description

The processor consists of 16bit program counter and 8 general purpose registers of 16 bit each in the register file, 16 bit instruction register along with the Link register and AluOut.

Register File The 8x16 register file has two read ports and one write ports. The read port takes 3-bit address inputs, RS1 and RS2, each specifying one of the 8 GPRs as source operands. They read the 16 bit register values onto read data outputs RD1 and RD2. The write port takes a 3 bit address input Rw, a 16 bit input, WD. The output ports of the register file serve as inputs A and B of the ALU if selected by the two multiplexers. By convention, register R7 is used to store the stack pointer.

Link Register The Link Register is used to store the return address of the caller function. However, it is not a part of the General Purpose register file. For example, in this processor the RET instruction performs unconditional branch to the address which is stored in the link register (LR).

**Program Counter** The Program Counter (PC) is a 16bit register wherein the output of the PC points to the current instruction and the input of the PC shows the address of the next instruction. The branch instructions make use of the PC.

Instruction Register The instruction register of 16 bit is also a storage element that has a single read port. It takes a 16-bit instruction address input and reads the 16-bit data or instruction from that address onto the read data output (Rd).

 $\bf AluOut$   $\,$  It is a 16 bit register, AluOut stores the output of the operations performed in the ALU.

## 4 Instruction Set

The complete instruction set architecture includes a number of instructions for performing calculations on data, memory access, transfer of control within a program and interrupt handling. All instructions implemented by this

architecture fall into one of 6 groups, categorized as follows:

- Data Manipulation Arithmetic, Logical, Shifting
- Byte Immediate Arithmetic, Byte Load
- Data Transfer Memory Access
- Control Transfer (Un)conditional Branching
- Stack Operations Push, Pop
- Interrupts Enabling, Status Storage, Returning

There is only one addressing mode associated with each instruction, generally following these groupings:

- Data Manipulation Register-Register, Register-Immediate
- Byte Immediate Register-Immediate
- Data Transfer Base Plus Offset
- Control Transfer PC Relative, Register-Indirect, Base Plus Offset
- Stack Operations Register-Indirect Preincrement/Postdecrement
- Interrupts Register-Indirect Preincrement/Postdecrement

# 4.1 General Instruction Formatting

| Instruction Type | $\mathbf{Sub}\text{-}\mathbf{Type}$ | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
|------------------|-------------------------------------|---------------------------------------|
|------------------|-------------------------------------|---------------------------------------|

| A1 | Data Manipulation | Register  |   | Or             | oco                                     | ما |   | ]   | Rd   | Ra    |    | Rb  |     | XX | _ |
|----|-------------------|-----------|---|----------------|-----------------------------------------|----|---|-----|------|-------|----|-----|-----|----|---|
| A2 | Data Manipulation | Immediate |   | O <sub>I</sub> | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | ıc |   | ]   | Rd   | Ra    |    | im  | m4  | /5 |   |
| В  | Byte Immediate    |           |   | OI             | coc                                     | de |   | ]   | Rd   |       | in | nm8 | 3   |    |   |
| С  | Data Transfer     |           | 0 | LS             | 0                                       | 0  | 0 | ]   | Rd   | Ra    |    | in  | nm  | 5  |   |
| D1 | Control Transfer  | Others    | 1 | 1              | 1                                       | 1  | 0 | C   | ond. |       | in | nm8 | 3   |    |   |
| D2 | Control Hansler   | Jump      | 1 | 1              | 1                                       | 1  | U |     | ona. | Ra    |    | in  | nm  | 5  |   |
| Е  | Stack Operations  | 0         | U | 0              | 0                                       | 1  | L | X X | Ra   | 0     | 0  | 0   | 0 1 | _  |   |
| F  | Interrupts        |           | 1 | 1              | 0                                       | 0  | 1 | IC  | ond. | 1 1 1 | X  | X   | X   | XX | _ |

#### **Instruction Field Definitions**

Opcode: Operation code as defined for each instruction

Rd: Destination Register

Ra: Source register 1

Rb: Source register 2

immN: Immediate value of length N

Cond.: Branching condition code as defined for branch instructions

ICond.: Interrupt instruction code as defined for interrupt instructions

LS: 0=Load Data, 1=Store Data

U: 1=PUSH, 0=POP

L: 1=Use Link Register, 0=Use GPR

## Pseudocode Notation

| Symbol     | Meaning                                             |
|------------|-----------------------------------------------------|
| <b>←</b>   | Assignment                                          |
| Result[x]  | Bit $x$ of result                                   |
| Ra[x: y]   | Bit range from $x$ to $y$ of register Ra            |
| <          | Numerically less than                               |
| >          | Numerically greater than                            |
| <<         | Logical shift left                                  |
| >>         | Logical shift right                                 |
| >>>        | Arithmetic shift right                              |
| Mem[val]   | Data at memory location with address $val$          |
| $\{x, y\}$ | Contatenation of $x$ and $y$ to form a 16-bit value |
| !          | Bitwise Negation                                    |

Use of the word UNPREDICTABLE indicates that the resultant flag value after operation execution will not be indicative of the ALU result. Instead its value will correspond to the result of an undefined arithmetic operation and as such should not be used.

4.2 ADD Add Word

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|
| 0  | 0  | 0  | 1  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |

#### **Syntax**

ADD Rd, Ra, Rb

eg. ADD R5, R3, R2

## Operation

$$Rd \leftarrow Ra + Rb$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow if (Ra{>}0 \text{ and } Rb{>}0 \text{ and } Result{<}0) \text{ or }$$

(Ra<0 and Rb<0 and Result>0) then 1, else 0

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

## Description

The 16-bit word in GPR[Ra] is added to the 16-bit word in GPR[Rb] and the result is placed into GPR[Rd].

## 4.3 ADDI

# Add Immediate

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|----|---|---|
| 0  | 0  | 1  | 1  | 0  |    | Rd |   |   | Ra |   |   | iı | mm | 5 |   |

### Syntax

ADDI Rd, Ra, #imm5

eg. ADDI R5, R3, #7

## Operation

$$Rd \leftarrow Ra + \#imm5$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

V 
$$\leftarrow$$
 if (Ra>0 and #imm5>0 and Result<0) or

(Ra<0 and #imm5<0 and Result>0) then 1, else 0

$$C \leftarrow \text{if (Result} > 2^{16} - 1) \text{ or}$$

(Result 
$$< -2^{16}$$
) then 1, else 0

## Description

The 16-bit word in GPR[Ra] is added to the sign-extended 5-bit value given in the instruction and the result is placed into GPR[Rd].

## **4.4** ADDIB

# Add Immediate Byte

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|----|----|---|---|---|
| 0  | 0  | 0  | 1  | 1  |    | Rd |   |   |   |   | im | m8 |   |   |   |

## **Syntax**

ADDIB Rd, #imm8

eg. ADDIB R5, #93

## Operation

$$\begin{split} &\mathrm{Rd} \leftarrow \mathrm{Rd} + \#\mathrm{imm8} \\ &\mathrm{N} \leftarrow \mathrm{if} \; (\mathrm{Result} < 0) \; \mathrm{then} \; 1, \; \mathrm{else} \; 0 \\ &\mathrm{Z} \leftarrow \mathrm{if} \; (\mathrm{Result} = 0) \; \mathrm{then} \; 1, \; \mathrm{else} \; 0 \\ &\mathrm{V} \leftarrow \mathrm{if} \; (\mathrm{Rd} {>} 0 \; \mathrm{and} \; \#\mathrm{imm8} {>} 0 \; \mathrm{and} \; \mathrm{Result} {<} 0) \; \mathrm{or} \\ &\qquad (\mathrm{Rd} {<} 0 \; \mathrm{and} \; \#\mathrm{imm8} {<} 0 \; \mathrm{and} \; \mathrm{Result} {>} 0) \; \mathrm{then} \; 1, \; \mathrm{else} \; 0 \\ &\mathrm{C} \leftarrow \mathrm{if} \; (\mathrm{Result} > 2^{16} - 1) \; \mathrm{or} \end{split}$$

(Result  $< -2^{16}$ ) then 1, else 0

## Description

The 16-bit word in GPR[Rd] is added to the sign-extended 8-bit value given in the instruction and the result is placed into GPR[Rd].

 ${\bf Addressing\ Mode:\ Register\text{-}Immediate.}$ 

## 4.5 ADC

## Add Word With Carry

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|
| 0  | 0  | 1  | 0  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |

#### **Syntax**

ADC Rd, Ra, Rb

eg. ADC R5, R3, R2

## Operation

$$\begin{split} \operatorname{Rd} &\leftarrow \operatorname{Ra} + \operatorname{Rb} + \operatorname{C} \\ \operatorname{N} &\leftarrow \operatorname{if} \left( \operatorname{Result} < 0 \right) \text{ then } 1, \operatorname{else } 0 \\ \operatorname{Z} &\leftarrow \operatorname{if} \left( \operatorname{Result} = 0 \right) \text{ then } 1, \operatorname{else } 0 \\ \operatorname{V} &\leftarrow \operatorname{if} \left( \operatorname{Ra} > 0 \text{ and } \left( \operatorname{Rb} + \operatorname{CFlag} \right) > 0 \text{ and } \operatorname{Result} < 0 \right) \operatorname{or} \\ &\qquad \left( \operatorname{Ra} < 0 \text{ and } \left( \operatorname{Rb} + \operatorname{CFlag} \right) < 0 \text{ and } \operatorname{Result} > 0 \right) \operatorname{then } 1, \operatorname{else } 0 \\ \operatorname{C} &\leftarrow \operatorname{if} \left( \operatorname{Result} > 2^{16} - 1 \right) \operatorname{or} \end{split}$$

## Description

The 16-bit word in GPR[Ra] is added to the 16-bit word in GPR[Rb] with the added carry in set according to the Carry flag from previous operation, and the result is placed into GPR[Rd].

(Result  $< -2^{16}$ ) then 1, else 0

## 4.6 ADCI

# Add Immediate With Carry

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|----|---|---|
| 0  | 0  | 1  | 0  | 1  |    | Rd |   |   | Ra |   |   | i | mm | 5 |   |

## **Syntax**

ADCI Rd, Ra, #imm5

eg. ADCI R5, R4, #7

## Operation

$$Rd \leftarrow Ra + \#imm5 + C$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

V 
$$\leftarrow$$
 if (Ra>0 and (#imm5+CFlag)>0 and Result<0) or

(Ra<0 and (#imm5+CFlag)<0 and Result>0) then 1, else 0

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

## Description

The 16-bit word in GPR[Ra] is added to the sign-extended 5-bit value given in the instruction with carry in set according to the Carry flag from previous operation, and the result is placed into GPR[Rd].

4.7 NEG

Negate Word

#### **Format**

|   | 14 |   |   |   |   |    |  |    |   |   |   |   |   |  |
|---|----|---|---|---|---|----|--|----|---|---|---|---|---|--|
| 1 | 1  | 0 | 1 | 0 | - | Rd |  | Ra | X | X | X | X | X |  |

# Syntax

NEG Rd, Ra

eg. NEG R5, R3

## Operation

$$Rd \leftarrow 0 - Ra$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow 0$$

$$\mathbf{C} \leftarrow \mathbf{0}$$

## Description

The 16-bit word in GPR[Ra] is added to the 16-bit word in GPR[Rb] and the result is placed into GPR[Rd].

4.8 SUB Subtract Word

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |  |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|--|
| 0  | 1  | 0  | 1  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |  |

## **Syntax**

SUB Rd, Ra, Rb

eg. SUB R5, R3, R2

## Operation

$$\mathrm{Rd} \leftarrow \mathrm{Ra} - \mathrm{Rb}$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow if (Ra>0 \text{ and } Rb>0 \text{ and } Result<0) \text{ or}$$

(Ra<0 and Rb<0 and Result>0) then 1, else 0

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

## Description

The 16-bit word in GPR[Rb] is subtracted from the 16-bit word in GPR[Ra] and the result is placed into GPR[Rd].

## 4.9 SUBI

## **Subtract Immediate**

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|----|---|---|
| 0  | 1  | 1  | 1  | 0  |    | Rd |   |   | Ra |   |   | iı | mm | 5 |   |

#### **Syntax**

SUBI Rd, Ra, #imm5

eg. SUBI R5, R3, #7

## Operation

$$Rd \leftarrow Ra - \#imm5$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

V 
$$\leftarrow$$
 if (Ra>0 and #imm5>0 and Result<0) or

(Ra<0 and #imm5<0 and Result>0) then 1, else 0

$$C \leftarrow \text{if (Result} > 2^{16} - 1) \text{ or}$$

(Result 
$$< -2^{16}$$
) then 1, else 0

# Description

The sign extended 5-bit value given in the instruction is subtracted from the 16-bit word in GPR[Ra] and the result is placed into GPR[Rd].

## 4.10 **SUBIB**

# Subtract Immediate Byte

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|----|----|---|---|---|
| 0  | 1  | 0  | 1  | 1  |    | Rd |   |   |   |   | im | m8 |   |   |   |

## **Syntax**

SUBIB Rd, #imm8

eg. SUBIB R5, #93

## Operation

$$Rd \leftarrow Rd - \#imm8$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow if (Rd>0 \text{ and } \#imm8>0 \text{ and } Result<0) \text{ or}$$

(Rd<0 and #imm8<0 and Result>0) then 1, else 0

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

#### Description

The 8-bit immediate value given in the instruction is subtracted from the 16-bit word in GPR[Rd] and the result is placed into GPR[Rd].

## 4.11 SUC

# Subtract Word With Carry

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|
| 0  | 1  | 1  | 0  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |

## **Syntax**

SUC Rd, Ra, Rb

eg. SUC R5, R3, R2

## Operation

$$Rd \leftarrow Ra - Rb - C$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow if \ (Ra{>}0 \ and \ (Rb{-}CFlag){>}0 \ and \ Result{<}0)$$
 or

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

# Description

The 16-bit word in GPR[Rb] is subtracted from the 16-bit word in GPR[Rb] with the subtracted carry in set according to the Carry flag from previous operation, and the result is placed into GPR[Rd].

## 4.12 SUCI

# Subtract Immediate With Carry

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|----|---|---|
| 0  | 1  | 1  | 0  | 1  |    | Rd |   |   | Ra |   |   | i | mm | 5 |   |

#### **Syntax**

SUCI Rd, Ra, #imm5

eg. SUCI R5, R4, #7

### Operation

Rd 
$$\leftarrow$$
 Ra - #imm5 - C  
N  $\leftarrow$  if (Result  $<$  0) then 1, else 0  
Z  $\leftarrow$  if (Result  $=$  0) then 1, else 0  
V  $\leftarrow$  if (Ra>0 and (#imm5-CFlag)>0 and Result<0) or  
(Ra<0 and (#imm5-CFlag)<0 and Result>0) then 1, else 0  
C  $\leftarrow$  if (Result  $>$  2<sup>16</sup>  $-$  1) or  
(Result  $<$   $-$  2<sup>16</sup>) then 1, else 0

#### Description

The 5-bit immediate value in instruction is subtracted from the 16-bit word in GPR[Ra] with the subtracted carry in set according to the Carry flag from previous operation, and the result is placed into GPR[Rd].

## 4.13 CMP

# Compare Word

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|----|---|---|----|---|---|---|
| 0  | 0  | 1  | 1  | 1  | X  | X | Χ |   | Ra |   |   | Rb |   | X | X |

#### **Syntax**

CMP Ra, Rb

eg. CMP R3, R2

## Operation

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow if \; (Ra{>}0 \; and \; Rb{>}0 \; and \; Result{<}0) \; or$ 

(Ra<0 and Rb<0 and Result>0) then 1, else 0

 $C \leftarrow if (Result > 2^{16} - 1) or$ 

(Result  $< -2^{16}$ ) then 1, else 0

## Description

The 16-bit word in GPR[Rb] is subtracted from the 16-bit word in GPR[Ra] and the status flags are updated without saving the result.

## 4.14 CMPI

# Compare Immediate

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3  | 2  | 1 | 0 |  |
|----|----|----|----|----|----|---|---|---|----|---|---|----|----|---|---|--|
| 0  | 1  | 1  | 1  | 1  | X  | X | X |   | Ra |   |   | iı | mm | 5 |   |  |

#### **Syntax**

CMPI Ra, #imm5

eg. CMPI R3, #7

## Operation

$$Ra - \#imm5$$

$$N \leftarrow if (Result < 0) then 1, else 0$$

$$Z \leftarrow if (Result = 0) then 1, else 0$$

$$V \leftarrow if (Ra>0 \text{ and } \#imm5>0 \text{ and } Result<0) \text{ or}$$

(Ra<0 and #imm5<0 and Result>0) then 1, else 0

$$C \leftarrow if (Result > 2^{16} - 1) or$$

(Result 
$$< -2^{16}$$
) then 1, else 0

#### Description

The sign extended 5-bit value given in the instruction is subtracted from the 16-bit word in GPR[Ra] and the status flags are updated without saving the result.

4.15 AND

Logical AND

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |  |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|--|
| 1  | 0  | 0  | 0  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |  |

## **Syntax**

AND Rd, Ra, Rb

eg. AND R5, R3, R2

## Operation

 $\mathrm{Rd} \leftarrow \mathrm{Ra} \; \mathtt{AND} \; \mathrm{Rb}$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

## Description

The logical AND of the 16-bit words in GPR[Ra] and GPR[Rb] is performed and the result is placed into GPR[Rd].

4.16 OR Logical OR

#### **Format**

| 15 |   |   |   |   |    |  |    |  |    |   |   |  |
|----|---|---|---|---|----|--|----|--|----|---|---|--|
| 1  | 0 | 0 | 0 | 1 | Rd |  | Ra |  | Rb | X | X |  |

## **Syntax**

OR Rd, Ra, Rb

eg. OR R5, R3, R2

## Operation

 $\mathrm{Rd} \leftarrow \mathrm{Ra} \; \mathtt{OR} \; \mathrm{Rb}$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

## Description

The logical OR of the 16-bit words in GPR[Ra] and GPR[Rb] is performed and the result is placed into GPR[Rd].

4.17 XOR

Logical XOR

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |  |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|--|
| 1  | 0  | 0  | 1  | 1  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |  |

## **Syntax**

XOR Rd, Ra, Rb

eg. XOR R5, R3, R2

## Operation

 $Rd \leftarrow Ra XOR Rb$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

# Description

The logical XOR of the 16-bit words in GPR[Ra] and GPR[Rb] is performed and the result is placed into GPR[Rd].

4.18 NOT

Logical NOT

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|
| 1  | 0  | 0  | 1  | 0  | -  | Rd |   |   | Ra |   | X | X | X | X | X |

## **Syntax**

NOT Rd, Ra

eg. NOT R5, R3

## Operation

 $\mathrm{Rd} \leftarrow \mathtt{NOT} \ \mathrm{Ra}$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

## Description

The logical NOT of the 16-bit word in GPR[Ra] is performed and the result is placed into GPR[Rd].

## 4.19 NAND

# Logical NAND

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|---|---|---|
| 1  | 0  | 1  | 1  | 0  |    | Rd |   |   | Ra |   |   | Rb |   | X | X |

## **Syntax**

NAND Rd, Ra, Rb

eg. NAND R5, R3, R2

## Operation

 $\mathrm{Rd} \leftarrow \mathrm{Ra} \; \mathtt{NAND} \; \mathrm{Rb}$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

# Description

The logical NAND of the 16-bit words in GPR[Ra] and GPR[Rb] is performed and the result is placed into GPR[Rd].

4.20 NOR

Logical NOR

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|----|---|---|----|---|---|---|
| 1  | 0  | 1  | 1  | 1  | Rd |   |   |   | Ra |   |   | Rb |   | X | X |

#### **Syntax**

NOR Rd, Ra, Rb

eg. NOR R5, R3, R2

## Operation

 $Rd \leftarrow Ra \; \mathtt{NOR} \; Rb$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

# Description

The logical NOR of the 16-bit words in GPR[Ra] and GPR[Rb] is performed and the result is placed into GPR[Rd].

## 4.21 LSL

# Logical Shift Left

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2  | 1  | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|----|----|---|
| 1  | 1  | 1  | 1  | 1  |    | Rd |   |   | Ra |   | 0 |   | im | m4 |   |

## **Syntax**

LSL Rd, Ra, #imm4

eg. LSL R5, R3, #7

## Operation

 $Rd \leftarrow Ra << \#imm4$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

## Description

The 16-bit word in GPR[Ra] is shifted left by the 4-bit amount specified in the instruction, shifting in zeros, and the result is placed into GPR[Rd].

## 4.22 LSR

# Logical Shift Right

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2  | 1  | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|----|----|---|
| 1  | 1  | 1  | 0  | 1  |    | Rd |   |   | Ra |   | 0 |   | im | m4 |   |

#### **Syntax**

LSR Rd, Ra, #imm4

eg. LSR R5, R3, #7

## Operation

 $Rd \leftarrow Ra >> \#imm4$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $C \leftarrow UNPREDICTABLE$ 

## Description

The 16-bit word in GPR[Ra] is shifted right by the 4-bit amount specified in the instruction, shifting in zeros, and the result is placed into GPR[Rd].

## 4.23 ASR

# Arithmetic Shift Right

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2  | 1  | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|---|----|----|---|
| 1  | 1  | 1  | 0  | 0  |    | Rd |   |   | Ra |   | 0 |   | im | m4 |   |

#### **Syntax**

ASR Rd, Ra, #imm4

eg. ASR R5, R3, #7

## Operation

 $Rd \leftarrow Ra >>> \#imm4$ 

 $N \leftarrow if (Result < 0) then 1, else 0$ 

 $Z \leftarrow if (Result = 0) then 1, else 0$ 

 $V \leftarrow UNPREDICTABLE$ 

 $\mathbf{C} \leftarrow \mathbf{UNPREDICTABLE}$ 

#### Description

The 16-bit word in GPR[Ra] is shifted right by the 4-bit amount specified in the instruction, shifting in the sign bit of Ra, and the result is placed into GPR[Rd].

4.24 LDW Load Word

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3  | 2  | 1 | 0 |
|----|----|----|----|----|----|----|---|---|----|---|---|----|----|---|---|
| 0  | 0  | 0  | 0  | 0  | -  | Rd |   |   | Ra |   |   | iı | mm | 5 |   |

# Syntax

LDW Rd, [Ra, #imm5]

eg. LDW R5, [R3, #7]

## Operation

 $Rd \leftarrow Mem[Ra + \#imm5]$ 

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

## Description

Data is loaded from memory at the resultant address from addition of GPR[Ra] and the 5-bit immediate value specified in the instruction, and the result is placed into GPR[Rd].

Addressing Mode: Base Plus Offset.

4.25 STW Store Word

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|----|---|---|----|----|---|---|---|
| 0  | 1  | 0  | 0  | 0  | Rd |   |   | Ra |   |   | iı | nm | 5 |   |   |

## **Syntax**

STW Rd, [Ra, #imm5]

eg. STW R5, [R3, #7]

## Operation

 $Mem[Ra + \#imm5] \leftarrow Rd$ 

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

## Description

Data in GPR[Rd] is stored to memory at the resultant address from addition of GPR[Ra] and the 5-bit immediate value specified in the instruction.

Addressing Mode: Base Plus Offset.

## 4.26 LUI

# Load Upper Immediate

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|----|---|---|---|---|----|----|---|---|---|
| 1  | 0  | 1  | 0  | 0  |    | Rd |   |   |   |   | im | m8 |   |   |   |

## **Syntax**

LUI Rd #imm8

eg. LUI R5, #93

## Operation

 $Rd \leftarrow \{\#imm8, \, 0\}$ 

 $\mathbf{N} \leftarrow \mathbf{N}$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

## Description

The 8-bit immediate value provided in the instruction is loaded into the top half in GPR[Rd], setting the bottom half to zero.

## 4.27 LLI

## Load Lower Immediate

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 0  | 1  | 0  | 1  | Rd |   |   |   |   |   | im | m8 |   |   |   |

## **Syntax**

LLI Rd #imm8

eg. LLI R5, #93

## Operation

 $Rd \leftarrow \{Rd[15:8], \#imm8\}$ 

 $\mathbf{N} \leftarrow \mathbf{N}$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

## Description

The 8-bit immediate value provided in the instruction is loaded into the bottom half in GPR[Rd], leaving the top half unchanged.

4.28 BR

**Branch Always** 

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 0 |   |   |   | im | m8 |   |   |   |

## **Syntax**

BR LABEL

eg. BR .loop

## Operation

$$PC \leftarrow PC + \#imm8$$

$$N \leftarrow N$$

$$Z \leftarrow Z$$

$$V \leftarrow V$$

$$\mathbf{C} \leftarrow \mathbf{C}$$

## Description

Unconditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

Addressing Mode: PC Relative.

## 4.29 BNE

# Branch If Not Equal

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 1 | 0 |   |   |   | im | m8 |   |   |   |

### **Syntax**

BNE LABEL

eg. BNE .loop

## Operation

if (z=0) 
$$PC \leftarrow PC + \#imm8$$

$$\mathbf{N} \leftarrow \mathbf{N}$$

$$Z \leftarrow Z$$

$$V \leftarrow V$$

$$C \leftarrow C$$

# Description

Conditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction if zero status flag (Z) equals zero. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

4.30 BE

Branch If Equal

#### **Format**

| 1 | 5 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|---|---|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
|   | 1 | 1  | 1  | 1  | 0  | 1  | 1 | 1 |   |   |   | im | m8 |   |   |   |

### **Syntax**

BE LABEL

eg. BE .loop

## Operation

if (z=1) 
$$PC \leftarrow PC + \#imm8$$

$$N \leftarrow N$$

$$Z \leftarrow Z$$

$$V \leftarrow V$$

$$\mathbf{C} \leftarrow \mathbf{C}$$

### Description

Conditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction if zero status flag (Z) equals one. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

## 4.31 BLT

# Branch If Less Than

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 0 |   |   |   | im | m8 |   |   |   |

## **Syntax**

BLT LABEL

eg. BLT .loop

## Operation

if (n&!v OR !n&v) PC  $\leftarrow$  PC + #imm8

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $C \leftarrow C$ 

# Description

Conditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction if negative status flag and overflow status flag are not equivalent. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

## 4.32 BGE

# Branch If Greater Than Or Equal

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 1  | 0 | 1 |   |   |   | im | m8 |   |   |   |

### **Syntax**

BGE LABEL

eg. BGE .loop

### Operation

if (n&v OR !n&!v) PC  $\leftarrow$  PC + #imm8

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $C \leftarrow C$ 

### Description

Conditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction if negative status flag and overflow status flag are equivalent. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

## 4.33 BWL

## **Branch With Link**

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 1 | 1 |   |   |   | im | m8 |   |   |   |

## **Syntax**

BWL LABEL

eg. BWL .loop

## Operation

$$LR \leftarrow PC + 1$$
;  $PC \leftarrow PC + \#imm8$ 

$$N \leftarrow N$$

$$Z \leftarrow Z$$

$$V \leftarrow V$$

$$C \leftarrow C$$

## Description

Save the current program counter (PC) value plus one to the link register. Then unconditionally branch to the resultant address from addition of PC and the 8-bit immediate value specified in the instruction. LABEL can be both a symbolic name or a numeric value, and is capable of jumping forwards or backwards.

4.34 RET Return

**Format** 

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 1 | 0 |   |   |   | im | m8 |   |   |   |

Syntax

RET

eg. RET

Operation

 $\mathrm{PC} \leftarrow \mathrm{LR}$ 

 $\mathbf{N} \leftarrow \mathbf{N}$ 

 $\mathbf{Z} \leftarrow \mathbf{Z}$ 

 $\mathbf{V} \leftarrow \mathbf{V}$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

Description

Unconditionally branch to the address stored in the link register (LR).

Addressing Mode: Register-Indirect.

4.35 JMP Jump

**Format** 

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|----|----|---|---|---|
| 1  | 1  | 1  | 1  | 0  | 0  | 0 | 1 |   |   |   | im | m8 |   |   |   |

**Syntax** 

JMP Ra, #imm5

eg. JMP R3, #7

Operation

 $PC \leftarrow Ra + \#imm5$ 

 $\mathbf{N} \leftarrow \mathbf{N}$ 

 $\mathbf{Z} \leftarrow \mathbf{Z}$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

Description

Unconditionally jump to the resultant address from the addition of GPR[Ra] and the 5-bit immediate value specified in the instruction.

Addressing Mode: Base Plus Offset.

## 4.36 PUSH

## **Push From Stack**

#### **Format**

|   |   | 13 |   |   |   |   |   |    |   |   |   |   |   |
|---|---|----|---|---|---|---|---|----|---|---|---|---|---|
| 0 | 1 | 0  | 0 | 1 | L | X | X | Ra | 0 | 0 | 0 | 0 | 1 |

## **Syntax**

PUSH Ra PUSH LR eg. PUSH R3

eg. PUSH LR

## Operation

$$Mem[R7] \leftarrow reg; R7 \leftarrow R7 - 1$$

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $C \leftarrow C$ 

# Description

'reg' corresponds to either a GPR or the link register, the contents of which are stored to the stack using the address stored in the stack pointer (R7). Then Decrement the stack pointer by one.

Addressing Modes: Register-Indirect, Postdecrement.

4.37 POP

Pop From Stack

#### **Format**

|   |   |   | 12 |   |   |   |   |    |   |   |   |   |   |
|---|---|---|----|---|---|---|---|----|---|---|---|---|---|
| 0 | 0 | 0 | 0  | 1 | L | X | X | Ra | 0 | 0 | 0 | 0 | 1 |

### **Syntax**

POP Ra POP LR eg. POP R3

eg. POP LR

# Operation

$$R7 \leftarrow R7 + 1; \text{ Mem}[R7] \leftarrow \text{reg};$$

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $C \leftarrow C$ 

# ${\bf Description}$

Increment the stack pointer by one. Then 'reg' corresponds to either a GPR or the link register, the contents of which are retrieved from the stack using the address stored in the stack pointer (R7).

Addressing Modes: Register-Indirect, Preincrement.

## 4.38 RETI

# **Return From Interrupt**

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 1  | 1  | 0  | 0  | 1  | 0  | 0 | 0 | 1 | 1 | 1 | X | X | X | X | X |  |

## **Syntax**

RETI

eg. RETI

## Operation

$$PC \leftarrow Mem[R7]$$

 $N \leftarrow N$ 

 $Z \leftarrow Z$ 

 $V \leftarrow V$ 

 $\mathbf{C} \leftarrow \mathbf{C}$ 

## Description

Restore program counter to its value before interrupt occured, which is stored on the stack, pointed to be the stack pointer (R7). This must be the last instruction in an interrupt service routine.

Addressing Mode: Register-Indirect.

4.39 ENAI

**Enable Interrupts** 

Format

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 1  | 0  | 0 | 1 | 1 | 1 | 1 | X | X | X | X | X |

Syntax

ENAI eg. ENAI

Operation

Set Interrupt Enable Flag

$$\mathbf{N} \leftarrow \mathbf{N}$$

$$\mathbf{Z} \leftarrow \mathbf{Z}$$

$$V \leftarrow V$$

$$\mathbf{C} \leftarrow \mathbf{C}$$

# Description

Turn on interrupts by setting interrupt enable flag to true (1).

# 4.40 **DISI**

# Disable Interrupts

### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 1  | 0  | 1 | 0 | 1 | 1 | 1 | X | X | X | X | X |

## Syntax

DISI

eg. DISI

# Operation

Reset Interrupt Enable Flag

$$\mathbf{N} \leftarrow \mathbf{N}$$

$$\mathbf{Z} \leftarrow \mathbf{Z}$$

$$\mathbf{V} \leftarrow \mathbf{V}$$

$$\mathbf{C} \leftarrow \mathbf{C}$$

# Description

Turn off interrupts by setting interrupt enable flag to false (0).

4.41 STF

Store Status Flags

### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 1  | 0  | 1 | 1 | 1 | 1 | 1 | X | X | X | X | X |

## Syntax

STF

eg. STF

## Operation

$$Mem[R7] \leftarrow \{12\text{-bit }0,\,Z,\,C,\,V,\,N\};\,R7 \leftarrow R7 - 1;$$

$$\mathbf{N} \leftarrow \mathbf{N}$$

$$Z \leftarrow Z$$

$$V \leftarrow V$$

$$\mathbf{C} \leftarrow \mathbf{C}$$

# Description

Store contents of status flags to stack using address held in stack pointer (R7). Then decrement the stack pointer (R7) by one.

Addressing Modes: Register-Indirect, Postdecrement.

# 4.42 LDF

# **Load Status Flags**

#### **Format**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 1  | 1  | 0  | 0  | 1  | 1  | 0 | 0 | 1 | 1 | 1 | X | X | X | X | X |

## **Syntax**

LDF

eg. LDF

## Operation

$$R7 \leftarrow R7 + 1$$

 $N \leftarrow \text{Mem}[R7][0]$ 

 $Z \leftarrow \text{Mem}[R7][3]$ 

 $V \leftarrow \text{Mem}[R7][1]$ 

 $C \leftarrow \text{Mem}[R7][2]$ 

# Description

Increment the stack pointer (R7) by one. Then load content of status flags with lower 4 bits of value retrieved from stack using address held in stack pointer (R7).

Addressing Modes: Register-Indirect, Preincrement.

# 5 Programming Tips

Lorem Ipsum...

# 6 Assembler

The current instruction set architecture includes an assembler for converting assembly language into hexadecimal. This chapter outlines the required formatting and available features of this assembler.

# 6.1 Instruction Formatting

Each instruction must be formatted using the following syntax. Here "[...]" indicates an optional field:

```
[.LABELNAME] MNEMONIC, OPERANDS, ..., : [COMMENTS]
```

For example:

```
.loop ADDI, R5, R3, #5 : Add 5 to R3
```

Comments may be added by preceding them with either: or;

Accepted general purpose register values are: R0, R1, R2, R3, R4, R5, R6, R7, SP. These can be upper or lower case and SP is equivalently evaluated to R7.

Branch instructions take a symbolic reference to the destination. Each type of branch supports moving up to 127 lines forward, or 128 lines backwards. But if a branch is over this limitation, the assembler will automatically create additional instructions to enable greater distances. Each additional branch added will cause two more lines of code to be added to the outputted file.

All label names must begin with a '.' while .ISR/.isr and .define are special cases used for the interrupt service routine and variable definitions respectively.

Instruction-less or comments only lines are allowed within the assembly file.

#### Special Case Label

The .ISR/.isr label is reserved for the interrupt service routine and may be located anywhere within the file but must finish with a 'RETI' instruction. Branches may occur within the ISR, but are not allowed into this service routine with the exception of a return from a separate subroutine.

#### 6.2 Assembler Directives

Symbolic label names are supported for branch-type instructions. Following the previous syntax definition for '.LABELNAME', they can be used instead of numeric branching provided they branch no further than the maximum distance allowed for the instruction used. Definitions are supported by the assembler. They are used to assign meaningful names to the GPRs to aid with programming. Definitions can occur at any point within the file and create a mapping from that point onwards. Different names can be assigned to the same register, but only one is valid at a time.

The accepted syntax for definitions is:

.define NAME REGISTER

# 6.3 Running The Assembler

The assembler is a python executable and is run by typing "./assemble.py". Alternatively, the assembler can be placed in a folder on the users path and executed by running "assemble.py". It supports Python versions 2.4.3 to 2.7.3. A help prompt is given by the script if the usage is not correct, or given a -h or --help argument.

By default, the script will output the assembled hex to a file with the same name, but with a '.hex' extension in the same directory. The user can specify a different file to use by using a -o filename.hex or --output=filename.hex argument to the script. The output file can also be a relative or absolute path to a different directory.

The full usage for the script is seen in listing 1. This includes the basic rules for writing the assembly language and a version log.

Listing 1: Assembler help prompt

1 \$> assemble.py

```
2 Usage: assemble.py [-o outfile] input
     -Team R4 Assembler Help---
        -Version:
   1 (CMPI addition onwards)
   2 (Changed to final ISA, added special case I's and error
     checking
   3 (Ajr changes – Hex output added, bug fix)
   4 (Added SP symbol)
   5 (NOP support added, help added) UNTESTED
   6 (Interrupt support added [ENAI, DISI, RETI])
11
   7 (Checks for duplicate Labels)
   8 (Support for any ISR location & automated startup code entry)
   9 (Support for .define)
14
  10 (Changed usage)
  Current is most recent iteration
17 Commenting uses : or ;
  Labels start with '.': SPECIAL .ISR/.isr-> Interrupt Service
     Routine)
                          SPECIAL . define -> define new name for
19
     General Purpose Register, .define NAME RO-R7/SP
  Instruction Syntax: [LABELNAME] MNEUMONIC, OPERANDS, ..., :[
     COMMENTS]
  Registers: R0, R1, R2, R3, R4, R5, R6, R7=SP
  Branching: Symbolic and Numeric supported
23
  Notes:
   Input files are assumed to end with a .asm extension
25
   Immediate value sizes are checked
   Instruction-less lines allowed
   .ISR may be located anywhere in file
   .define may be located anywhere, definition valid from location
      in file onwards, may replace existing definitions
30
31
  Options:
32
33
    -h, --help
                           show this help message and exit
    -o FILE, --output=FILE
                           output file for the assembled output
```

# 6.4 Error Messages

| Code    | Description                                                                      |  |  |  |  |
|---------|----------------------------------------------------------------------------------|--|--|--|--|
| ERROR1  | Instruction mneumonic is not recognized                                          |  |  |  |  |
| ERROR2  | Register code within instruction is not recognized                               |  |  |  |  |
| ERROR3  | Branch condition code is not recognised                                          |  |  |  |  |
| ERROR4  | ROR4 Attempting to branch to undefined location                                  |  |  |  |  |
| ERROR5  | Instruction mneumonic is not recognized                                          |  |  |  |  |
| ERROR6  | Attempting to shift by more than 16 or perform a negative shift                  |  |  |  |  |
| ERROR7  | Magnitude of immediate value for ADDI, ADCI, SUBI, SUCI, LDW or STW is too large |  |  |  |  |
| ERROR8  | Magnitude of immediate value for CMPI or JMP is too large                        |  |  |  |  |
| ERROR9  | Magnitude of immediate value for ADDIB, SUBIB, LUI or LLI is too large           |  |  |  |  |
| ERROR10 | Attempting to jump more than 127 forward or 128 backwards                        |  |  |  |  |
| ERROR11 | Duplicate symbolic link names                                                    |  |  |  |  |
| ERROR12 | Illegal branch to ISR                                                            |  |  |  |  |
| ERROR13 | Multiple ISRs in file                                                            |  |  |  |  |
| ERROR14 | Invalid formatting for .define directive                                         |  |  |  |  |

# 7 Programs

Every example program in this section uses R7 as a stack pointer which is initialised to the by the program to 0x07D0. The simulation environment contains an area of an area of memory with 2048 locations and memory mapped deices. There are 16 switches at location 0x0800, 16 LEDs at location 0x0801 and a serial io device which can be read from location 0xA000 and has a control register at location 0xA001.

# 7.1 Multiply

The code for the multiply program is held in Appendix A.1 listing 7. A sixteen bit number is read from input switches, split in to lower and upper bytes which are then multiplied. The resulting sixteen bit word is written to the LEDs before reaching a terminating loop. Equation (1) formally describes the algorithm disregarding limitations.

$$A = M \times Q = \sum_{i=0}^{\infty} 2^{i} M_{i} Q \text{ where } M_{i} \in \{0, 1\}$$
 (1)

The subroutine operation is described in listing 2, using C. If the result is greater than or equal to 2<sup>16</sup> the subroutine will fail and return zero. The lowest bit of the multiplier controls the accumulator and the overflow check. The multiplier is shifted right and the quotient is shifted left at every iteration. An unconditional branch is used to keep the algorithm in a while loop. The state of the multiplier is compared at every iteration against zero when the algorithm is finished. As size of the multiplier controls the number of iterations a comparison is made on entry to use the smallest operand.

Listing 2: Multiply Subroutine

```
uint16_t multi(uint16_t op1, op2){
      uint16_t A,M,Q;
      A = 0;
                                      // Make M small, less loops
      if(op1 < op2){
          M = op1; Q = op2;
          M = op2; Q = op1;
      while (1) {
                                      // No loop counter
           if (M & 0x0001) {
                                      // LSb
               A = A + Q;
11
               if(A > 0xFFFF)
                                     // Using carry flag
                                     // Overflow - fail
                    return 0;
13
15
          M = M >> 1;
16
           if (0 == M) 
17
               return A;
                                     // Finished - pass
19
           if (Q & 0x8000) {
20
                                     // Q >= 2^16 - fail
               return 0;
21
```

```
\begin{bmatrix} 23 \\ 24 \\ 25 \end{bmatrix} = Q << 1;
```

#### 7.2 Factorial

The code for the factorial program is held in Appendix A.2 listing 8. It is possible to calculate the factorial of any integer value between 0 and 8 inclusive. The subroutine is called which in turn calls the multiply subroutine discussed in section 7.1. The factorial subroutine does no parameter checking but the multiply code does so if overflow does occur zero is propagated and returned; zero is not a possible factorial. The result is calculated recursively as described using C in listing 3. Large values can cause stack overflow the main body of code makes sure inputs, read from the switches, are sufficiently small.

Listing 3: Recursive Factorial Subroutine

### 7.3 Random

The code for the random program is held in Appendix A.3 listing 9. A random series of numbers is achieved by simulating the 16 bit linear feedback shift register in Figure 1. This produces a new number every 16 sixteen clock cycles so in this case a simulation subroutine is called 16 times. A seed taken from switches and passed to the first subroutine call via the stack is altered and passed to the next subroutine call. No more stack operations are performed. A load from the stack pointer is used write a new random number to LEDs. All contained within an unconditional branch but a loop counter is used control write and reset.

A two input XOR gate is simulated using the XOR operation along with shifting to compare bits in different locations. Bits 2 and 4 are used as inputs so a logical shift left by two is used to align them at the bit 4 position.



Figure 1: 16 Bit Linear Feedback Shift Register.

Masking the output value is used feedback to the top bit. This is described using C in listing 4.

Listing 4: Linear Feedback Shift Register Subroutine

```
uint16_t rand(uint16_t last){
    uint16_t next, test;
    next = last >> 1;
    test = last << 2;
    test = test ^ last;
    if(test & 0x0008){
        return (next | 0x8000);
    }
    return next;
}</pre>
```

# 7.4 Interrupt

The code for the interrupt program is held in Appendix A.4 listing 10. This is the most complex example and makes use of both the multiply and factorial subroutines in sections 7.1 and 7.2 respectively. The interrupt services the serial device by writing data to a 4 byte circular buffer. A main program check to see if data is in the buffer then and if so calculates the factorial writing the result to the LEDs. The buffer is purposefully small to test overflow.

Listing 5: Serial Device Interrupt Service Request

```
5 #define SERIAL 0xA000
  isr(){
       uint16_t data, readPtri, writePtr;
      asm("DISI");
                                      // critical op
9
       data = read (SERIAL);
10
                                      // nested ints
      asm ("ENAI");
       readPtr = read(READ);
12
       writePtr = read(WRITE);
13
       if(((readPtr-1) = writePtr)
14
           (readPtr == BOTTOM)
           (writePtr = (TOP-1))
                                           ) {
16
                                      // full, don't write
           asm("RETI");
17
18
       if(readPtr == BOTTOM)
19
                                      // write to buffer
       write (readPtr, data);
20
       writePtr++;
21
       if(writePtr = TOP){
22
           writePtr = BOTTOM;
23
       }else{
24
           writePtr++;
25
26
       write (WRITE, writePtr);
27
      asm ("RETI")
28
29
30
  void main(){
31
       uint16_t readPtr, writePtri, data;
32
      do{
33
           readPtr = read(READ);
34
           writePtr = read (WRITE);
35
       } while (readPtr == writePtr)
       data = read(readPtr)
37
38
       fact();
39
```

# 8 Simulation

# 8.1 Running the simulations

A register window could also be done for this section too

Sim.py needs a fair bit of change. If we have time, this could be altered to use Iains dir structure. This section highlights how to use his script and our assembler.

Before the simulator is invoked, the assembler should be run. This is discussed in section 6.3. It can be done from within the programs directory ( /design/fcde/verilog/programs) by running, for example, assemble.py multiply

The script "simulate" is an executable shell script. It is run from the terminal in the directory /design/fcde/verilog. This supports running simulations of a full verilog model, cross simulation and a fully extracted simulation. Usage is as follows:

#### ./simulate type program [definitions]

The 'type' can be one of the following: behavioural, mixed, extracted. 'Program' is a relative path to the assembled hex file, usually located in the programs folder. Extra definitions can also be included to set the switch value or serial data input.

The serial data file used is located in the programs directory. This is a hex file with white space separated values of the form "time data". The data is then sent at the time to the processor by the serial module. An example serial data hex file is shown in listing 6.

Listing 6: Example serial data file

Below is a complete list of commands to run all programs on all versions of the processor. 'Number' is a user defined decimal value to set the switches.

• ./assembler/assemble.py programs/multiply.asm ./simulate behavioural programs/multiply.hex +define+switch\_value=number

- ./assembler/assemble.py programs/multiply.asm ./simulate mixed programs/multiply.hex +define+switch\_value=number
- ./assembler/assemble.py programs/multiply.asm ./simulate extracted programs/multiply.hex +define+switch\_value=number
- ./assembler/assemble.py programs/random.asm ./simulate behavioural programs/random.hex +define+switch\_value=number
- ./assembler/assemble.py programs/random.asm ./simulate mixed programs/random.hex +define+switch\_value=number
- ./assembler/assemble.py programs/random.asm ./simulate extracted programs/random.hex +define+switch\_value=number
- ./assembler/assemble.py programs/factorial.asm ./simulate behavioural programs/factorial.hex +define+switch\_value=number
- ./assembler/assemble.py programs/factorial.asm ./simulate mixed programs/factorial.hex +define+switch\_value=number
- ./assembler/assemble.py programs/factorial.asm ./simulate extracted programs/factorial.hex +define+switch\_value=number
- ./assembler/assemble.py programs/interrupt.asm ./simulate behavioural programs/interrupt.hex programs/serial\_data.hex
- ./assembler/assemble.py programs/interrupt.asm ./simulate mixed programs/interrupt.hex programs/serial\_data.hex
- ./assembler/assemble.py programs/interrupt.asm ./simulate extracted programs/interrupt.hex programs/serial\_data.hex

A scan path simulation can also be run. This is done by running ncverilog -sv +gui +ncaccess+r stimulus.sv opcodes.svh cpu.sv for a GUI or ncverilog -sv stimulus.sv opcodes.svh cpu.sv -exit for a command line simulation. This test pulses a signal on the SDI line, and verifies a pulse is seen on the output. The clock cycles, and therefore the number of registers, are counted and reported upon success of the simulation.

Table 1: Clock cycles required for each program to run

Make these more accurate when AJR has finished playing around

| Program   | Clock Cycles |
|-----------|--------------|
| Multiply  | 900          |
| Factorial | 6000         |
| Random    |              |
| Interrupt | 30000        |

The number of clock cycles for each program to fully run is shown in table 1. Factorial run time is given for an input of 8 and is the worst case. Interrupt is dependant on the serial data input and the time is given for the serial data file mentioned above.

A dissembler is also implemented in System Verilog to aid debugging. It is an ASCII formatted array implemented at the top level of the simulation. It is capable of reading the instruction register with in the design, and reconstructing the assembly language of the instruction and is supported in behavioural, mixed and extracted simulations. It will show the opcode, register addresses and immediate values. It is automatically included by the TCL script. The TCL script also opens a waveform window and adds important signals.

# A Code Listings

All code listed in this section is passed to the assembler as is and has been verified using the final design of the processor.

# A.1 Multiply

Listing 7: multiply.asm

```
ADDIB R0,#0
            ADDIB R0,#0
            ADDIB R0, \#0
            ADDIB R0,\#0
           ADDIB R0, \#0
            ADDIB R0, \#0
            ADDIB R0,\#0
12
            ADDIB R0,\#0
13
            ADDIB R0,#0
14
            ADDIB R0,\#0
           ADDIB R0, \#0
16
            ADDIB R0,\#0
17
            ADDIB R0,\#0
18
            LUI
                     SP, #7
                                    ; Init SP
19
                     SP, #208
            LLI
20
           LUI
                     R3, #8
                                    ; SWs addr
21
                     R3, #0
            LLI
22
           LDW
                     R0, [R3, \#0]
                                    ; READ SWs
23
            LUI
                     R1, #0
24
                     R1, #255
                                    ; 0x00FF in R1
            LLI
25
           AND
                     R1, R0, R1
                                    ; Lower byte SWs in R1
26
           LSR
                     R0, R0, #8
                                      Upper byte SWs in R0
27
           PUSH
                     R0
                                      Op1
28
                                      Op2
           PUSH
                     R1
29
           SUB
                     R2, R2, R2
                                      Zero required
30
           PUSH
                     R2
                                      Place holder is zero
           BWL
                     . multi
                                      Run Subroutine
32
           POP
                                      Result
                     R1
33
            ADDIB
                     SP, \#2
                                      Duummy pop
34
                                      Address of LEDS
            ADDIB
                     R3, #1
```

```
; Result on LEDS
            STW
                      R1, [R3, \#0]
36
                                        Finish loop
   . end
            BR
                       . end
37
   . multi
            PUSH
                      R0
38
            PUSH
                      R1
39
            PUSH
                      R2
            PUSH
                      R3
41
            PUSH
                      R4
42
            PUSH
                      R5
43
            PUSH
                      R6
44
            LDW
                      R0, [SP, #8]
                                      ; R0 - Multiplier
45
                      R1, [SP, #9]
                                      ; R1 - Quotient
            LDW
46
                      R0,R1
            CMP
47
            BLT
                       .\,\mathrm{nSw}
                                      ; Branch if M < Q
                      R2,R1,\#0
            ADDI
                                      ; Make M the smallest
49
                      R1, R0, \#0
            ADDI
50
            ADDI
                      R0, R2, \#0
51
  .\,\mathrm{nSw}
            SUB
                      R2, R2, R2
                                      ; R2 - Accumulator
52
            ADDI
                      R3, R2, #1
                                      R3 - 0x0001
53
                      R4, #128
                                      R4 - 0x8000
            LUI
            LLI
                      R4,#0
55
            AND
                      R6, R0, R3
                                      ; R6 - Cmp var
   . mloop
56
            CMPI
                      R6, #1
57
                      . nAcc
            BNE
58
            SUB
                      R3, R3, R3
59
                                      ; A = A + Q
            ADD
                      R2, R2, R1
60
            ADCI
                      R3,R3,\#1
61
            CMPI
                      R3, #2
62
            BE
                       . fail
                                      ; OV
                                      M = M >> 1
                      R0, R0, #1
  . nAcc
            LSR
64
            CMPI
                      R0, \#0
65
            BE
                       . done
66
            AND
                      R5, R4, R1
            CMPI
                      R5, #0
68
            BNE
                       . fail
69
                                      ; Q = Q << 1
            LSL
                      R1\,,R1,\#1
70
            BR
71
                      . mloop
72
   . done
            STW
                      R2, [SP, #7]
                                     ; Res on stack frame
            POP
                      R6
73
            POP
                      R5
74
            POP
                      R4
75
            POP
                      R3
76
                      R2
77
            POP
            POP
                      R1
78
            POP
                      R0
79
            RET
80
```

## A.2 Factorial

Listing 8: factorial.asm

```
ADDIB R0,#0
           ADDIB R0,\#0
           ADDIB R0,#0
           ADDIB R0,#0
           ADDIB R0, \#0
           ADDIB R0,#0
10
           ADDIB R0, \#0
11
           ADDIB R0, \#0
12
           ADDIB R0,\#0
13
           ADDIB R0,\#0
14
           ADDIB R0,#0
15
           ADDIB R0,#0
16
           ADDIB R0,#0
17
           ADDIB R0, \#0
18
                     R7, #7
           LUI
19
                     R7, #208
           LLI
           LUI
                     R0, #8
                                   ; Address in R0
21
                     R0, #0
           LLI
22
           LDW
                     R1, [R0, \#0]
                                   ; Read switches into R1
23
           PUSH
                     R1
                                   ; Pass para
24
                                   ; Run Subroutine
           BWL
                     . fact
25
           POP
                     R3
                                   ; Para overwritten with result
26
           ADDIB
                     R0,#1
27
           STW
                     R3, [R0, \#0]
                                  ; Result on LEDS
28
  . end
           BR
                     . end
                                   ; finish loop
29
  . fact
           PUSH
                     R0
30
           PUSH
                     R1
31
           PUSH
                     LR
32
           LDW
                     R1, [SP, #3]; Get para
33
           ADDIB
                     R1, \#0
34
           BE
                     .retOne
                                       ; 0! = 1
35
           SUBI
                     R0, R1, #1
36
           PUSH
                                   ; Pass para
                     R0
37
```

```
BWL
                        . fact
                                          The output remains on the stack
38
             \displaystyle {\rm PUSH}
                       R1
                                          Pass para
             SUBIB
                       SP, #1
                                          Placeholder
40
             BWL
                        . multi
41
             POP
                                          Get res
                       R1
42
             ADDIB
                       SP, \#2
                                        ; pop x 2
43
             STW
                       R1, [SP, #3]
44
             POP
                       LR
45
             POP
                       R1
46
                       R0
             POP
47
             RET
48
   .retOne ADDIB
                                        ; Avoid jump checking
                       R1, #1
49
             STW
                       R1, [SP, #3]
             POP
                       LR
51
             POP
                       R1
52
             POP
                       R0
53
             RET
54
   . multi
             PUSH
                       R0
55
             PUSH
                       R1
56
             PUSH
                       R2
57
             PUSH
                       R3
58
             PUSH
                       R4
59
                       R5
             PUSH
60
             PUSH
                       R6
61
                                        ; R0 - Multiplier
             LDW
                       R0, [SP, #8]
62
             LDW
                       R1, [SP, #9]
                                        ; R1 - Quotient
63
             CMP
                       R0, R1
64
             BLT
                        .\,\mathrm{nSw}
                                        ; Branch if M < Q
65
                       R2,R1,\#0
                                        ; Make M the smallest
             ADDI
66
             ADDI
                       R1, R0, \#0
67
             ADDI
                       R0, R2, \#0
68
   .\,\mathrm{nSw}
                       R2, R2, R2
                                        ; R2 - Accumulator
             SUB
69
             ADDI
                       R3, R2, #1
                                         R3 - 0x0001
70
             LUI
                                        R4 - 0x8000
                       R4, #128
71
             LLI
                       R4, #0
                       R6, R0, R3
                                        ; R6 - Cmp var
   . mloop
             AND
73
74
             CMPI
                       R6, #1
             BNE
                        .\,\mathrm{nAcc}
75
             SUB
                       R3, R3, R3
76
                                        ; A = A + Q
             ADD
                       R2, R2, R1
77
                       R3, R3, #1
             ADCI
78
79
             CMPI
                       R3, #2
                                       ; OV
             BE
                        . fail
80
   . nAcc
             LSR
                       \mathrm{R0}\,,\mathrm{R0},\#1
                                        M = M >> 1
81
             CMPI
                       R0, #0
82
```

```
BE
                       . done
83
            AND
                       R5, R4, R1
            CMPI
                       ^{\rm R5,\#0}
85
            {\rm BNE}
                       . fail
86
                                      ; Q = Q << 1
            LSL
                       R1, R1, #1
87
            BR
                       . mloop
88
   . done
            STW
                       R2, [SP, #7]; Res on stack frame
89
            POP
                       R6
90
            POP
                       R5
91
            POP
                       R4
92
            POP
                       R3
93
            POP
                       R2
94
            POP
                       R1
95
            POP
                       R0
96
            RET
97
   . fail
            SUB
                       R2, R2, R2
                                      ; OV - ret 0
98
            BR
                       . done
```

## A.3 Random

Listing 9: random.asm

```
ADDIB
                      R0,#0
            R0,#0
2 ADDIB
3 ADDIB
            R0,#0
4 ADDIB
            R0,#0
5 ADDIB
            R0,#0
            R0,#0
6 ADDIB
            R0,#0
7 ADDIB
8 ADDIB
            R0,#0
9 ADDIB
            R0, #0
            R0, #0
10 ADDIB
11 ADDIB
            R0, #0
12 ADDIB
            R0,\#0
            ^{\rm R0,\#0}
13 ADDIB
14 ADDIB
            R0, #0
15 ADDIB
            R0,#0
16 ADDIB
            ^{\rm R0,\#0}
17 ADDIB
            R0,#0
18 ADDIB
            ^{\rm R0,\#0}
            R0,#0
19 ADDIB
            LUI
                      SP, #7
                                     ; Init SP
20
            LLI
                      SP,#208
21
            LUI
                      R0,#8
                                     ; SW Address in R0
22
```

```
R0,#0
            LLI
23
            LDW
                      R1, [R0, \#0]
                                     ; Read switches into R1
            ADDIB
                      R0, #1
                                       Address of LEDS in R0
25
            PUSH
                      R1
  .reset
            SUB
                      R4, R4, R4
                                     ; Reset Loop counter
27
   .loop
            BWL
                      . rand
28
            CMPI
                      R4, #15
29
            BE
                      . write
30
            ADDIB
                      R4, #1
                                     ; INC loop counter
31
            BR
                      .loop
32
  .write
            LDW
                      R1, [SP, #0]
                                     ; No pop as re-run
33
            STW
                      \mathrm{R1}\,,[\,\mathrm{R0}\,,\#\,0\,]
                                     ; Result on LEDS
34
            BR
                      .reset
35
                                     ; LFSR Sim
  .rand
            PUSH
                      R0
36
            PUSH
                      R1
                                     ; Protect regs
37
            PUSH
                      R2
38
            LDW
                      R0, [SP, #3]
                                       Last reg value
39
                                       Shift Bit 4 < -2
                      R1, R0, #2
            LSL
40
            XOR
                      R1, R0, R1
                                       xor Gate
41
            LSR
                      R0, R0, #1
                                     ; Shifted reg
42
                      R2,#0
            LUI
43
            LLI
                      R2,#8
44
            AND
                      R1, R2, R1
                                     ; Mask off Bit 4
45
            CMPI
                      R1,#0
46
            BNE
                      . done
47
            LUI
                      R1, \#128
48
            LLI
                      R1,#0
49
            OR
                      R0, R0, R1
                                     ; or with 0x8000
            STW
                      R0, [SP, #3]
  . done
51
            POP
                      R2
52
            POP
                      R1
53
            POP
                      R0
54
            RET
55
```

# A.4 Interrupt

Listing 10: interrupt.asm

```
ADDIB R0,#0
```

```
ADDIB R0,\#0
           ADDIB R0,\#0
           ADDIB R0,#0
9
           ADDIB R0,\#0
10
           ADDIB R0,#0
11
           ADDIB R0,\#0
12
           ADDIB R0,\#0
13
           ADDIB R0,\#0
14
           ADDIB R0, \#0
15
16
           ADDIB R0,\#0
           ADDIB R0, \#0
17
           ADDIB R0,\#0
18
           DISI
                                   ; Reset is off anyway
19
           LUI
                     R7, #7
20
           LLI
                     R7, #208
21
           LUI
                     R0, #2
                                   ; R0 is read ptr
                                                          0x0200
22
           LLI
                     R0, #0
23
                                   0x0202
           ADDI
                     R1, R0, #2
24
           STW
                     R1, [R0, \#0]
                                   ; Read ptr set to
                                                          0x0202
           STW
                     R1, [R0, #1]
                                   ; Write ptr set to
                                                          0x0202
26
           LUI
                     R0, #160
                                   ; Address of Serial control reg
27
           LLI
                     R0, #1
28
           LUI
                     R1, \#0
29
           LLI
                                   ; Data to enable ints
                     R1, #1
30
                     R1, [R0, \#0]; Store 0x001 @ 0xA001
           STW
31
           ENAI
32
           BR
                     . main
33
  . isr
           STF
                                   ; Keep flags, disable auto
34
                                   ; Save only this for now
           PUSH
                     R0
35
           LUI
                     R0, #160
36
           LLI
                     R0, \#0
37
           LDW
                     R0, [R0, \#0]
                                   ; R1 contains read serial data
           ENAI
                                   ; Don't miss event
39
           PUSH
                     R1
40
           PUSH
                     R2
41
           PUSH
                     R3
42
           PUSH
                     R4
43
           LUI
                     R1,#2
44
           LLI
                     R1,#0
45
           LDW
                     R2, [R1,#0]; R2 contains read ptr
46
           ADDI
                     R3, R1, #1
47
48
           LDW
                     R4, [R3, \#0]
                                  ; R4 contain the write ptr
           SUBIB
                     R2, #1
                                   ; Get out if W = R - 1
49
           CMP
                     R4, R2
50
           BE
                     .isrOut
51
```

```
ADDIB
                     R2, #1
52
            LUI
                     R1,#2
            LLI
                     R1,#2
54
                     R2,R1
           CMP
55
           BNE
                     .write
56
                     R1,#3
            ADDIB
57
           CMP
                     R4,R1
58
           BE
                     .isrOut
59
           STW
                     R0, [R4, \#0]
                                  ; Write to buffer
  .write
60
            ADDIB
                     R4, #1
61
            LUI
                     R1, #2
62
                     R1,#6
            LLI
63
                     R1, R4
           CMP
           BNE
                     .wrapW
65
            SUBIB
                     R4, #4
66
                     R4, [R3, \#0]; Inc write ptr
  . wrapW
           STW
67
  .isrOut POP
                     R4
           POP
                     R3
69
           POP
                     R2
           POP
                     R1
           POP
                     R0
72
           LDF
73
           RETI
74
            LUI
                     R0, #2
                                    ; Read ptr address in R0
  . main
75
                     R0, #0
            LLI
76
                                    ; Read ptr in R2
           LDW
                     R2, [R0, #0]
77
                                    ; Write ptr in R3
           LDW
                     R3, [R0, #1]
78
           CMP
                     R2,R3
           BE
                                    ; Jump back if the same
                     . main
80
                     R3, [R2, \#0]
                                    ; Load data out of buffer
           LDW
81
            ADDIB
                     R2, #1
                                    ; Inc read ptr
82
           SUB
                     R0, R0, R0
            LUI
                     R0,#2
84
            LLI
                     R0,#6
85
                     R0, R0, R2
           SUB
86
           BNE
                     . wrapR
87
            SUBIB
                     R2, #4
88
                                    ; Read ptr address in R0
  . wrapR
           LUI
                     R0, #2
            LLI
                     R0, #0
90
           STW
                     R2, [R0, \#0]
                                   ; Store new read pointer
91
           SUB
                     R4, R4, R4
92
                     R4, #15
            LLI
           AND
                     R3, R4, R3
94
           CMPI
                     R3, #8
95
           BE
                     . do
96
```

```
LLI
                      R4, #7
97
             AND
                      R3, R3, R4
            PUSH
                      R3
   . do
99
            BWL
                       . fact
100
            POP
                      R3
             LUI
                      R4, #8
102
                                      ; Address of LEDs
             LLI
                      R4, #1
103
            STW
                      R3, [R4, \#0]; Put factorial on LEDs
104
            BR
                       .\ main
                                           ; look again
105
            PUSH
                      R0
106
   . fact
            PUSH
                      R1
107
            PUSH
                      LR
108
            LDW
                      R1, [SP, #3]; Get para
109
             ADDIB
                      R1,#0
110
            BE
                                          ; 0! = 1
                       .retOne
111
             SUBI
                      R0, R1, #1
112
                                      ; Pass para
            PUSH
                      R0
113
            BWL
                       . fact
                                      ; The output remains on the stack
114
            PUSH
                                      ; Pass para
115
                      R1
             SUBIB
                      SP,\#1
                                      ; Placeholder
116
            \operatorname{BWL}
                       . multi
117
                                      ; Get res
            POP
                      R1
118
             ADDIB
                      SP, \#2
                                      ; pop x 2
119
            STW
                      R1, [SP, #3]
120
            POP
                      LR
121
            POP
                      R1
            POP
                      R0
123
            RET
124
   .retOne ADDIB
                                      ; Avoid jump checking
                      R1, #1
125
            STW
                      R1, [SP, #3]
126
            POP
                      LR
127
            POP
                      R1
            POP
                      R0
129
            RET
130
   . multi
            PUSH
                      R0
131
             PUSH
                      R1
132
             PUSH
                      R2
            PUSH
                      R3
134
            PUSH
                      R4
135
            PUSH
                      R5
136
            PUSH
                      R6
137
                      R0, [SP, \#8]; R0 - Multiplier
138
            LDW
            LDW
                      R1, [SP, #9]; R1 - Quotient
139
            CMP
                      R0,R1
140
                       .\,\mathrm{nSw}
                                      ; Branch if M < Q
            BLT
141
```

```
ADDI
                        R2, R1, \#0
                                         ; Make M the smallest
142
                        R1, R0, \#0
              ADDI
143
              ADDI
                        R0, R2, \#0
144
                        R2, R2, R2
                                         ; R2 - Accumulator
   .\,\mathrm{nSw}
              SUB
145
                                         ; R3 - 0x0001
              ADDI
                         R3, R2, #1
146
                                         R4 - 0x8000
              LUI
                        R4, #128
147
              LLI
                        R4,\#0
148
                                         ; R6 - Cmp var
   . mloop
              AND
                         R6, R0, R3
149
              CMPI
                        R6, #1
150
              BNE
                         . nAcc
151
              SUB
                        R3, R3, R3
152
                        R2, R2, R1
                                         ; A = A + Q
              ADD
153
              ADCI
                        R3, R3, #1
              CMPI
                         R3,#2
155
                         . fail
              BE
                                         ; OV
156
                                         M = M >> 1
   . nAcc
              LSR
                        R0, R0, #1
157
              CMPI
                        R0,#0
158
              BE
                         . done
159
              \boldsymbol{A}\boldsymbol{N}\!\boldsymbol{D}
                        R5, R4, R1
160
              CMPI
                         R5,\#0
161
              BNE
                         . fail
162
                                         ; Q = Q << 1
              LSL
                        R1, R1, #1
163
              BR
                         . mloop
164
              STW
                        R2, [SP, #7]
                                        ; Res on stack frame
   . done
165
              POP
                        R6
166
              POP
                        R5
167
              POP
                        R4
168
              POP
                        R3
169
                        R2
              POP
170
                        R1
              POP
171
              POP
                        R0
172
              RET
   . fail
              SUB
                         R2, R2, R2
                                         ; OV - ret 0
174
              BR
                         . done
175
```