Jeremiah Mahler

Introduction

Simulation

Complement

Time

FPGA Error

Buffer Underruns

Questions

### Jeremiah Mahler

California State University Chico

January 17, 2013

#### Introduction

Jeremiah Mahler

#### Introduction

Simulation Architecture

Synthesis

EDGA Error

Buffer

Underruns

- Introduce myself by discussing a past project.
- Enthusiasm for cars and electronics.
- Before any classes on programming or embedded systems.
- Before college.

### Engine Controller

Jeremiah Mahler

#### Introduction

Simulation Architecture

Time

FPGA Error

Buffer Underruns

Questior

- Built a fully functional engine controller from scratch.
- Controlled both fuel and ignition.
- Four cylinder gas engine.
- Motorola 68HC12 processor.
- Developed under Linux.
- Wrote all code in C.
- Designed all circuits to and from the sensors and actuators.

## Engine Controller

Jeremiah Mahler

#### Introduction

Architect

Synthesis

EDCA Error

Buffer

Questio

Plot from test drive.



- map sensor: blue, O2 sensor: red, rpm: green
- Full throttle, through three gears.
- 2005

#### Current Projects

Jeremiah Mahler

#### Introduction

Simulation Architecture

. . . . . .

II GA LIIGI

Underruns

Question

- California State University Chico
  - B.S. Electrical Engineering.
  - Spring 2014.
- McLeod Institute of Simulation Sciences
  - CSU Chico research project.
  - Led by Dr. Crosbie, Dr. Zenor, Dr. Kredo and others.
  - FPGA based real time simulations.
  - Grants from The Office of Naval Research.
  - Electric motor simulations for naval ships and UUV.
  - Work with three other students.

#### Preview

Jeremiah Mahler

#### Introduction

Simulation Architecture

Time

FPGA Error

Buffer Underruns

Question

- Introduction to one of the simulation architectures that were developed at McLeod Institute.
- Problems encountered during its development.
- Along with solutions.

# Background: Simulation Architecture

Jeremiah Mahler

Introduction

Simulation Architecture

Synthe Time

FPGA Erro

Buffer Underrun:

Question



- FPGA
  - Matrix multiplier, core computation engine.
  - Top level connects the matrix multiplier to the PCle bus.
- PC
  - Control program can be a test program or user interface such as Simulink.

### Problem: Synthesis Time

Jeremiah Mahler

Introduction

Architect

Synthesis Time

FPGA Erro

Buffer

Questio



- Synthesis of HDL code with a 20x20 matrix takes two hours.
- HDL Simulation?
  - Simulation of PCle bus?

#### Solution: FIFO Simulation

Jeremiah Mahler

Introduction

Simulation

Synthesis Time

FPGA Error

Buffer Underruns

Questions

- Matrix multiplier and top level change frequently.
- PCle bus code rarely changes.
- Idea: Simulate everything after the FIFO interface.





Frequently changed code can be tested in minutes.

# Problem: Errors Running on FPGA

Jeremiah Mahler

Introduction

. . .

/ II CIII CCC

Time

FPGA Errors

Buffer Underruns

Questions



- Sporadic errors when running on FPGA.
- Is the FIFO Simulation not recreating some scenario?

# Diagnosis: Probe Matrix Multiplication in Hardware

Jeremiah Mahler

Introduction

Simulation

Architecture Synthesis

FPGA Errors

Buffer Underruns

Question

Incorrect results.

$$\begin{bmatrix} 0.025 & 59.50 & 12.0 & 0.0 \\ 1.5 & 32.7 & 12.0 & 0 \\ 0.025 & 89.50 & 12.0 & 0 \\ 0.0 & 23.001 & 0.001 & 1.01 \end{bmatrix} \begin{bmatrix} 0.01 \\ 1.50 \\ 460.0 \\ 60 \end{bmatrix} = \begin{bmatrix} 1929192 \\ 8929282 \\ 8273994 \\ 1234458 \end{bmatrix}$$

• Change test program to use an identity matrix.

$$\begin{bmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1 \end{bmatrix} \begin{bmatrix} 1 \\ 1 \\ 1 \\ 1 \end{bmatrix} = \begin{bmatrix} 1 \\ 1 \\ 7378292 \\ 9288282 \end{bmatrix}$$

Partial transfer of input vector? Buffer underrun?

### Update: Include Underrun in FIFO Simulation

Jeremiah Mahler

Introduction

Simulation

Architectur

FPGA Errors

Buffer Underruns

Question

- First, add underrun condition to FIFO Simulation.
- Should reproduce error from FPGA.
- Previously, the FIFO Simulation produced the ideal case.

ideal case, never empty during transfer



worst case, empty during transfer



• Now the FIFO Simulation produces the worst case.

# Update: FPGA Error Reproduced in FIFO Simulation

Jeremiah Mahler

Introduction

Simulation

Architectur

FPGA Errors

Buffer

Questio

- Re-run FIFO Simulation tests.
- Error in FPGA reproduced in FIFO Simulation.



#### Problem: Buffer Underruns

Jeremiah Mahler

Introduction

Architectur

Time

FPGA Errors

Buffer Underruns

Questions

- Why are buffer underruns breaking the top level?
- Input vector is transferred directly from the FIFO in to the data input.
- Matrix multiplier reads a new value on each clock edge.
- Operation cannot be paused.



### Solution: Accumulate Input Vector

Jeremiah Mahler

Introduction

Architectur

Architectu

11 G/( LIIO

Buffer Underruns

Questions

 Accumulate input vector in top level before transfer to matrix multiplier.



# Success: Architecture Operating Correctly

Jeremiah Mahler

Introduction

Simulation

6 .. .

Time

Buffer

Underruns

Questions



Jeremiah Mahler

Introduction

Architecture

Synti

. . . . . .

FPGA Erro

Buffer Underruns

Onderruns

Questions

Questions?

Jeremiah Mahler

<jmmahler@gmail.com>
github.com/jmahler