# **Raisin64 Documentation**

Release 0.1

**Christopher Parish** 

# **CONTENTS:**

| 1 | Raisi | in64 CPU                             |  |  |  |  |  |
|---|-------|--------------------------------------|--|--|--|--|--|
|   | 1.1   | Overview                             |  |  |  |  |  |
|   | 1.2   | Pipeline Stages                      |  |  |  |  |  |
|   | 1.3   | Caches                               |  |  |  |  |  |
|   | 1.4   | MMU                                  |  |  |  |  |  |
|   | 1.5   | Interrupt Unit                       |  |  |  |  |  |
|   | 1.6   | Debug Unit                           |  |  |  |  |  |
| 2 | Code  | Code Snippets and Software           |  |  |  |  |  |
|   | 2.1   | Handling Interrupts                  |  |  |  |  |  |
|   | 2.2   | Initializing the MMU                 |  |  |  |  |  |
| 3 | Tools | S                                    |  |  |  |  |  |
|   | 3.1   | Assembler                            |  |  |  |  |  |
|   | 3.2   | Debugging                            |  |  |  |  |  |
| 4 | Nexy  | Nexys 4 DDR Reference Implementation |  |  |  |  |  |
|   | 4.1   | SoC Peripherals                      |  |  |  |  |  |
|   | 4.2   | Required Hardware                    |  |  |  |  |  |
|   | 4.3   | Synthesizing the Core                |  |  |  |  |  |

Raisin64 (*RISC Architecture with In-order Superscalar INterlocked-pipeline*) is a pure 64-bit CPU design created as part of an educational project. Architecturally similar to the MIPS R10000 and POWER3, Raisin64 is a superscalar design that employs multiple specialized pipelines for integer operations, floating point, load/store, etc. Unlike most superscalar designs, Raisin64 does not re-order instructions but instead provides a larger architectural register file of 64x64-bit registers.



Major features of the Raisin64 include:

Bits: 64-bitDesign: RISC

• Type: Register-Register

• Branching: Condition Code

• Endianness: Big

• Page Size: 16KB Fixed

• Virtual Address Size: 47-Bits

• Page Table: Three Level

• **Registers:** 61 (R0 = 0)

CONTENTS: 1

2 CONTENTS:

#### CHAPTER

#### **ONE**

# **RAISIN64 CPU**

- 1.1 Overview
- 1.2 Pipeline Stages
- 1.3 Caches
- 1.4 MMU
- 1.5 Interrupt Unit
- 1.6 Debug Unit

| CHAPTER |
|---------|
| TWO     |

# **CODE SNIPPETS AND SOFTWARE**

- 2.1 Handling Interrupts
- 2.2 Initializing the MMU

**CHAPTER** 

## **THREE**

## **TOOLS**

- Assembler
- Debugging
  - Getting OpenOCD

## 3.1 Assembler

# 3.2 Debugging

## 3.2.1 Getting OpenOCD

8 Chapter 3. Tools

**CHAPTER** 

#### **FOUR**

#### **NEXYS 4 DDR REFERENCE IMPLEMENTATION**

- **4.1 SoC Peripherals**
- 4.2 Required Hardware
- 4.3 Synthesizing the Core