## CS520: APEX CPU Simulator v2.0

Gaurav Kothari <gkothar1@binghamton.edu>

Department of Computer Science State University of New York at Binghamton

November 2, 2020

#### Overview

- A template for a working 5-Stage APEX In-order Pipeline
- Implementation in C language
- You can read, modify and build upon given code-base
- You are also free to write your own implementation from scratch

### Micro-architecture

- ullet Stages: Fetch o Decode o Execute o Memory o Writeback
- All the stages have latency of one clock cycle
- Includes logic for ADD, LOAD, BZ, BNZ and HALT instructions
- On fetching HALT instruction, fetch stage stop fetching new instructions
- When HALT instruction is in commit stage, simulation stops
- Logic to check data dependencies not included

#### **Files**

- Makefile
- $\bullet$  file\_parser.c  $\rightarrow$  Functions to parse input file, add new instructions
- $\bullet$  apex\_cpu.h  $\to$  Data structures declarations, model of CPU, Pipeline stages, code and data memory
- apex\_cpu.c → Implementation of APEX cpu
- apex\_macros.h → Macros used in the implementation
- main.c → Main function which calls APEX CPU interface
- ullet input.asm o Sample input file

# How to compile and run?

- Go to terminal, cd into project directory and type:
  - \$ make
- To run:
  - \$ ./apex\_sim <input\_file\_name>
- Report bugs at: gkothar1@binghamton.edu