# HDL-Lab Introduction



#### Alex Schönberger

Date: 03.08.2015

TU Darmstadt Integrated Electronic Systems Lab Prof. Dr.-Ing. Klaus Hofmann Merckstr. 25, 64283 Darmstadt, Germany

### **Organisational**



Supported time period:

■ 03.08 - 14.08.2015, 9:00 am - 5:30 pm

• Room: S3|06/67

Supervisor: Alex Schönberger,

Alex-Schoenberger@ies.tu-darmstadt.de

• room: S3|06/345b

HiWi: Xiang Ding

#### Goal



 Design, implemention, synthesis and test of a MIPS-I specified processor core on FPGA

Description language: VHDL

Target technology: Virtex5 (Xilinx)

■ Frequency constraint: 50 – 200 MHz

Core constraints:

■ Pipeline stages: 2 – 6

Following subcomponents are mandatory:

ALU, datapath, controlpath

#### **Evaluation**



- Simulative tests
  - ModelSIM for simulation
  - reference signal waves created on a core with 4-staged pipeline (generic memory and FPGA memory)
- Synthesis test
  - Synplify for pre-synthesis (netlist generation)
  - Xilinx ISE for bitfile generation

### Minimum requirements to pass



- Simulative execution of reference program on a core, netlist is synthesized for at least 50 MHz
- Successfully generated bitfile tested with on reference FPGAtestbench
- Report (12 pages)
  - Short introduction (1 page)
  - Design
    - ALU (1 page)
    - datapath (3 pages) block diagram mandatory
    - controlpath (4 pages)
  - Evaluation (1 page)
  - Synthesis (1 page ) timing and resource reports mandatory
  - Conclusion(1 page)



#### **Bonus**



- 1. Full implementation of MIPS-I specification or
- 2. Design is synthesizedable for more than 200 MHz (+0.3 grade improvement)
- 1. and 2. together, tested with openJPEG algorithm and reference FPGA-testbench

#### **Milestones**



- 1 (after 4 days): ALU is implemented and tested
- 2 (after 8 days): The core executes reference programs as expected
- 3 (after 10 days): FPGA-Testbench is synthesized and works without errors.



### **Deadlines**



■ 13.08.2015, 0:00 am: ALU with simulative testbench

■ 14.08.2015, 5:30 pm: designs for grade improvements

■ 24.08.2015, 8:00 am: Final deadline

### **Support**



**3.08** – 14.08.2015

■ 9:00 am - 5:30 pm: Xiang Ding

■ 2 pm – 4 pm: Alex Schönberger

■ 4.08, 13.08-14.08: 11 am: Alex Schönberger

Support list:

 Group number, kind of question (organisational, tool usage, script usage, VHDL syntax, design structure, synthesis reports, FPGA availability ...)

### **Project files**



- complete scr-, test- and report-folders
  - each source file should contain revision history
    - when (03.08.2015), who (Alex Schönberger), did what (created)
  - source files without revision history are going to be excluded from grading process

# **Starting point (I)**



- hdllab
  - doc
    - MIPS I specification
    - ModelSIM User Quide
    - Synplify User Quide
    - Xilinx (ML507) User Quide
  - src
    - vhdl
      - mips\_instruction\_set.vhd, cpu\_pack.vhd
      - cpu.vhd, cpu\_control.vhd, cpu\_datapath.vhd, alu.vhd
    - C
      - counter.c
  - test
    - vhdl
      - tb\_alu.vhd, tb\_cpu.vhd, tb\_hdllab.vhd, hdllab.vhd, uart.vhd, memory.vhd

### **Testbenches**





# Starting point (II)



- sim
  - counter
  - build
  - openJPEG
- syn
  - hdllab
- scripts
  - memory.tcl
- conf
  - alu.conf, cpu\_full.conf, lab.conf

# first steps



```
hdllab/test/scripts/create_env.sh
```

```
module load modelsim
sim cpu lc
sim cpu
```

sim alu lc

#### simulation



- module load modelsim
- sim cpu lc
- sim cpu
- sim <testname> lc
- sim <testname>

- load ModelSIM
- compile sources
- start simulation

- compile sources
- start GUI

- ModelSIM command line

  - open\_counteropens reference signal waves

# netlist synthesis



- module load synplify
- ■syn lab lc
- (optional) syn lab

# bitfile synthesis



- cd hdllab/test/syn/hdllab
- module load xilinx/14.5
- ■ise &