

## ORGANISATION EUROPÉENNE POUR LA RECHERCHE NUCLÉAIRE EUROPEAN ORGANIZATION FOR NUCLEAR RESEARCH

### **CERN BE-CO-HT**

# Technical Specification Gennum GN4124 Core For FMC Projects

July 2010

Edited by:
Simon Deprez

Checked by:

#### Abstract

This technical specification describes the HDL controller for Gennum GN4124 chip. It provides a Wishbone master for control and status registers access and a DMA controller for high speed data transfers.

## **Revision History**

| Version | Date       | Notes             |  |
|---------|------------|-------------------|--|
| 0.1     | 10-06-2010 | Initial release   |  |
| 0.2     | 12-07-2010 | First draft       |  |
| 0.3     | 20-07-2010 | Add byte swapping |  |

## **Contents**

| In | ntroduction                                                               | 3                          |  |  |  |  |  |  |
|----|---------------------------------------------------------------------------|----------------------------|--|--|--|--|--|--|
| 1  | De-multiplexer                                                            |                            |  |  |  |  |  |  |
| 2  |                                                                           |                            |  |  |  |  |  |  |
| 3  |                                                                           |                            |  |  |  |  |  |  |
| 4  | CSR Wishbone master                                                       | 4                          |  |  |  |  |  |  |
| 5  | DMA Engine 5.1 DMA controller                                             | 5<br>5<br>5<br>6           |  |  |  |  |  |  |
| 6  | Arbiter                                                                   |                            |  |  |  |  |  |  |
|    | Interrupt clock bridge                                                    | 7                          |  |  |  |  |  |  |
|    | 1 GN4124 core for PCIe FMC carrier 2 CSR Wishbone master 3 DMA controller | 3<br>4<br>6<br>7<br>8<br>8 |  |  |  |  |  |  |

CERN BE-CO-HT Page 2 of 8

#### Introduction

The GN4124 core is a controller for the GN4124 chip on the PCIe FMC Carrier<sup>1</sup> (PFC) and the Simple PCIe FMC carrier<sup>2</sup> (SPEC). The functional specification<sup>3</sup> describes the interfaces of the core and the configuration registers of the DMA controller.

This specification describes how the core works internally. For each internal block, we give a summary description of its function. Figure 1 show the core with all main blocks.



Figure 1: GN4124 core for PCIe FMC carrier

The structure of this cores and some signals names are based on the Gennum cores Lambo and Lotus.

The VHDL guidelines<sup>4</sup> describes the rules used for writing the HDL code and the signals naming conventions.

## 1 De-multiplexer

This block takes the double data rate 16-bit P2L (PCI Express to Local Bus direction) bus from the GN4124 device and converts it to a single data rate 32-bit bus for use inside the GN4124 core.

## 2 Multiplexer

It takes the internal single data rate 32-bit data and transmits it as double data rate 16-bit data on the L2P (Local Bus to PCI Express direction) bus.

CERN BE-CO-HT Page 3 of 8

<sup>&</sup>lt;sup>1</sup>See http://www.ohwr.org/projects/fmc-pci-carrier.

<sup>&</sup>lt;sup>2</sup>See http://www.ohwr.org/projects/spec.

<sup>&</sup>lt;sup>3</sup>See http://svn.ohwr.org/gn4124-core/trunk/documentation/specifications/func\_spec\_GN4124\_core.pdf.

<sup>&</sup>lt;sup>4</sup>See http://www.ohwr.org/attachments/27/VHDLcoding.pdf.

#### 3 Packet decoder

This block extracts header information, address, data, byte enables, and timing controls of the packets from the GN4124 chip. It provides signals like:

- Type of packet (target read request, target write request, master read completion ...)
- Begin of packet
- Address that will increment with data for data block transfer (e.g. DMA transfers)
- Data
- End of packet

#### 4 CSR Wishbone master

The CSR Wishbone master implements a master for the CSR Wishbone bus. CSR stands for Control and Status Registers. The CSR Wishbone bus is foreseen to access control, status and configuration registers of the cores inside the FPGA. It transforms a PCIe write into a Wishbone write and a PCIe read into a Wishbone read. Only single word reads and writes are supported on the Wishbone interface. Figure 2 shows the block diagram of the CSR Wishbone master.



Figure 2: CSR Wishbone master

The target memory read and target memory write data packets type coming from the decoder are routed to the CSR Wishbone master. The target address, the data (for the write cycles) and the cycle type (read or write) are pushed to a FIFO. This FIFO is synchronizing the data, address and cycle type to the CSR Wishbone clock domain.

Data are coming from the packet decoder. Wishbone signals are generated and the master waits for an

CERN BE-CO-HT Page 4 of 8

acknowledge. Write cycles are queued up at full local bus speed into a small FIFO (16 words deep) so that the write cycles can be played out at the Wishbone bus speed. In order to prevent the FIFO from overflowing due to too many writes coming from the host, the p\_wr\_rdy\_o signal is de-asserted to the GN4124 whenever the FIFO is not empty.

The p\_wr\_rdy\_o signal prevents write requests from the PCI Express bus to the Wishbone configuration interface. The read completions of the P2L DMA transfers are not slowed down.

#### 5 DMA Engine

#### 5.1 DMA controller

| NAME        | OFFSET | MODE | RESET      | DESCRIPTION                               |
|-------------|--------|------|------------|-------------------------------------------|
| DMACTRLR    | 0x00   | R/W  | 0x00000000 | DMA engine control                        |
| DMASTATR    | 0x04   | RO   | 0x00000000 | DMA engine status                         |
| DMACSTARTR  | 0x08   | R/W  | 0x00000000 | DMA start address in the carrier          |
| DMAHSTARTLR | 0x0C   | R/W  | 0x00000000 | DMA start address (low) in the PCIe host  |
| DMAHSTARTHR | 0x10   | R/W  | 0x00000000 | DMA start address (high) in the PCIe host |
| DMALENR     | 0x14   | R/W  | 0x00000000 | DMA read length in bytes                  |
| DMANEXTLR   | 0x18   | R/W  | 0x00000000 | Pointer (low) to next item in list        |
| DMANEXTHR   | 0x1C   | R/W  | 0x00000000 | Pointer (high) to next item in list       |
| DMAATTRIBR  | 0x20   | R/W  | 0x00000000 | DMA chain control                         |

Table 1: Register set for the DMA controller block

The DMA controller is a Wishbone slave controlled from the PCI Express host with the Wishbone master (see the functional specification). Figure 3 shows the internals of the DMA controller.

The transfer starts when the first bit (LSB) of the DMACTRLR (See table 1) register is asserted. One of the two signals, dma\_ctrl\_start\_L2P\_o and dma\_ctrl\_start\_P2L\_o, is set to '1' for one clock cycle. The dma\_ctrl\_start\_L2P\_o signal controls the DMA L2P master that performs transfers from the carrier to the PCI Express host and the dma\_ctrl\_start\_P2L\_o signal controls the DMA P2L master that performs transfers from the PCI Express host to the carrier.

The DMA controller waits for the dma\_ctrl\_done\_i signal from one of the two DMA masters that indicates the end of the transfer. The dma\_ctrl\_error\_i signal indicates the end of the current transfer if an error occurs.

After the end of a transfer, if this transfer is not the last, the controller ask to the P2L DMA master the new item of the DMA chain. The next\_item\_valid\_i signal indicates that the DMA master can read the new DMA chain item from the P2L DMA master and starts the new cycle.

#### 5.2 L2P DMA Master

The L2P DMA master (See figure 5) performs data transfers from the FMC carrier to the memory of the PCI Express host. The transfer is split in blocks of data with a maximal length of 4096 bytes. This is the maximal length of transfers allowed by the GN4124 chip.

The L2P DMA master sends a master read request on the DMA interface and waits for answer. This transfer is clocked by the <code>sys\_clk\_i</code> signal. The received data are stocked in a FIFO that allows switching between clock domains.

CERN BE-CO-HT Page 5 of 8



Figure 3: DMA controller

When the block of data is in the FIFO, the DMA master sends a master write request to the PCI Express host. This operation is clocked by the GN4124 Local Bus Clock. The transfer is paused if the <code>l\_wr\_rdy\_i</code> signal from GN4124 chip is not asserted.

#### 5.3 P2L DMA Master

The P2L DMA master (See figure 6) performs data transfers from the PCI Express host to the FMC carrier. The transfer is split in blocks of data with a maximal length of 4096 bytes.

The P2L DMA master sends a memory read request toward the GN4124 chip and waits for the answer. This operation is clocked by the GN4124 Local Bus Clock. The received data are stocked in a FIFO.

When the block of data is in the FIFO, the DMA master starts a master write cycle on the DMA interface of this block. This transfer is clocked by the sys\_clk\_i signal.

#### 6 Arbiter

Arbitrate between Wishbone master and the two DMA masters. The arbiter is waiting for a request signal from one of this blocks and it grants the bus to the first requester until the end of the packet.

CERN BE-CO-HT Page 6 of 8



Figure 4: DMA controller state machine

The highest priority is for the Wishbone master, then for the P2L DMA master, and the lower priority is for the L2P DMA master.

## 7 Interrupt clock bridge

It transforms input interrupt one-tick-long pulse clocked by  $sys\_clk\_i$  in a one-tick-long pulse clocked by the GN4124 local bus clock.

CERN BE-CO-HT Page 7 of 8



Figure 5: L2P DMA master



Figure 6: P2L DMA master

CERN BE-CO-HT Page 8 of 8