# DMA datasheet

DMA team

# Contents

| 1 | Theory of operation            | 3 |
|---|--------------------------------|---|
| 2 | Hardware programming interface | 4 |
| 3 | Application notes              | 9 |

## 1 Theory of operation

The Direct Memory Access (DMA) engine transfers an internal device memory contents to a 64 bits host memory over PCIe. A memory transfer runs from start to completion without requiring the host CPU assistance, making it available for other computation tasks.

In this device, the DMA is connected to an internal 32KB addressable BRAM memory whose contents are initialized once at main time with an increasing pattern such that:

$$bram[i] = seed + i$$

seed is a user provided value used to randomize the memory contents.

#### 2 Hardware programming interface

The DMA engine PCIe endpoint is mapped at the base address 1, starting at offset 0x0. Only 32 bits aligned accesses are supported.

5 registers (figure 1) are used to interact with the DMA:

- DMA\_REG\_CTL, controls the engine operations,
- DMA\_REG\_STA, informs on the engine status,
- DMA\_REG\_ADx, a pair holding the 64 bits destination address,
- DMA\_REG\_BAZ, user provided seed to fill internal memory.



Figure 1: DMA registers

Registers are described in the following sections.

## 2.1 DMA\_REG\_CTL



Figure 2: DMA control register

| name | description                                                    |
|------|----------------------------------------------------------------|
| S    | set to 1 to start the transfer. self clears.                   |
| I    | set to 1 to enable interrupt at end of transfer. default to 0. |
| N    | size of the transfer, in bytes.                                |

Table 1: DMA\_REG\_CTL RW register fields

## 2.2 DMA\_REG\_STA



Figure 3: DMA status register

|   | name | description                                                                           |
|---|------|---------------------------------------------------------------------------------------|
| ſ | D    | automatically set to 1 when a transfer is done. 0 if a transfer is running.           |
| Ì | N    | size (in bytes) actually transfered. valid only when DMA not running (ie. R cleared). |

Table 2: DMA\_REG\_STA RO register fields

## $2.3 \quad DMA\_REG\_ADx$



Figure 4: DMA destination address register

| ſ | name | description                                               |
|---|------|-----------------------------------------------------------|
| ſ | ADL  | destination address low part (32 least significant bits). |
| Γ | ADH  | destination address high part (32 most significant bits). |

Table 3:  $DMA_REG_ADX RW register fields$ 

## 2.4 DMA\_REG\_BAZ



Figure 5: DMA seed register

| name | description                           |
|------|---------------------------------------|
| S    | the user provided seed. default to 0. |

Table 4:  $DMA_REG_BAZ RW$  register fields

#### 3 Application notes

#### 3.1 Programming procedure

When programming the DMA to perform a memory transfer, a user is expected to follow this procedure:

- 1. the user eventually sets a seed in DMA\_REG\_BAZ[7:0],
- 2. the user sets DMA\_REG\_ADx with the 64 bits destination address,
- 3. the user sets DMA\_REG\_CTL[15:0] with the byte count to transfer,
- 4. the user eventually sets the DMA\_REG\_CTL I bit if an interrupt is required at the end of the transfer,
- 5. the user sets the DMA\_REG\_CTL S bit to start the transfer,
- 6. the DMA set the DMA\_REG\_STA D bit upon transfer completion. An interrupt is generated as indicated by the user,
- 7. the user reads the byte count actually transfered in the DMA\_REG\_STA N field.