#### Host Interface for Streaming Applications in a Xilinx Virtex-II Pro FPGA

#### Vinay Vaddepalli vinay@ittc.ku.edu



A KTEC Center of Excellence

#### Overview

- Introduction
- Issues
- Design & Architecture
- Resources used
- Verification
- Summary
- Questions



#### Introduction

- Evolution of Main memory
  - Capacity
  - Latency
  - Bandwidth
- Mitigating handshaking overhead
- FERP (Full Empty Register Pipe) is a very small component
- Standard target for RCADE
  - Developed at Clemson University



#### Issues

- On-Chip Peripheral Bus vs Processor Local Bus
  - Bus width
  - Read / Write lines
  - Speed
- Global State Machine vs Local State Machine
  - Rugged
  - Component updates



- Slave on the Processor Local Bus
- Connects to the PLB using the Xilinx PLB IPIF (IP Interface)



Support for variable no. of data streams

- NUM\_DATA\_STREAMS VHDL generic
- Max of eight streams
- Eight data streams
  - Eight input slave registers
  - Eight output slave registers
- One slave register acts as a status register







A KTEC Center of Excellence

- FIFO Stream
  - Instantiated in the *user\_logic.vhd* file using a forgenerate construct



- FIFO Stream
  - Component view





A KTEC Center of Excellence

- FIFO Stream
  - Input FIFO
    - Synchronous 511x32 FIFO
    - 511x36 FIFO is described in Xilinx App 258
    - Uses 512x36 Block RAM
      - Synchronous dual-ported
    - full/empty status lines
    - *fifo\_count* line
    - Burst capable



• FIFO Stream

The University of Kansas

• Input FIFO



- FIFO Stream
  - Input FIFO
    - Write State Machine
      - PLB pulls *slv\_write\_enable* high
      - This signal triggers the State Machine
      - Slave registers contents are presented to the FIFO
      - The State Machine can accept a data element every clock cycle



- FIFO Stream
  - Input FERP
    - Full Empty Register Pipe
    - Developed at Clemson University
    - Local state machine
    - Two element FIFO
    - Simultaneous read and write
    - Width is parameterized



- FIFO Stream
  - Input FERP





A KTEC Center of Excellence

- FIFO Stream
  - Input FERP
    - Write State Machine
      - Check if FIFO is not empty
      - Check if FERP is not full
      - Read data from FIFO
      - Write to the FERP



- FIFO Stream
  - Adder
    - Place holder
    - Interfaces to the FERPs
    - Adds '5' to the input data element
    - Logic that implements the arithmetic
    - State machine to read from a FERP
    - State machine to write to a FERP



- FIFO Stream
  - Adder





- FIFO Stream
  - Output FERP
    - Similar to the input FERP
    - Interfaces the Adder to the FIFO
    - Adder checks if the FERP is not full
    - Adder writes data to the FERP



- FIFO Stream
  - Output FIFO
    - Similar to the input FIFO
    - Write State Machine
      - Check FERP for data
      - Check FIFO for space
      - Reads data from the FERP
      - Writes to the FIFO



- FIFO Stream
  - Output FIFO
    - -Read State Machine
      - -Puts data in the output slave register
      - PLB read request to the slave is the trigger
      - -Burst capable



- FIFO Stream
  - Output FIFO
    - Read Acknowledge
      - PLB after issuing the read request, waits for a read acknowledge
      - FIFO has a read latency of '1' clock cycle
      - PLB read request is delayed by '1' clock cycle to generate the acknowledge



- Host Interface
  - Status Register
    - Slave device
    - User must monitor the FIFOs
    - Input FIFO *fifocount* less than 31
    - Input FIFO *fifocount* greater than 448
    - Output FIFO *fifocount* greater then 448



#### Resources Used

- Host interface
  - Optimization Goal: Speed
  - NUM\_DATA\_STREAMS: 8
  - Number of Slices: 2225 out of 13696
  - Number of BRAMS: 16 out of 136



### Verification

- Host interface
  - Synthesized a design with eight streams
  - Wrote a series of values to each of the streams
  - Read the status register to see if it reflected the streams' fullness
  - Read the individual streams' output registers to see if the arithmetic had taken place



## Summary

- Studied the functionality of FERPs
- Designed a stream by putting together FERPs and FIFOs with the relevant state machine
- Built a parameterized host interface
- Verified functionality with a simple adder slotted into the host interface







A KTEC Center of Excellence