

# Required Software

Download **NoMachine Enterprise Client** on your laptop



The screenshot shows the NoMachine website's "Enterprise Client Products" section. At the top, there is a header with the NoMachine logo, a "Login" button, and a menu icon. Below the header, there is a section titled "NoMachine Download" with the tagline "You there, everywhere". A navigation breadcrumb shows "Home / Download / Enterprise / Enterprise Client Products". The main content area is titled "Enterprise Client Products" with the sub-instruction "Install just the bare minimum to get access". It features an illustration of a computer monitor displaying a pie chart and a server tower. A red box highlights the "NoMachine Enterprise Client" section, which lists five client versions: "NoMachine Enterprise Client for Windows", "NoMachine Enterprise Client for Mac", "NoMachine Enterprise Client for Linux", "NoMachine Enterprise Client for Raspberry Pi", and "NoMachine Enterprise Client for ARM". A green "Features and support" button is located at the bottom of this section.



# Design Your Own CPU

*Session 2 – The single-cycle CPU*



# Session 1 – Intro to SystemVerilog

## ***Session 2 – The single-cycle CPU***

# Session 3 – Optimisation and bare-metal programming



# About Me

- Part IV Electronic Engineering with Computer Systems
- IP: *A Universal Superscalar Processor Design for MIPS and RISC-V*
- GDP: *Verify a RISC-V Core in 10 Weeks*
- R&D Intern at Codasip (Fabless RISC-V IP firm)



# Reasons for Attending These Workshops

- You're interested in doing a digital design focused IP or GDP
- You want an internship in digital design
- You want to learn or have a refresher on SystemVerilog
- You want to know how digital systems are designed
- For fun



# Setup



# Setup (1)



# Setup (2)





# Setup (3)



# Setup (4)





# Setup (5)

- **If you were here last week:**
  - **Go to the folder we were working in**
  - **git pull**
- *Otherwise*, in your terminal, clone this Git repository:

<https://github.com/bhart17/design-your-own-cpu>

- `git clone https://github.com/bhart17/design-your-own-cpu.git`
- `cd design-your-own-cpu`



# Recap



# Overall: Designing digital systems

- We want to model systems that take in a number of binary inputs
- They compute outputs as a function of these inputs **and** the state of the system using boolean logic
- State is updated on a clock edge



# Levels of Abstraction for a Digital IC

1. Specification
2. Block diagram
3. Hardware description language (such as SystemVerilog)
4. Gate-level circuit (*Generic cells*)
5. Transistor-level circuit (*Specific cells*)
  - 5.1. Transistor circuit diagram
  - 5.2. Stick diagram
  - 5.3. Mask diagram



# Hardware Description Languages

- Aiming to describe the logic between an input and output in a formal but high-level way
- Readable by humans but understandable to computers
- Historically called Register Transfer Layer – describing how data flows between *registers*
- Not programming languages!



# CPUs

# Specific Circuits



# Specific Circuits with Control Signals



# CPUs (1)



# CPUs (2)





# RISC-V

- Open-source *Instruction Set Architecture*
- Defines the set of functions that our CPU needs to perform and how those instructions are encoded
- We have freedom to implement those instructions in whatever architecture we want



# Assembly and Machine Code

- We can write a program in assembly language
- This is just a human readable version of the instruction that the CPU reads – a 1-to-1 mapping
- For example

```
add s1, s2, s3
```

*Add the values in registers s2 and s3 and put the result in s1*



# RV32I Instructions

- Arithmetic Instructions
  - ADD, SUB, AND...
- Load and Store Instructions
  - LW, SW...
- Control Flow Instructions
  - JAL, BEQ...



# Memory Mapped Peripherals

- CPUs need to interact with inputs and outputs
- Integrating specific I/O into every CPU is not trivial
- Solution: access all data via the data memory interface
- Some sections of memory are not ROM or RAM – they are any generic I/O,  
*mapped as a memory address*



# Our Design

# Datapath





# Memory Map

- ROM: 0x00000000 to 0x3FFFFFFF, size 4K
- RAM: 0x40000000 to 0x7FFFFFFF, size 4K
- *Unused: 0x80000000 to 0xBFFFFFFF*
- Virtual Console: 0xC000000 to 0xFFFFFFFF
- All memory devices contain virtual copies to fill their space



# Practical



# 1. Program Counter

- The Program Counter stores the current instruction address
- Fix it so that it correctly updates to the next PC on a clock edge



## 2. Register File

- The Register File stores the 32 general purpose registers
- Implement the reading and writing



## 3. ALU

- The Arithmetic and Logic Unit does all\* of the calculations in our CPU
- An alu\_op input defines what operation the ALU should do
- Implement the correct calculation based on the operation

\* The BCU also does branch related additions



## 4. BCU

- The Branch Control Unit calculates the next PC
- A branch\_op input defines what criteria we have to branch or not branch
- Implement the branch logic based on the operation

## 5. Control

- Implement a couple of the control functions that our datapath uses
- *I've provided most of them*





# Next Week

- Optimise our CPU using pipelining
- Compile C code to create your own Hello World!
- Learn about cutting edge CPU design methods

*Some materials and inspiration in this presentation sourced from Iain McNally's notes  
(<https://www.southampton.ac.uk/~bim/>)*