

Christian Cherry  
18-224  
Semester Project

# Mini\_NPU Design Schematics



## Testbench Overview

Testbench will act as the accelerometer and generate a series of serial I<sub>2</sub>C data transactions corresponding to physical motions to replicate the data transfer of the ADXL345 Accelerometer. The design will output a 3x4 array corresponding to what motion it thinks it saw, and the TB will take this output and compare it against the actual motion of input to the dut.

# Protocol Handler

## Inputs

clock (TB)  
 $\text{reset\_n}$  (TB)  
 $\text{start}$  (TB)  
 $\text{stop}$  (TB)  
 $\text{abort}$   
 $\text{write\_done}$   
 $\text{data\_ready}$   
 $\text{read\_done}$

## Outputs

$\text{write}$   
 $\text{poll}$   
 $\text{data\_read}$

## Control Signals

$\text{write\_en}$   
 $\text{poll\_en}$   
 $\text{data\_read\_en}$



# I<sup>2</sup>C Master

## Inputs

reset\_n (T8)  
 Clock (T8)  
 Stop (T8)  
 SDA  
 write  
 poll  
 data\_ready

## Status Signals

[1:0] iferat<sup>9^n</sup>  
 [3:0] count  
 [5:0] data\_count

## Outputs

### SCL

wrMe\_done  
 data\_ready  
 read\_done  
 abort  
 data\_avail

[15:0] X\_DATA = {X1\_DATA, X0\_DATA}  
 [15:0] Y\_DATA = {Y1\_DATA, Y0\_DATA}  
 [15:0] Z\_DATA = {Z1\_DATA, Z0\_DATA}

## Local

SDA\_out  
 SDA\_out\_en  
 [7:0] ADDR  
 [7:0] abbr  
 [7:0] sub\_addr  
 [7:0] Sd-W = 0x3A  
 [7:0] Sd-R = 0x3B  
 [7:0] INT\_SOURCE\_addr = 0x80  
 [7:0] DATA\_X0\_addr = 0x32  
 [7:0] FIFO\_CTL\_addr = 0x38  
 [7:0] X0\_DATA  
 [7:0] X1\_DATA  
 [7:0] Y0\_DATA  
 [7:0] Y1\_DATA  
 [7:0] Z0\_DATA  
 [7:0] Z1\_DATA  
 [7:0] FIFO\_DATA = 01100000  
 [7:0] INT\_SOURCE  
 [3:0] count  
 [5:0] data\_count  
 data

## Control Signals

i-up  
 i-clr  
 count\_en  
 count\_reset  
 data\_count\_en  
 data\_count\_reset  
 shift\_n-X0 shift\_n-X1  
 shift\_clr-X0 shift\_clr-X1  
 shift\_n-Y0 shift\_n-Y1  
 shift\_clr-Y0 shift\_clr-Y1  
 shift\_n-Z0 shift\_n-Z1  
 shift\_clr-Z0 shift\_clr-Z1  
 shift\_n-S shift\_clr-S





# Ax3 Numa

## Inputs

reset\_n (TB)  
clock (TB)  
stop (TB)  
abort

[15:0] data  
data\_avail

## Outputs

activated  
activated2

## Status Signals

A1#B  
Aq#B  
Ag#B

## Control Signals

d1\_en  
d2\_en  
d2n\_en  
d1\_clr  
d2n\_clr  
d2\_clr





# Motion Neuron

## Inputs

reset-n  
clock  
activated

## Outputs

fire

## Local Signals

[23:0] cycle  
[6:0] accum  
accum-down

## Control Signals

cycle-en  
cycle-reset  
accum-up  
accum-reset

## Status Signals

fire



Start at 0



Start at 0

Count up to 89



# LED\_Controller

## Inputs

clock (TB)  
reset\_n (TB)

[7:0] fire\_array

## Outputs

[7:0] LEDs

## Status Signals

count\_done

## Control Signals

count\_down  
count\_reset  
led\_en  
led\_reset

