# Fusion-Core ISA Definition: Revision 0.1

Dylan Wadler

October 18, 2017

## Contents

| 1 | Cha                                          | angelog       |                               |  |
|---|----------------------------------------------|---------------|-------------------------------|--|
| 2 | Intr                                         | oducti        | on                            |  |
|   | 2.1                                          | About         |                               |  |
|   | 2.2                                          | Goals         |                               |  |
|   | 2.3                                          | Conve         | ntions                        |  |
| 3 | Register File Defintions                     |               |                               |  |
|   |                                              |               | al Purpose Registers          |  |
|   |                                              | 3.1.1         | Definition                    |  |
|   |                                              | 3.1.2         | Usage                         |  |
|   | 3.2                                          | Speial        | Registers                     |  |
|   |                                              | 3.2.1         | Control Registers             |  |
|   |                                              | 3.2.2         | Supervisor Registers          |  |
| 4 | Inct                                         | ructio        | 2 Defintions                  |  |
| 4 | Instruction Defintions 4.1 Instruction Types |               |                               |  |
|   | 1.1                                          | 4.1.1         | Integer                       |  |
|   |                                              | 4.1.2         | Immediate                     |  |
|   |                                              | 4.1.3         | LoadStore                     |  |
|   |                                              | 4.1.4         | Branch Jump                   |  |
|   |                                              | 4.1.4 $4.1.5$ | Floating Point                |  |
|   |                                              | 4.1.6         | Atomic                        |  |
|   |                                              | 4.1.7         | System                        |  |
|   |                                              | 4.1.8         | Co-Processor                  |  |
|   |                                              | 4.1.9         | Custom                        |  |
|   | 4.2                                          |               | Instructons                   |  |
|   | 4.2                                          | 4.2.1         |                               |  |
|   |                                              | 4.2.1         | Integer                       |  |
|   |                                              |               |                               |  |
|   |                                              | 4.2.3 $4.2.4$ | LoadStore                     |  |
|   |                                              |               | BranchJump                    |  |
|   |                                              | 4.2.5         | Floating Point                |  |
|   |                                              | 4.2.6         | Atomic                        |  |
|   |                                              | 4.2.7         | System                        |  |
|   |                                              | 4.2.8         | Co-Processor                  |  |
|   |                                              | 4.2.9         | Custom                        |  |
| 5 | Exc                                          | eption        | s and Interrupts              |  |
|   | 5.1                                          | Excep         | tions                         |  |
|   | 5.2                                          | Interr        | ipts                          |  |
|   |                                              | 5.2.1         | User Level                    |  |
|   |                                              | 5.2.2         | Supervisor Level              |  |
| 6 | Mei                                          | mory I        | Лар                           |  |
| - |                                              | -             |                               |  |
| 7 | Pro<br>7.1                                   | _             | ing Conventions er Usage      |  |
|   | $7.1 \\ 7.2$                                 | _             | · ·                           |  |
|   | 1.4                                          | 7.2.1         | ry Locations for Vector Table |  |
|   |                                              | 7.2.1         | Interrupt Vector Table        |  |
|   |                                              | 1.2.2         | Exception Vector Table        |  |

## 1 Changelog

Version 0.1 Initial Definition of the Instruction Set Architecture

#### 2 Introduction

- 2.1 About
- 2.2 Goals
- 2.3 Conventions

### 3 Register File Defintions

- 3.1 General Purpose Registers
- 3.1.1 Definition
- **3.1.2** Usage
- 3.2 Speial Registers
- 3.2.1 Control Registers
- 3.2.2 Supervisor Registers

#### 4 Instruction Defintions

- 4.1 Instruction Types
- 4.1.1 Integer
- 4.1.2 Immediate
- 4.1.3 LoadStore
- 4.1.4 BranchJump
- 4.1.5 Floating Point
- 4.1.6 Atomic
- 4.1.7 System
- 4.1.8 Co-Processor
- 4.1.9 Custom
- 4.2 List of Instructons
- 4.2.1 Integer
- 4.2.2 Immediate
- 4.2.3 LoadStore
- 4.2.4 BranchJump
- 4.2.5 Floating Point
- 4.2.6 Atomic
- 4.2.7 System
- 4.2.8 Co-Processor
- 4.2.9 Custom

### 5 Exceptions and Interrupts

- 5.1 Exceptions
- 5.2 Interrupts
- 5.2.1 User Level

5 2 2 Supervisor Level

## 7 Programming Conventions

- 7.1 Register Usage
- 7.2 Memory Locations for Vector Table
- 7.2.1 Interrupt Vector Table
- 7.2.2 Exception Vector Table