![](data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEA3ADcAAD/2wBDAAIBAQEBAQIBAQECAgICAgQDAgICAgUEBAMEBgUGBgYFBgYGBwkIBgcJBwYGCAsICQoKCgoKBggLDAsKDAkKCgr/2wBDAQICAgICAgUDAwUKBwYHCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgr/wAARCAFhAz4DASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwD9/KKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAooooAKKKKACiiigAoorwP9uX/gpj+xt/wTt8F/8ACX/tQfGCx0me4hL6X4dtf9J1TUjyMQWyfOwyMeY22NT95hW2Hw+IxVaNKjByk9kk238kDaW574SB1qtqer6ZotjLqer38NrbwqWluLiZY0RR3LMQAK/nY/bi/wCD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iigAooooAKKKKACggHqKKKADA9KMD0oooAOtGMUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAFFFFABRRRQAUUUUAf/2Q==)

**FDAS DDRIF2 Module Design Specification for Intel Agilex F Implementation**

FDAS\_DDRIF2\_DS Revision 3 Draft C

Classification: UNRESTRICTED

Document type: DTE

Date: 2023-01-25

Status:

© Copyright 2023 SKA Observatory.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFgAAAAfCAYAAABjyArgAAAFOElEQVR42u2ay04bVxzGvY4Uiz0blmFHWqXLFCl5APoAiXiDou4iUQVFpFKkSAhRRe0ioVJ3TcBgc/EN22Ab4xu2SciWR+AR/p3fGc7kzDDgC2aMCUc60njOZY6/+c73v5wJiUg4FArJXb2Wqor6sZnckO30liQycUnvpiSTz8huMSf5g7zsV4pyUCtJuV6W6mFFao2q1Jo1u1rX1UZFKlYbfehbsMYwNmvNwVyJTELNzTNi8aisb6/J2mZEVjdWZCX2SdVP0Y/ycf2/W1NNkB1wk9mE7OylJVfISr60p8Aq1w8UgIetujQ/N6T1pSlHx0fy+atduW59aak2+lQtwBnDWObIFbNqTub2ghzZXHVABuBbCnLIDa7FPBhYqpYUWwENUOdfz8uTp0/kfvj+ua3APdrm/5hXfQ+PDtVLgdGFckGxeWdvxwVyNL4ua1sRG+TYSt9Y/GL2hYyPj59bI/doGwjAyIIJLsDUmlXFysWlRRkdHe1Yd+i7+OeiGouEwOaiA3LakYuNREyi2zbI/WDx0l9L8mD8gbOOyclJmZmZUZVrfZ8+9A0UYHQSWfgGbk0xceqXKRd4IyMjMj09LXNzc5LNZlXlmnu0mX0ZWyjlpd6yQYbJyIWtyXHZSm26peIKLF7+94OEw2H7uVNTcnJyIt7CPdroQ98gQHYAxqChl8gCzPWCC3gAeXp6KpeV5eVlF9CwBZB5Ybw4noHhS+WSEt/ZtqXCh8Xd/hHNXF60WfQ6vGvUawsMYLYvRgnNZWub4E5MTPgy4qLCS2CMyWTmRJN5xjepMFi8ZbF4Y7UnmUBXNXO/Hh+3BZiimXzdmuwAnFfScKAMGpprgtuOtZ2AjCZj+JRUWM/KFmwWKy1O2lqsZaJbgLVB64YE9NWGLxCAFXsthiEN2qCx1RuNhvRaAFnLBXMyNy6cZnF612ax6VH0IhPaoHkLcqFfsFc6KNrwBQIw+li32IsrpheF5l61aL2j4sKxQ7QWZ87cNlMmegUYT8FbvN6NtzAmMICJ0BqWTuLLavaa0oC3gG7x1qkm+N62hYUF1x/RLGZutJiI75xMWC6b8iYMHb5VAGPc2MI6iDC3FAD6+buAGYlEfNvM8XqrMjcRH1JUPHPZUrmU8ibQYe2u3UqJIJ9wdNxyFmSyUBursbExZRwAnGu2v27TngaA6zY/mSCsrrl0OOVy13oB+DIjdxF7Azdy+L7kFfSCANG7SD9N7kSvzR3AM/CJ9yv7fQPYdNM6BThwN22YAe420NDaG2ig0alEYPhw3bgGVFMivG1BScRQhMqXGbnLDFknRk4zxjZyTfWsfho5E2Qz2cNLZx083wx6BpLs0W6aDpFxrbzb/CI3DZD1fW8bBUabblrZcNOS2au7aUORrtSBhhkme/3ZfgYae2eBBqlLHWhcNeFzoxPuxbJ/qNxNfD+oUHkoADaTPR/+ed//ZI+1M5ibZA/P0ilLM/Hea7JnKACmzr6cddKVz54/c4HcTdIH1vumK625X71+9V2eLDs/Zn77VblRzR4S7rTRx0y4P/rpkZIG/Gxe4Pd6dO+68bsFBMEAIJtM7uXICHDr1lzv/n4XyJ+5KMjw9hkowA7IDfvQE03u+tBzSR96VgMD1wue3/UAwPUHWMuFeWwPaO2O7Tm5UMf2fB9hjQ1aFtqlK2+ERJj1hx8fSiQaUS4cfnLD+fCkZXx40lL3zA9P1mIRefzz48D/zA2ThvYA6wpYb96+kXQubXw6dVb5dMq6Rxt9BgHs0DL4rvahWi/23h0Q18fe/wEPGi45ko+NwAAAAABJRU5ErkJggg==)  This work is licensed under a [Creative Commons Attribution 4.0 International License](http://creativecommons.org/licenses/by/4.0/)

|  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- |
| *Role* | *Name* | *Designation* | *Affiliation* | *Signature* | *Date* |
| Author | Martin Droog | FPGA Design Engineer | SKAO |  | 25/01/2023 |
| Owner | Ben Stappers | Head of SKA PSS Team | SKAO |  |  |
| Approver | Ben Stappers | Head of SKA PSS Team | SKAO |  |  |
| Released by | Lina Levin Preston | SKA PSS Team Scrum Master | SKAO |  |  |

|  |  |  |
| --- | --- | --- |
| Document History | | |
| Issue | Date | Comments |
| Issue 2 Draft A | 05/04/2022 | First Issue for review.  Comments from Prabu Thiagaraj and Atul Ghalame, and responses from Martin Droog:-  1)If I am reading it right, the DDR write and read speeds are 300 ms and 130 ms, respectively. I am missing to recall why the read/write speeds are different?  **M. Droog Response: These times were based on initial theoretical analysis and are stating the time that each module/function within FDAS will need to have access to the DDR SDRAMs to complete the task. The numbers are not meant to infer that read and write accesses to DDR SDRAM take a different time to perform. More accurate analysis (with a single DDR SDRAM to store the FOP) shows the CONV module needs to have access to the DDR SDRAM for about 106ms to complete the FOP for a DM and the HSUM module needs to have access to the DDR SDRAM for about 335ms to read all the necessary FOP columns to perform the Harmonic summing of a DM. The nature of the HSUM module operation is that as it performs the harmonic summing across a range of possible pulsar frequencies and accelerations it may read a FOP column on multiple occasions thus accounting for the different CONV write access and HSUM read access times to the DDR SDRAM.**  **To make the DDRIF2 module specification more general the exact times shall be re-worded as a “period of time”.**  2) The read/write priority assigned is the lowest for the CONV. Although a clash may not happen, I am missing to recall why we have kept the lowest priority for CONV.    **M. Droog Response: The architecture is designed such that under normal operation there will be no clash between the CONV and HSUM modules trying to access the FOP DDR SDRAM at the same time. The PC/Computer knows what is happening because it triggers the activity in the FDAS FPGA and knows when activities have finished via the “DONE” signalling. Hence the PC/Computer access to the FOP DDR SDRAM via the PCIe has been given the highest priority just in case for debug purposes it wishes to grab access to the FOP DDR SDRAM midway through the processing of a DM.** |
| Issue 2 Draft B | 28/04/2022 | * The CONV and HSUM processing times have been re-worded as a “period of time” to make the DDRIF2 specification more general. |
| Issue 3 Draft A | 02/09/2022 | 1. Update the design to support up to three DDR Interfaces to be combined to act in unison to provide up to 1536-bit data buses to the CONV and HSUM modules to increase the bandwidth to the external memory storing the Filter Output Plane (FOP). 2. Remove the redundant feature whereby address bits [33:32] are used to select the DDRIF2 instance for PCIe access, since this feature is performed by the PCIe Hard IP Macro. 3. As a tidying exercise change the address busses to the PCIe Hard IP Macro to [31:0] as the upper [63:32] address bits are unused. 4. As a tidying exercise set the Byte Enable bus to the DDR Controller/Calibration block to 64 to cover only the data bytes that DDRIF2 controls. |
| Issue 3 Draft B | 02/09/2022 | Updated DDRIF2 instances to match the DDR Channel number. |
| Issue 3 Draft C | 25/01/2023 | * The Intel Agilex PCIe Hard Macro has a “wait request allowance” hard coded to 16 for the DMA Writes from the Host Computer to the FPGA. Hence the RX\_FIFO size has to be increased to take the data after DDRIF2 asserts Wait\_Request. The RX\_FIFO size has been increased from 16 to 64 locations. In addition the FIFO must have at least 48 spare locations to avoid RD\_DMA\_WAIT\_REQUEST being asserted for WRITE accesses from the PCIe Hard IP Macro, inferring the DDRIF2 module has a WaitRequest Allowance of 48 or WRITE accesses. |

**Table of Contents**

1 Introduction 5

2 Place in the System 6

3 Functional Specification 7

3.1 DDRIF2 Connectivity 7

3.1.1 DDRIF2 <> DDR Controller 9

3.1.2 PCIe Hard IP Macro <> DDRIF2 Interface 9

3.1.3 DDRIF2 > CLD and DDRIF2 > HSUM Interface 12

3.1.4 CONV > DDRIF2 Interface 13

3.2 DDRIF2 Architecture 14

3.2.1 Interface Select: IF\_SEL Sub-Module 15

3.2.2 Receive PCIE Interface: RX\_PCIE\_IF Sub-Module 15

3.2.3 Receive Processing Interface: RX\_PROC\_IF Sub-Module 16

3.2.4 RX\_FIFO , WAG\_IN & RAG\_IN Sub-Modules 17

3.2.5 Transmit PCIE Interface: TX\_PCIE\_IF Sub-Module 18

3.2.6 Transmit Processing Interface: TX\_PROC\_IF Sub-Module 19

3.2.7 DATA\_FIFO\_512, WAG\_OUT , RAG\_OUT\_512 and RAG\_OUT\_3\_512 Sub-Modules 20

4 Design Requirement Tags 21

5 Interface Specification 22

6 MCI Memory Mapped Interface 26

7 Design Parameterisation 27

8 References 28

9 Abbreviations and Acronyms 29

# Introduction

This document captures the requirements for the DDRIF2 module used in the FDAS FPGA implemented in the Intel Agilex F family.

For the first implementation of FDAS in Agilex two instantiations of the DDRIF2 module were required in FDAS. However for the second implementation of FDAS in Agilex four instantiations of the DDRIF2 module shall be required, with three of the instantiations combined to act in unison to provide the CONV and HSUM modules with a 1536-bit data bus to the external DDR4 SDRAM storing the FOP.

The DDRIF2 connection to the PCIE Hard IP Macro module shall support DMA transfers (both read and write) via 512-bit data buses @ 350MHz.

The DDRIF2 connection to the CLD module shall be via 512-bit data buses at 350MHz.

The DDRIF2 connection to the CONV and HSUM modules shall be via 512-bit data buses at 350MHz, with three DDRIF2 instances acting in unison to provide the CONV and HSUM modules with an effective 1536-bit data bus.

It is the responsibility of functions external to the DDRIF2 module to ensure that only one interface (from PCIe, CLD, CONV or HSUM) is requesting access to the DDRIF2 module at any one time. Hence the DDRIF2 module does not need any form of scheduling function to apportion bandwidth.

The DDRIF2 module shall use data FIFOs to adapt between the internal clock rates and the clock rate for the Intel Agilex DDR4 Controller. The internal clock rates shall be 350MHz for the PCIe Clock (CLK\_PCIE) and 350MHz for the System Clock (CLK\_SYS). The clock rate for the Intel Agilex DDR4 Controller (CLK\_DDR) shall be 1333.333MHz/4 = 333.333MHz.

**This version of DDRIF2 supports a WaitRequest Allowance of 48 on the WRITE accesses from the PCIe Hard IP Macro and hence is not compatible with the standard (classic) Avalon interface protocol. Only the RD\_DMA\_WRITE (= 1) signal is used to qualify existence of a new WRITE access. The WaitRequest Allowance feature allows for greater bandwidth as the data sender (i.e. Host) can continue transmitting for a specified time after the slave (i.e. Agent) as asserted its WaitRequest.**

**This version of DDRIF2 supports a WaitRequest Allowance of 0 on the READ accesses by PCIe Hard IP Macro, i.e. it follows the standard (classic) Avalon interface protocol. The WR\_DMA\_READ (= 1) and WR\_DMA\_WAIT\_REQUEST (= 0) signals are used to qualify existence of a new READ access.**

# Place in the System

The DDRIF2 Module’s place in the system is shown highlighted in the figure below:-

**DDRIF2 #2**

**DDRIF2 #2**

PCIe

**CLD**

**CTRL**

FDAS Control

CLD\_DONE

**CONV**

data[63:0]

ready

**HSUM**

**FDAS**

CONV\_DONE CONV\_FFT\_REDAY

valid

**PCIE HARD IP MACRO (INTEL IP)**

**MCI\_TOP**

CLD\_DM\_TRIGGER

CLD\_ENABLE

CLD\_PAGE[31:0]

CONV\_DM\_TRIGGER

CONV\_ENABLE

CONV\_PAGE[31:0]

IFFT\_LOOP\_NUM[5:0]

HSUM\_DM\_TRIGGER

HSUM\_ENABLE

HSUM\_PAGE[31:0]

HSUM\_DONE

**PCIF**

ADDR

DATA[511:0]

**DDRIF2 #1**

**DDRIF2 #0, #2 and #3 acting in unison to provide a 1536-bit data interface to CONV and HSUM**

ADDR

3xDATA[5111:0]

3xDATA[511:0]

ADDR

ADDR

DATA[511:0]

*Note: The PCIe Hard Macro can read and write to allExternal DDR memories for diagnostic purposes. Not shown in this figure for clarity.*

*Note CLD, CONV and HSUM are designed with paging of the DDR memory for a future implementation. This allows different regions of the DDR SDRAM memory to be used to store data if desired.*

**FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS (INTEL IP)**

**provides the DDR Controllers for DDRIF2#0 and DDRIF#1**

**FDAS\_DDR\_CONTROLLER\_CALIBRATION (INTEL IP)**

**provides the DDR Controllers for DDRIF2#2 and DDRIF#3**

DMA Transfer

**External 4 Gibi-Byte**

**DDR4 SDRAM Memory #1**

**External 4 Gibi-Byte**

**DDR4 SDRAM Memory #0. #2 and #3**

MC

Interface

Via

PCIe

*Note: In this implementation CLD\_PAGE, CONV\_PAGE and HSUM\_PAGE are fixed (static) in this implementation. However with a future implementation with more DDR Interfaces to CONV/HSUM a Paging technique shall enable increased processing performance.*

MC Bus

OVERLAP\_SIZE[9:0]

FOP\_SAMPLE\_NUM[22:0]

**MSIX**

MSI-X

Figure ‑ – DDRIF2 Module Location in FDAS

# Functional Specification

## DDRIF2 Connectivity

The figure below shows the connectivity of the DDRIF2 modules the FDAS design.

PCIE

Hard IP

Macro

CLD

Module

CONV

Module

HSUM

Module

DDRIF2 #1 Module containing clock boundary FIFOs

DDR 4 SDRAM#1

**FDAS**

512-bit @ 350MHz access from PCIe to each DDRIF2

512-bit @ 350MHz

1536-bit @ 350MHz

1536-bit @ 350MHz

64-bit @ 1333MHz

C

A

L

DDR\_

CONT

HPS

Ch 1

FDAS\_DDR\_

CONTROLLER\_HPS

CALIBRATION

(INTEL IP) #1

DDR\_

CONT

Ch 0

DDRIF2 #0 Module containing clock boundary FIFOs

DDR 4 SDRAM#0

64-bit @ 1333MHz

DDRIF2 #2 Module containing clock boundary FIFOs

DDR 4 SDRAM#2

64-bit @ 1333MHz

C

A

L

DDR\_

CONT

Ch 2

FDAS\_DDR\_

CONTROLLER\_

CALIBRATION

(INTEL IP) #1

DDR\_

CONT

Ch 3

DDRIF2 #3 Module containing clock boundary FIFOs

DDR 4 SDRAM#3

64-bit @ 1333MHz

“FIFO\_READY”, “FIFO\_FULL” and “DATA\_AVAIL” signals transferred between DDRIF2 modules for CONV/ HSUM data paths

512 bits to/from each DDRIF2

Figure ‑ : DDRIF2 Connectivity in FDAS

System design external to the DDRIF2 module shall ensure that only one FDAS traffic module attempts to accesses a DDRIF2 module at any one time. Hence the DDRIF2 module does not need any internal scheduling or calendar.

The intended operational sequence of FDAS shall be as follows:-

* For a period of time the PCIe Hard Macro shall write to External DDR SDRAM memory via DDRIF2 #1 simultaneously whilst the HSUM module reads from External DDR SDRAM memory via DDRIF2 #0, #2 and #3.
* For a period of time the CLD module shall read from External DDR SDRAM memory via DDRIF2 #1 simultaneously whilst the CONV module writes to External DDR SDRAM memory via DDRIF2 #0, #2 and #3.

As a diagnostic facility the PCIe Hard IP Macro shall be able to read from or write to either any SDRAM via its associated DDRIF2 module.

However as a precaution the DDRIF2 modules shall prioritise any access requests as follows:-

DRRIF2 #1

|  |  |
| --- | --- |
| Access Request | Priority |
| PCIe Hard Macro Read from External DDR SDRAM memory | 1 - Highest |
| PCIe Hard Macro Write to External DDR SDRAM memory | 2 |
| CLD Read from External DDR SDRAM memory | 3 - Lowest |

Table ‑ : DDRIF2 #1 Access Request Priority

DRRIF2 #0, #2 and #3

|  |  |
| --- | --- |
| Access Request | Priority |
| PCIe Hard Macro Read from External DDR SDRAM memory | 1 - Highest |
| PCIe Hard Macro Write to External DDR SDRAM memory | 2 |
| HSUM Read from External DDR SDRAM memory | 3 |
| CONV Write to External DDR SDRAM memory | 4 - Lowest |

Table ‑: DDRIF2 #0, #2 and #3 Access Request Priority

### DDRIF2 <> DDR Controller

The DDRIF2 module shall provide an interface to the Intel Agilex DDR Controller [Ref: Agilex DDR User Guide] via a 512-bit data bus.

The Intel Agilex DDR Controller shall connect to the external DDR4 SDRAM.

It is expected that the SDRAM devices will be identical, each with 4 Gibi-byte of storage. Each address location of the SDRAM device shall store 64-bits of data (i.e. 8 Bytes).

### PCIe Hard IP Macro <> DDRIF2 Interface

The PCIe Hard IP Macro shall present separate read and write interfaces to the DDRIF2 modules with 512-bit data buses @ 350MHz. The PCIe Hard IP Macro shall perform DMA transfers to and from the DDRIF2 module.

#### PCIe Hard IP Macro Write to External DDR SDRAM memory

PC/Computer > External DDR SDRAM memory DMA transfer requests shall be indicated by assertion of the RD\_DMA\_WRITE signal by the PC/Computer via the PCIe Hard IP Macro.

The PCIe Hard IP Macro shall present a 512-bit data bus @ 350MHz “RD\_DMA\_WRITE\_DATA[511:0]” to the DDRIF2 module, with a 32-bit address bus “RD\_DMA\_ADDRESS[31:0]”. Each value of the address bus corresponds to a byte offset, however with a 512-bit (i.e. 64-byte) bus the only legal values for the 32-bit address are:-

0x0000,0000

0x0000,0040

0x0000,0080

etc

The 64-bit byte based address (RD\_DMA\_ADDRESS[31:0]) to the DDRIF2 module should be populated as:-

|  |  |
| --- | --- |
| PCIe Interface Address to DDRIF2 module | |
| bit 31 bit 6 | bit 5 bit 0 |
| 64 byte Word Address from  PCIe Hard IP Macro  i.e. [25:0] | All zeros |

Table ‑: Addressing of DDRIF2 with Address from the PCIe Hard IP Macro

To target a particular byte within the 512-bit data bus the RD\_DMA\_BYTE\_EN[63:0] signal shall be used:-

|  |  |  |
| --- | --- | --- |
| RD\_DMA\_BYTE\_EN[63:0]  / Hex | Valid RD\_DMA\_WRITE\_DATA[255:0]  bits | Comment |
| 0x0000\_0000\_0000\_0001 | [7:0] | Byte #1 valid |
| 0x0000\_0000\_0000\_0002 | [15:8] | Byte #2 valid |
| 0x0000\_0000\_0000\_0004 | [23:16] | Byte #3 valid |
| 0x0000\_0000\_0000\_0008 | [31:24] | Byte #4 valid |
| : | : |  |
| 0x4000\_0000\_0000\_0000 | [503:496] | Byte #63 valid |
| 0x8000\_0000\_0000\_0000 | [511:504] | Byte #64 valid |
| : | : |  |
| : | : |  |
| 0xFFFF\_FFFF\_FFFF\_FFFF | [511:0] | All Bytes valid |

Table ‑ : RD\_DMA\_BYTE\_EN Description

**However it shall be a requirement of the software running on the PC/Computer to ensure that RD\_DMA\_BYTE\_EN[63:0] is set to 0xFFFF\_FFFF\_FFFF\_FFFF to indicate that all bytes in the 512-bit word are valid.**

If the DDRIF2 module is unable to respond to the DMA request it shall assert the RD\_DMA\_WAIT\_REQUEST signal. This shall cause the PCIe Hard IP Macro to pause its operation and until RD\_DMA\_WAIT\_REQUEST is de-asserted.

**However it should be noted that PCIe Hard IP Macro may still send a further 16 write accesses after RD\_DMA\_WAIT\_REQUEST has been asserted, due to the fact it has a “wait request allowance” value hard coded to16.**

The size of the burst transfer of data from the PC/Computer to the DDRIF2 module in terms of the number of 512-bit words shall be indicated by the RD\_DMA\_BURST\_COUNT[3:0] signal.

#### PCIe Hard IP Macro Read from External DDR SDRAM memory

External DDR SDRAM memory > PC/Computer DMA transfer requests shall be indicated by assertion of the WR\_DMA\_READ signal by the PC/Computer via the PCIe Hard IP Macro.

The DDRIF2 module shall present a 512-bit data bus “WR\_DMA\_READ\_DATA[511:0]” @ 350MHz to the PCIe Hard IP Macro, along with a WR\_DMA\_READ\_DATA\_VALID signal which shall be asserted when the data is valid.

The PCIe Hard IP Macro shall present a 32-bit address bus “WR\_DMA\_ADDRESS[31:0]” to the DDRIF2 module. Each value of the address bus corresponds to a byte offset, however with a 512-bit (i.e. 64-byte) bus the only legal values for the 32-bit address are:-

0x0000,0000

0x0000,0040

0x0000,0080

etc

The population of the WR\_DMA\_ADDRESS[31:0] shall follow the same method as described in section 3.1.2.1 Table 3‑3.

If the DDRIF2 module is unable to respond to the DMA request it shall assert the WR\_DMA\_WAIT\_REQUEST signal. This shall cause the PCIe Hard IP Macro to pause its operation and until WR\_DMA\_WAIT\_REQUEST is de-asserted.

The size of the burst transfer of data from the DDRIF2 module to the PC/Computer in terms of the number of 512-bit words shall be indicated by the WR\_DMA\_BURST\_COUNT[3:0] signal.

### DDRIF2 > CLD and DDRIF2 > HSUM Interface

This interface shall support the reading of data from external DDR SDRAM memory to the CLD module (via DDRIF2 #1) or HSUM module (via DDRIF2 #0, #2 and #3) via a 512-bit data bus DDR\_RD\_DATA[511:0] from each DDRIF2 instance.

The traffic module (CLD/HSUM) shall assert a “DDR\_RD\_EN” signal when a read is required, along with an address signal DDR\_RD\_ADDR[31:0]. Each value of the address bus corresponds to a byte offset, however with a 512-bit (i.e. 64-byte) data bus the only legal values for the 32-bit address are:-

0x0000,0000

0x0000,0040

0x0000,0080

etc

The DDRIF2 module shall indicate when it is able to accept the address by controlling the DDR\_RD\_WAIT\_REQUEST signal to the CLD/HSUM module. In the case of DDRIF2 #0, #2 and #3 “FIFO\_READY” and “FIFO\_FULL” signals passed between the DDRIF2 module instances ensure that the DDR\_RD\_WAIT\_REQUEST is only de-asserted when all three DDRIF2 module instances have space to store the address.

When the DDRIF2 module supplies valid data to the CLD/HSUM module it shall assert the DDR\_RD\_DATA\_VALID signal.

In the case of DDRIF2 #0, #2 and #3 “DATA\_AVAIL” signals passed between the DDRIF2 module instances ensure that the DDR\_RD\_DATA\_VALID is only asserted when all three DDRIF2 module instances have data available.

### CONV > DDRIF2 Interface

This interface shall support the writing of data from the CONV module to DDRIF2#0, #2 and #3 via a 512-bit data bus DDR\_WR\_DATA[511:0] to each DDRIF2 instance.

The CONV module shall assert a “DDR\_WR\_EN” signal when a write is required, along with an address signal DDR\_WR\_ADDR[31:0]. Each value of the address bus corresponds to a byte offset, however with a 512-bit (i.e. 64-byte) data bus the only legal values for the 32-bit address are:-

0x0000,0000

0x0000,0040

0x0000,0080

etc

The DDRIF2 #0, #2 and #3 module instances shall indicate when it is able to accept data and address by controlling the DDR\_WR\_WAIT\_REQUEST signal to the CONV module. “FIFO\_READY” signals passed between the DDRIF2 module instances ensure that the DDR\_WR\_WAIT\_REQUEST is only de-asserted when all three DDRIF2 module instances have space to store the data and address.

## DDRIF2 Architecture

**DDRIF2**

RD\_DMA\_WRITE\_DATA[511:0]

RD\_DMA\_BURST\_COUNT[3:0]

RD\_DMA\_BYTE\_EN[63:0]

IF\_

SEL

RD\_DMA\_WAIT\_REQUEST

DDR\_WR\_EN

AMM\_ADDRESS[31:0]

RX\_PCIE\_IF

RX\_PROC\_IF

RD\_DMA\_WRITE

RD\_DMA\_ADDRESS[63:0]

DDR\_WR\_ADDR[31:0]

DDR\_WR\_DATA[511:0]

DDR\_WR\_WAIT\_REQUEST

AMM\_WRITE\_DATA[511:0]

RX\_ADDR [31:0]

AMM\_WRITE

AMM\_ WAIT\_REQUEST

AMM\_BURSTCOUNT[6:0]

= “0000001”

AMM\_BYTE\_EN[63:0]

= 0xFFFF,FFFF,FFFF,FFFF

TX\_PCIE\_IF

TX\_PROC\_IF

WR\_DMA\_ADDRESS[63:0]

DDR\_RD\_ADDR[31:0]

DDR\_RD\_DATA[511:0]

DDR\_RD\_DATA\_VALID

AMM\_READ\_DATA[511:0]

AMM\_READ\_DATA\_VALID

WR\_DMA\_READ\_DATA[511:0]

DDR\_RD\_EN

WR\_DMA\_READ

WR\_DMA\_BURST\_COUNT[3:0]

WR\_DMA\_READ\_DATA\_VALID

WR\_DMA\_WAIT\_REQUEST

AMM\_READ

FIFO\_READY

FIFO\_READY

RX\_FIFO

Store 512-bit data words and DDR address

RX\_DATA

\_PCIE

[511:0]

RX\_ADDR

\_PCIE

[31:0]

RX\_DATA

\_PROC

[511:0]

RX\_ADDR

\_PROC

[31:0]

VALID

WADDR

WAIT

WAG\_IN

RAG\_IN

RX\_DATA

\_PCIE

[511:0]

RX\_ADDR

\_PCIE

[31:0]

REQ

VALID

WAG

\_IN

RAG\_IN

RX\_FIFO

Store 512-bit data words and DDR address

RADDR

WADDR

RADDR

WAIT

REQ

RX\_DATA

\_PROC

[511:0]

RX\_ADDR

\_PROC

[31:0]

RD\_ADDR

\_PCIE

[31:0]

RD\_ADDR

\_PROC

[31:0]

VALID

VALID

TX\_DATA

[511:0]

DATA\_FIFO

\_512

Store

DDR Data

TX\_DATA

[511:0]

TX\_DATA

[511:0]

VALID\_

DATA

RADDR

RAG\_OUT512

WAG\_OUT

VALID\_DATA

RAG\_OUT\_3

\_512

WAG\_OUT

DATA\_

FIFO

\_512

Store

DDR Data

WADDR

RADDR

WADDR

TX\_DATA

[511:0]

DDR\_RD\_WAIT\_REQUEST

READ\_WRITE\_SEL

PCIE\_PROC\_SEL

CLK\_SYS

CLK\_PCIE

RST\_SYS\_N

CLK\_DDR

FIFO\_FULL

FIFO\_FULL

RX\_DATA [511:0]

WRITE

WAIT

READ

PROC\_READ\_DATA\_VALID

PCIE\_READ\_DATA\_VALID

VALID

WR\_DATA

\_PCIE

[511:0]

WR\_ADDR

\_PCIE

[31:0]

VALID

WR\_DATA

\_PROC

[511:0]

WR\_ADDR

\_PROC

[31:0]

RST\_DDR\_N

RST\_PCIE\_N

READ

WRITE

READ

WRITE

READ

WRITE

READ

WRITE

FIFO\_READY\_OUT

FIFO\_READY\_IN\_1

FIFO\_READY\_IN\_2

FIFO\_FULL\_IN\_1

FIFO\_FULL\_IN\_2

DATA\_AVAIL\_OUT

FIFO\_FULL\_OUT

DATA\_AVAIL\_IN\_1

DATA\_AVAIL\_IN\_2

Figure ‑ : DDRIF2 Architecture Block Diagram

### Interface Select: IF\_SEL Sub-Module

The IF\_SEL sub-module shall select which interface is to be given access to the External DDR SDRAM memory. Each of the input active high Enable signals shall be edge detected (both rising and falling edges detected) on the CLK\_DDR domain (333.33MHz). A priority shall be applied in the event that multiple input Enable signals are asserted simultaneously according to the table below:-

|  |  |  |
| --- | --- | --- |
| Enable Signal Requesting External DDR SDRAM memory access | Interface | Priority |
| WR\_DMA\_READ | PCIe Read from External DDR SDRAM memory | 1 - Highest |
| RD\_DMA\_WRITE | PCIe Write to External DDR SDRAM memory | 2 |
| DDR\_RD\_EN | CLD / HSUM Read from External DDR SDRAM memory | 3 |
| DDR\_WR\_EN | CONV Write to External DDR SDRAM memory | 4 - Lowest |

Table ‑ : Interface Priority Selection

In normal fault free operation only one interface shall be requesting External DDR SDRAM memory access at any one time.

The output of the IF\_SEL sub-module shall be used to control muxes to select interface to be granted access to the External DDR SDRAM memory.

### Receive PCIE Interface: RX\_PCIE\_IF Sub-Module

The RX\_PCIE\_IF sub-module shall terminate the data from the PCIe Hard IP Macro.

When the PCIe Hard IP Macro attempts to write to the External DDR SDRAM memory it shall assert the RD\_DMA\_WRITE signal (active high) which shall enable the RX\_PCIE\_IF sub-module.

The RX\_PCIE\_IF sub-module shall de-assert the RD\_DMA\_WAIT\_REQUEST if the associated RX\_FIFO sub-module has spare capacity as indicated by the “FIFO\_READY” signal from the RX\_FIFO sub-module’s Write Address Generator sub-module (WAG\_IN).

The transfer of data and address shall then commence with the RX\_PCIE\_IF sub-module asserting the VALID signal to the WAG\_IN sub-module when data is available and with the RX\_PCIE\_IF sub-module continually monitoring the fill level of the associated RX\_FIFO sub-module (via “FIFO\_READY”) and raising RD\_DMA\_WAIT\_REQUEST as and when necessary.

**To support the PCIe Hard IP Macro which has a WaitRequest Allowance of 16 this version of the RX\_PCIE\_IF sub-module only uses the RD\_DMA\_WRITE** **signal to qualify the existence of new data from the PCIe Hard IP Macro. The PCIe Hard IP Macro may still send a further 16 write accesses after RD\_DMA\_WAIT\_REQUEST has been asserted.**

The RD\_DMA\_BURST\_COUNT[3:0] signal and the RD\_DMA\_ADDRESS[31:0] signal shall be used to generate the series of 32-bit External DDR SDRAM memory addresses to accompany the data.

The PCIe Transaction Layer Packet is terminated in the PCIe Hard IP Macro and only the payload data is presented to the DDRIF2 module.

The incoming data RD\_DMA\_WRITE\_DATA[511:0] shall be stored in the RX\_FIFO sub-module with an associated 32-bit External DDR SDRAM memory address per 512-bit data word. It is a requirement on the PC/Computer that RD\_DMA\_BYTE\_EN[63:0] is always all 1’s (i.e. all bytes of RD\_DMA\_WRITE\_DATA[511:0] are valid).

### Receive Processing Interface: RX\_PROC\_IF Sub-Module

The RX\_PROC\_IF sub-module shall terminate the data from the CONV module.

When the CONV module attempts to write to the External DDR SDRAM memory it shall assert the DDR\_WR\_EN signal (active high) which shall enable the RX\_PROC\_IF sub-module.

The RX\_PROC\_IF sub-module shall de-assert the DDR\_WR\_WAIT\_REQUEST if the associated local RX\_FIFO sub-module has spare capacity as indicated by the “FIFO\_READY” signal from the RX\_FIFO sub-module’s Write Address Generator sub-module (WAG\_IN) and the “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2” signals from the other DDRIF2 modules supporting the CONV module.

i.e.

DDR\_WR\_WAIT\_REQUEST <=

**NOT**(FIFO\_READY **AND** FIFO\_READY\_IN\_1 **AND** FIFO\_READY\_IN\_2)

The transfer of data and address shall then commence, with the RX\_PROC\_IF sub-module asserting the VALID signal to the WAG\_IN sub-module when data is available and with the RX\_PROC\_IF sub-module continually monitoring the fill level of the local RX\_FIFO sub-module and other DDRIF2 module (via “FIFO\_READY” “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2”) and raising DDR\_WR\_WAIT\_REQUEST as and when necessary.

The RX\_PROC\_IF sub-module shall present the incoming address DDR\_WR\_ADDR[31:0]

and Data DDR\_WR\_DATA[511:0] to the RX\_FIFO sub-module so that the data for the External DDR SDRAM memory can be stored in the RX\_FIFO sub-module along with its External DDR SDRAM memory address.

### RX\_FIFO , WAG\_IN & RAG\_IN Sub-Modules

**These versions of RX\_FIFO, WAG\_IN and RAG\_IN sub-modules support a 64 location FIFO and require at least 48 free locations to be deemed to be capable of receiving more access commands from the PCIe Hard IP Macro. This infers DDRIF2 supports a WaitRequest Allowance of 48.**

The RX\_FIFO sub-module provides a rate adaption function between the CLK\_DDR domain and the CLK\_SYS or CLK\_PCIE domains.

DDR address, data and read/write information shall be stored in the RX\_FIFO sub-module. The RX\_FIFO submodule shall have a depth of 64 locations and a word width of 546-bits so that the 512-bit data for the External DDR SDRAM memory, the 32-bit Address for the External DDR SDRAM memory and the READ/WRITE signals can be stored in each RX\_FIFO sub-module location. (If desired the lower 6 bits of the address can be omitted from storage in the RX\_FIFO sub-module since they shall always be “000000” for a 512-bit data word).

The Write Address Generator sub-module (WAG\_IN) and Read Address Generator sub-module (RAG\_IN) shall pass their FIFO pointer positions between each other with meta-stable protection (for example using a gray code style). In this way the WAG\_IN sub-module shall be able to determine when there is space in the RX\_FIFO and RAG\_IN sub-module shall be able to determine when the RX\_FIFO sub-module is empty. A “FIFO\_READY” signal shall indicate if the FIFO is able to accept more information. The “FIFO\_READY” signal shall be asserted if the FIFO is able to accept at least 48 more access commands, and since this signal ultimately controls the RD\_DMA\_WAIT\_REQUEST to the PCIe Hard IP Macro, this infers the DDRIF2 module has a WaitRequest Allowance of 48.

The WAG\_IN sub-module shall be sensitive to the “VALID” signal from RX\_PCIE\_IF/RX\_PROC\_IF/ TX\_PCIE\_IF/TX\_PROC\_IF sub-modules indicating that data is available to be stored in the RX\_FIFO sub-module and shall increment each clock cycle that VALID is asserted.

The RAG\_IN sub-module shall be sensitive to the “WAIT” signal indicating that the downstream DDR Controller is not able to accept data and shall increment each clock cycle that WAIT is not asserted (until the Read pointer advances to the Write pointer, - indicating the RX\_FIFO sub-module is empty). When the RAG\_IN sub-module increments it shall assert the “REQ” signal which shall be used by the downstream to qualify the READ / WRITE signals from the RX\_FIFO sub-module to the DDR Controller to indicate a read or write request.

### Transmit PCIE Interface: TX\_PCIE\_IF Sub-Module

The TX\_PCIE\_IF sub-module shall terminate the address from the PCIe Hard IP Macro and source the data to the PCIe Hard IP Macro.

When the PCIe Hard IP Macro attempts to read the External DDR SDRAM memory it shall assert the WR\_DMA\_READ signal (active high) which shall enable the TX\_PCIE\_IF sub-module.

The TX\_PCIE\_IF sub-module shall de-assert the WR\_DMA\_WAIT\_REQUEST if the associated RX\_FIFO sub-module has spare capacity as indicated by the “FIFO\_READY” signal from the RX\_FIFO sub-module’s Write Address Generator sub-module (WAG\_IN), and the associated DATA\_FIFO\_512 sub-module is not getting too full as indicated by the “FIFO\_FULL” signal from the DATA\_FIFO\_512 sub-module’s Read Address Generator sub-module (RAG\_OUT\_512).

The transfer of the address information shall then commence with the TX\_PCIE\_IF sub-module asserting the VALID signal to the WAG\_IN sub-module when address information is available and with the TX\_PCIE\_IF sub-module continually monitoring the fill level of the associated RX\_FIFO sub-module (via “FIFO\_READY”) and the DATA\_FIFO\_512 sub-module (via “FIFO\_FULL”), raising WR\_DMA\_WAIT\_REQUEST as and when necessary.

The WR\_DMA\_BURST\_COUNT[3:0] signal and the WR\_DMA\_ADDRESS[63:0] signal shall be used to generate the series of 32-bit External DDR SDRAM memory addresses to be stored in the RX\_FIFO sub-module.

The outgoing data “WR\_DMA\_READ\_DATA[511:0]” back to the PCIe Hard IP Macro shall be validated by the WR\_DMA\_READ\_DATA\_VALID signal.

### Transmit Processing Interface: TX\_PROC\_IF Sub-Module

The TX\_PROC\_IF sub-module shall terminate the address from the CLD / HSUM module and source the data to the CLD/ HSUM module.

When the CLD/HSUM module attempts to read the External DDR SDRAM memory it shall assert the DDR\_RD\_EN signal (active high) which shall enable the TX\_PROC\_IF sub-module.

The TX\_PROC\_IF sub-module shall de-assert the DDR\_RD\_WAIT\_REQUEST if the associated local RX\_FIFO sub-module has spare capacity as indicated by:-

1. The “FIFO\_READY” signal from the RX\_FIFO sub-module’s Write Address Generator sub-module (WAG\_IN) and the “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2” signals from the other DDRIF2 modules supporting the HSUM module (in the case of supporting the CLD module the “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2” signals are tied to logic ‘1’)
2. The “FIFO\_FULL” signal from the DATA\_FIFO\_512 sub-module’s Read Address Generator sub-module (RAG\_OUT\_512) and the “FIFO\_FULL\_IN\_1” and “FIFO\_FULL\_IN\_2” signals from the other DDRIF2 modules supporting the HSUM module (in the case of supporting the CLD module the “FIFO\_FULL\_IN\_1” and “FIFO\_FULL\_IN\_2” signals are tied to logic ‘0’)

i.e.

DDR\_RD\_WAIT\_REQUEST <=

(**NOT**(FIFO\_READY **AND** FIFO\_READY\_IN\_1 **AND** FIFO\_READY\_IN\_2)

**OR**

(FIFO\_FULL **OR** FIFO\_FULL\_IN\_1 **OR** FIFO\_FULL\_IN\_2)

The transfer of data shall then commence, with the RX\_PROC\_IF sub-module asserting the VALID signal to the WAG\_IN sub-module when data is available and with continually monitoring the fill level of the local RX\_FIFO sub-module and other DDRIF2 module (via “FIFO\_READY” “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2”) and raising DDR\_WR\_WAIT\_REQUEST as and when necessary.

The transfer of the address information “DDR\_RD\_ADDR[31:0]” shall then commence with the TX\_PROC\_IF sub-module asserting the VALID signal to the WAG\_IN sub-module when address information is available and with the TX\_PROC\_IF continually monitoring the fill level of the local RX\_FIFO sub-module and other DDRIF2 module (via “FIFO\_READY” “FIFO\_READY\_IN\_1” and “FIFO\_READY\_IN\_2”) and

and the DATA\_FIFO\_512 sub-module (via “FIFO\_FULL”, “FIFO\_FULL\_IN\_1” and “FIFO\_FULL\_IN\_2”)), raising DDR\_RD\_WAIT\_REQUEST as and when necessary.

The TX\_PROC\_IF sub-module supplies “DDR\_RD\_DATA[511:0]” valid data to the CLD/HSUM module with the DDR\_RD\_DATA\_VALID signal asserted if the VALID\_DATA signal from the RAG\_OUT\_3\_512 sub-module is asserted.

### DATA\_FIFO\_512, WAG\_OUT , RAG\_OUT\_512 and RAG\_OUT\_3\_512 Sub-Modules

The DATA\_FIFO\_512 sub-module provides a rate adaption function between the CLK\_DDR domain and the CLK\_SYS or CLK\_PCIE domains.

DDR data information shall be stored in the DATA\_FIFO\_512 sub-module when it is valid. The DATA\_FIFO\_512 sub-module shall have a depth of 512locations and a word width of 512-bits so that the 512-bit data from the External DDR SDRAM memory can be stored in each DATA\_FIFO\_512 sub-module location.

The reason for the large DATA\_FIFO\_512 sub-module depth is to take account of the latency of the external DDR memory. If the DATA\_FIFO\_512 sub-module starts to get too full (i.e. exceeds half full) the WAIT\_REQUEST to the FDAS module (CLD/HSUM) or PCIe Hard IP Macro shall be asserted which in turn shall result in the RX\_FIFO sub-module pausing thus stopping any further read requests to the external DDR memory. The external DDR memory shall continue to process read requests previously received which will need to be stored in the DATA\_FIFO\_512 sub-module. The largest read request shall be from the HSUM module when it requests 40 FOP columns (each of 85 rows with 32-bit values per location), which is equivalent to 212.5 DATA\_FIFO\_512 locations, - hence half the DATA\_FIFO\_512 sub-module capacity is set to 256 locations so that it exceeds 212.5 locations.

The Write Address Generator sub-module (WAG\_OUT) shall pass its FIFO pointer position to the Read Address Generator sub-module (RAG\_OUT\_512) with meta-stable protection (for example using a gray code style). In this way the RAG\_OUT\_512 sub-module shall be able to determine when the DATA\_FIFO\_512 sub-module is empty or when it is getting too full, raising the FIFO\_FULL signal when necessary to raise the WAIT signal to CLD/HSUM via the TX\_PROC\_IF sub-module or PCIE Hard IP Macro via the TX\_PCIE\_IF sub-module.

The RAG\_OUT\_512 and RAG\_OUT\_3\_512 sub-modules shall support addressing to the DATA\_FIFO\_512 sub-module based on a 512-bit read data.

The WAG\_OUT sub-module shall be sensitive to the “VALID” signal from the DDR Controller indicating that Data is available to be stored in the DATA\_FIFO\_512 sub-module and shall increment each clock cycle that VALID is asserted.

The RAG\_OUT\_512 sub-module shall increment its pointer on each clock cycle that the DATA\_FIFO\_512 sub-module is not empty. The RAG\_OUT\_512 sub-module shall indicate that the data is valid each time in increments and also indicate if the DATA\_FIFO\_512 sub-module is full.

The RAG\_OUT\_3\_512 sub-module is similar to the RAG\_OUT\_512 sub-module, however it will only increment its pointer each clock cycle if the DATA\_FIFO\_512 sub-module is not empty and the “DATA\_AVAIL\_IN\_1” and “DATA\_AVAIL\_IN\_2” from the other DDRIF2 modules are all asserted (in the case of supporting the CLD module the DATA\_AVAIL\_IN\_1” and “DATA\_AVAIL\_IN\_2” signals are tied to logic ‘1’).

# Design Requirement Tags

The relevant design requirement tags from the FDAS Design Specification Document for the DDRIF2 module are listed below.

| **Design Requirement Tag** | **Description** | **Comment** |
| --- | --- | --- |
| FDAS.DATAIN:040/A | The FFT sequence shall be stored by FDAS in external DDR SDRAM memory, with all values static for a known period of time. | The freq-bin samples from the PC/Computer via the PCIe shall be stored in External DDR SDRAM memory. |
| FDAS.DATAIN:060/A | The external memory containing the input data shall have two pages, to allow one page to be written to whilst the other page is being accessed by the FDAS core processing. | In this implementation with reduced complexity DDR interface only one page of storage shall be required. |
| FDAS.DATAIN:070/A | For a given page the allocation of freq-bins to memory locations shall be known and fixed, thus the memory address can be used to identify the freq-bin number and the real and imaginary value of each freq-bin. | The freq-bin locations within the External DDR SDRAM memory are fixed. |
| FDAS.DATAIN:080/A | The input data to FDAS (i.e. the observed data) shall be stored in external DDR SDRAM memory with the information shared equally across the available SDRAM devices. The **internal** FDAS data bus width shall be dependent on the number of external DDR SDRAM memory interfaces. A generic “ddr\_g” shall indicate the number of external DDR interfaces. | In this implementation with reduced complexity DDR interface only one External DDR SDRAM device shall be used to store the freq-bin samples, with a separate External DDR SDRAM device being used to store the FOP. |
| FDAS.DATAIN:090/A | External commands from Software via a Monitor and Control (MC) interface shall instruct FDAS to commence reading the FFT sequence from memory, and also which memory page to access. | In this implementation with reduced complexity DDR interface the commands shall be such that only one internal module is attempting access to an External DDR SDRAM device at any one time. |
| FDAS.DIAGNOSTIC:010/A | It shall be possible, via the PCIe, for the MC Interface to have read/write access to any location of the external DDR memory. Ideally block accesses shall possible so that a region of the DDR external memory can be accessed via the PCIe with a minimum number of read/write commands. | In this implementation with reduced complexity DDR interface, the PCIe shall access to the External DDR SDRAMs via two separate DDRIF2 modules. |

Table ‑ : DDRIF2 Design Requirement Tags

# Interface Specification

| Signal | Direction | Clock Domain | Description |
| --- | --- | --- | --- |
| **DDRIF2 Interface to PCIE Hard IP Read DMA Interface to Read Data from PC/Computer and write to External DDR SDRAM memory** |  |  |  |
| RD\_DMA\_WRITE | IN | CLK\_PCIE | When asserted, indicates that the PCIe Hard IP is ready to write data to External DDR SDRAM memory.  ‘1’ = Write |
| RD\_DMA\_ADDRESS[31:0] | IN | CLK\_PCIE | Address of an External DDR SDRAM memory location to which data from the PCIe Hard IP Macro is to be written.  [31] = msb |
| RD\_DMA\_WRITE\_DATA[511:0] | IN | CLK\_PCIE | Data from the PCIe Hard IP Macro which is to be written to External DDR SDRAM memory.  [511] = msb |
| RD\_DMA\_BURST\_COUNT[3:0] | IN | CLK\_PCIE | Specifies the burst count in 512-bit words. This bus is 4 bits for the 512-bit interface. |
| RD\_DMA\_BYTE\_EN[63:0] | IN | CLK\_PCIE | Specifies which bytes of a word or are valid. |
| RD\_DMA\_WAIT\_REQUEST | OUT | CLK\_PCIE | When asserted, indicates that the DDRIF2 module is not ready to receive data from the PCIe Hard IP Macro.  ‘1’ = Wait, DDRIF2 is not ready. |
|  |  |  |  |
| **DDRIF2 Interface to PCIE Hard IP Write DMA Interface to Read Data from External DDR SDRAM memory and write to PC/Computer** |  |  |  |
| WR\_DMA\_READ | IN | CLK\_PCIE | When asserted, indicates that the CLD/HSUM module is ready to read data from External DDR SDRAM memory.  ‘1’ = Read |
| WR\_DMA\_ADDRESS[31:0] | IN | CLK\_PCIE | Specifies the External DDR SDRAM memory address for the data to be read from.  [31] = msb |
| WR\_DMA\_READ\_DATA[511:0] | OUT | CLK\_PCIE | Data from External DDR SDRAM memory to the PCIe Hard IP Macro.  [511] = msb |
| WR\_DMA\_BURST\_COUNT[3:0] | IN | CLK\_PCIE | Specifies the burst count in 512-bit words. This bus is 4 bits for the 512-bit interface. |
| WR\_DMA\_READ\_DATA\_VALID | OUT | CLK\_PCIE | Indication that the WR\_DMA\_READ\_DATA from the DDRIF2 module to the PCIe Hard IP Macro is valid.  ‘1’ = Valid |
| WR\_DMA\_WAIT\_REQUEST | OUT | CLK\_PCIE | When asserted, indicates that the DDRIF2 module is not ready to process read requests from the PCIe Hard IP Macro.  ‘1’ = Wait, DDRIF2 is not ready. |
| **DDRIF2 Interfaces common to CONV and HSUM modules** |  |  |  |
| FIFO\_READY\_IN\_1 | IN | CLK\_SYS | Asserted when the RX FIFO of one of the other DDRIF2 module instances is able to accept Address from CONV or HSUM and Data from CONV to access the DDR4 SDRAM  ‘1’ = Able to accept Address & Data |
| FIFO\_READY\_IN\_2 | IN | CLK\_SYS | Asserted when the RX FIFO of one of the other DDRIF2 module instances is able to accept Address from CONV or HSUM and Data from CONV to access the DDR4 SDRAM  1’ = Able to accept Address & Data |
| FIFO\_READY\_OUT | OUT | CLK\_SYS | Asserted when the local RX FIFO is able to accept Address from CONV or HSUM and Data from CONV to access the DDR4 SDRAM  1’ = Able to accept Address & Data |
|  |  |  |  |
| **DDRIF2 Interface to CONV Module** |  |  |  |
| DDR\_WR\_EN | IN | CLK\_SYS | When asserted, indicates that the CONV module is ready to write data to External DDR SDRAM memory.  ‘1’ = Write |
| DDR\_WR\_ADDR[31:0] | IN | CLK\_SYS | Address of an External DDR SDRAM memory location to which data from the CONV module is to be written.  [31] = msb |
| DDR\_WR\_DATA[511:0] | IN | CLK\_SYS | Data from the CONV module which is to be written to External DDR SDRAM memory.  [511] = msb |
| DDR\_WR\_WAIT\_REQUEST | OUT | CLK\_SYS | When asserted, indicates that the DDRIF2 module is not ready to receive data from the CONV module.  ‘1’ = Wait, DDRIF2 is not ready. |
|  |  |  |  |
| **DDRIF2 Interface to CLD & HSUM Modules** |  |  |  |
| DDR\_RD\_EN | IN | CLK\_SYS | When asserted, indicates that the CLD/HSUM module is ready to read data from External DDR SDRAM memory.  ‘1’ = Read |
| DDR\_RD\_ADDR[31:0] | IN | CLK\_SYS | Specifies the External DDR SDRAM memory address for the data to be read from.  [31] = msb |
| DDR\_RD\_DATA[511:0] | OUT | CLK\_SYS | Data from External DDR SDRAM memory to the CLD/HSUM module.  [511] = msb |
| FIFO\_FULL\_IN\_1 | IN | CLK\_SYS | Asserted when the DATA\_FIFO \_512 of one of the other DDRIF2 module instances supporting HSUM access is full and hence no more Read requests from HSUM can be accepted.  ‘1’ = DATA\_FIFO\_512 is full |
| FIFO\_FULL\_IN\_2 | IN | CLK\_SYS | Asserted when the DATA\_FIFO \_512 of one of the other DDRIF2 module instances supporting HSUM access is full and hence no more Read requests from HSUM can be accepted.  ‘1’ = DATA\_FIFO\_512 is full |
| DATA\_AVAIL\_IN\_1 | IN | CLK\_SYS | Asserted when the DATA\_FIFO \_512 of one of the other DDRIF2 module instances supporting HSUM access has data available to supply to HSUM.  ‘1’ = Data is available |
| DATA\_AVAIL\_IN\_2 | IN | CLK\_SYS | Asserted when the DATA\_FIFO \_512 of one of the other DDRIF2 module instances supporting HSUM access has data available to supply to HSUM.  ‘1’ = Data is available |
| DDR\_RD\_DATA\_VALID | OUT | CLK\_SYS | Indication that the DDR\_RD\_DATA from DDRIF2 to the CLD/HSUM module is valid.  ‘1’ = Valid |
| DDR\_RD\_WAIT\_REQUEST | OUT | CLK\_SYS | When asserted, indicates that the DDRIF2 module is not ready to process read requests from the CLD / HSUM module.  ‘1’ = Wait, DDRIF2 is not ready. |
| FIFO\_FULL\_OUT | OUT | CLK\_SYS | Asserted when the local DATA\_FIFO \_512 is full and hence no more Read requests from HSUM can be accepted.  ‘1’ = DATA\_FIFO\_512 is full |
| DATA\_AVAIL\_IN\_1 | OUT | CLK\_SYS | Asserted when the the DATA\_FIFO \_512 has data available to supply to HSUM.  ‘1’ = Data is available |
|  |  |  |  |
| **Interface to the DDR Controller** |  |  |  |
| AMM\_WRITE | OUT | CLK\_DDR | When asserted, indicates that the DDRIF2 module is ready to write data to External DDR SDRAM memory.  ‘1’ = Write |
| AMM\_WRITE\_DATA[511:0] | OUT | CLK\_DDR | Data from the DDRIF2 module which is to be written to External DDR SDRAM memory.  [255] = msb |
| AMM\_BURSTCOUNT[6:0] | OUT | CLK\_DDR | Specifies the burst count. This is hardwired to a burst of one 512-bit word  AMM\_BURSTCOUNT[6:0] = “0000001” |
| AMM\_BYTE\_EN[63:0] | OUT | CLK\_DDR | Specifies which bytes of a word or are valid. This is hardwired to 0xFFFF,FFFF, FFFF,FFFF to indicate all bytes of the 512-bit word are valid  AMM\_BYTE\_EN[63:0]  = 0xFFFF,FFFF, FFFF,FFFF |
| AMM\_ADDRESS[31:0] | OUT | CLK\_DDR | Address of an External DDR SDRAM memory location to which data from the DDRIF2 module is to be written.  [31] = msb |
| AMM\_READ | OUT | CLK\_DDR | When asserted, indicates that the DDRIF2 module is ready to read data from External DDR SDRAM memory.  ‘1’ = Read |
| AMM\_READ\_DATA[511:0] | IN | CLK\_DDR | Data from External DDR SDRAM memory to the DDRIF2 module.  [255] = msb |
| AMM\_READ\_DATA\_VALID | IN | CLK\_DDR | Indication that the AMM\_READ\_DATA from the DDR Controller is valid.  ‘1’ = Valid |
| AMM \_WAIT\_REQUEST | IN | CLK\_DDR | When asserted, indicates that the DDR Controller is not ready to process requests from the DDRIF2 module.  ‘1’ = Wait, DDR Controller is not ready  . |
|  |  |  |  |
| **Global Clock/Resets** |  |  |  |
| CLK\_SYS | IN | - | 350MHz Core System Clock |
| CLK\_PCIE | IN | - | 350MHz clock from the PCIe Hard IP macro |
| CLK\_DDR | IN | - | 333.33MHz clock from the DDR Controller |
| RST\_SYS\_N | IN | - | Asynchronous Logic reset for the CLK\_SYS domain  ‘0’=Reset |
| RST\_PCIE\_N | IN | - | Asynchronous Logic reset for the CLK\_PCIE domain  ‘0’=Reset |
| RST\_DDR\_N | IN | - | Asynchronous Logic reset for the CLK\_DDR domain  ‘0’=Reset |

Table ‑ : DDRIF2 Pinlist

# MCI Memory Mapped Interface

The DDRIF2 module does not have an MCI memory mapped interface.

# Design Parameterisation

The DDRIF2 module does not have any generic parameterisation.

# References

|  |  |  |
| --- | --- | --- |
| **Bookmark** | **Reference** | **Description** |
| [Ref: Agilex DDR User Guide] | External Memory Interfaces Intel Agilex FPGA IP User Guide UG-20218 2021.07.09 | Intel DDR interface User Guide for the Agilex FPGA family. |

# Abbreviations and Acronyms

|  |  |
| --- | --- |
| DM | Dispersion Measure |
| DMA | Direct Memory Access |
| DDR | Double Data Rate |
| FDAS | Fourier Domain Acceleration Search |
| FFT | Fast Fourier Transform |
| FOP | Filter Output Plane |
| FPGA | Field Programmable Gate Array |
| IEEE | Institute of Electrical Engineers |
| IP | Intellectual Property |
| MC | Micro Controller Interface |
| MSI-X | Extended Message Signalled Interrupt |
| PCIe | Peripheral Component Interconnect Express |
| SDRAM | Synchronous Dynamic RAM |