Skip to content
Marco Forconesi edited this page Mar 23, 2015 · 2 revisions

Name

dma | naas_dma

Version

v2.10a

Author

Marco Forconesi (marco.forconesi_at_cl.cam.ac.uk)

Type

pcore (HW)

Location

lib/hw/std/pcores/dma_v2_10_a/

Interface Types

AXI4-Stream

AXI4-Lite

PCIe

Busses

M_AXIS: Master AXI4-Stream (RX) bus, 64bit

S_AXIS: Slave AXI4-Stream (TX) bus, 64bit

M_AXI: Master AXI4-LITE bus, 32bit address, 32 bit data

S_AXI: Slave AXI4-LITE bus, 32 bit address, 32 bit data

Parameters

C_BASEADDR: Base address for the S_AXI interface

C_HIGHADDR: High address for the S_AXI interface

Register map

There are 8 AXI registers (32 bit) implemented for test purposes. One can write any data into them and then read it out later. They do not affect the operation of the DMA in any way. These registers are located at: C_BASEADDR...C_BASEADDR+7

Description

This module is a DMA engine that interconnects the hardware systems running on the FPGA with the software components in the host computer. The DMA engine has two AXI4-Stream interfaces, one of which is a slave interface for sending packets from the card to the host and the other master interface is where packets sent by the host are received and pushed to the FPGA fabric. Packet metadata (e.g. length, source and destination) is encoded in the TUSER signal of the AXI4-Stream bus. The AXI4-Lite master interface exposes the registers of every pcore to the host in order to read and/or write them by using a user level application. A (linux) device driver ref a driver running on the host works orchestrated with the DMA and is in charge of delivering and sending the packets to each interface: nf0, nf1, etc.

The DMA/Driver is a research system part of the Network as a Service (NaaS) project and is currently under development. People interested should refer to the https://github.com/NetFPGA-NewNIC

Clone this wiki locally