![](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 DDR CONTROLLER AND CALIBRATION BLOCK IN THE INTEL AGILEX F FPGA FAMILY**

FDAS\_DDR\_CONTROLLER\_DS Revision 3 Draft D

Classification: UNRESTRICTED

Document type: DTE

Date: 2023-01-27

Status: DRAFT

© 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 |  | 27/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 | 31/03/2022 | First Issue for review.  Comments from Prabu Thiagaraj and Atul Ghalame, and responses from Martin Droog:-  1) Pinouts for PCIe and DDR are given in the respective documents. It will be helpful to add the reference board schematics source (possibly a link to the intel schematics for the board or some file containing the pinouts). Once we have the board, we can perhaps upload relevant intel documents etc., with these details so that they will all be in one place.  **M. Droog Response: The Intel Agilex F Board schematics shall be referenced in this document.**  2) References to the DDR documentation etc. may be added to the document.  **M. Droog Response: The Intel Agilex DDR User Guide reference shall be added to this document as a table of references**  3) In the DDR interface document: page 8/25 says that the data lines could be selected from our sub bank and address from the inner sub bank. In our case, DDR side pinouts are fixed in the dev-kit. Could you please comment?  **M. Droog Response: The statement you are referring to is**  **“*If a DDR SDRAM memory interface spans more than one sub-bank then the control and address pins must be in the central sub-bank and the data pins can be assigned to outer sub-bank”.***  **This is a general Intel Agilex rule that must be adhered to when creating a DDR interface that needs to use more than one sub-bank. In the case of the Intel Agilex F Development Board Intel have defined the pinout for the DDR interfaces and they do abide by this rule, in that they support up to 72-data bit DDR interfaces and have ensured that the central sub-bank contains the Address/Control pins.**  4) Also, DDR clock considered is 1333.x MHz. If the design has to be ported for another speed DDR, I wonder how the clocks (333.x) scale fine?  **M. Droog Response: The maximum DDR interface clock speed that the Agilex FPGA family supports is 1333.33 MHz (using both clock edges with 64-bit data), which infers an internal clock speed of 333.33MHz (using just the rising clock edge with 512-bit data) to the DDRIF2 module within the FDAS FPGA. The DDRIF2 module contains phase buffers to cope with data transfer between the 333.33MHz DDR clock speed and the 350MHz internal core clock speeds. If the phase buffers are starting to get to full the signalling provided by the Avalon interface protocol used to connect the data paths allows data delivery to be paused. The CONV module which passes data to the DDRIF2 module to be written to DDR SDRAM therefore has to be designed to cope with back-pressure due to the DDRIF2 phase buffers starting to get too full.** |
| Issue 2 Draft B | 28/04/2022 | * Intel Agilex F Board schematics reference added. * Intel Agilex DDR User Guide reference added as a bookmark to a references table. |
| Issue 2 Draft C | 12/07/2022 | * Updated for the DDR SDRAM supplied with the Intel Agilex Development Kit DK-DEV-AGF014EA * Agilex FPGA AGFB014R24B2E2V * DDR4 SDRAM Modules: RDIMM DDR4 8GB K41197-001 MTA9ASF1G72PZ-2G9E1UI |
| Issue 2 Draft D | 18/07/2022 | * Typo correction |
| Issue 2 Draft E | 19/07/2022 | * Changed DDR4 PLL Clock Frequency to 33.333MHz to match the Development Board clock frequency. |
| Issue 2 Draft F | 22/07/2022 | * Added Appendix A to describe the FDAS DDR Controller design required for DDR Channel 1 which normally supports the HPS (Hard Processor Sub-System). |
| Issue 3 Draft A | 10/10/2022 | * DDR Controller and Calibration block designs to support all four DDR4 SDRAM interfaces of the Agilex FPGA. One DDR Controller and Calibration block design supports DDR channels 0 and 1, with channel 1 being repurposed from the HPS and the other DDR Controller and Calibration block design supports DDR channels 2 and 3. |
| Issue 3 Draft B | 19/10/2022 | * Renamed DDRIF2 instances to match DDR channel numbers. |
| Issue 3 Draft C | 2401/2023 | * Design changed to 1200MHz operation with ECC base on the parameters from the Intel Reference design as the 1333.333MHz presets in Intel Quartus Prime cause traffic errors in the DDR Controller. The intention is to eventually support 1333.333MHz, but until working parameters are available the design will use the Intel Reference design 1200MHz parameters with ECC enabled. |
| Issue 3 Draft D | 27/01/2023 | * The ECC seems to slow down the DDR SRDAM accesses by approx. 60%, Hence the ECC has been turned off on the FDAS\_DDR\_CONTROLLER to improve bandwidth. Quartus Prime does not allow the ECC to be turned off on the FDAS\_DDR\_CONTROLLER\_HPS |

**Table of Contents**

1 Introduction 6

2 Place in the System 8

3 Intel Agilex F DDR Controller and Calibration Block IP 10

3.1 Overview of External Memory Interfaces in Agilex F 10

3.2 FDAS Memory Bank Selection 13

3.3 DDR4 SDRAM Pinout 23

4 FDAS DDR Controller Simulation 35

4.1 Generation of DDR4 SDRAM Simulation Model 35

4.2 Creating Simulation Compile Script 35

5 FDAS\_DDR\_CONTROLLER\_CALIBRATION Architecture for DDR Channels 2 and 3 36

6 FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS Architecture for DDR Channels 0 and 1 37

7 Design Requirement Tags 38

8 Interface Specifications 39

8.1 FDAS\_DDR\_CONTROLLER IP Component 39

8.2 FDAS\_DDR\_CONTROLLER\_HPS IP Component 43

8.3 FDAS\_EMIF\_CALIBRATION IP Component 47

9 MCI Memory Mapped Interface 48

10 Design Parameterisation 49

11 References 50

12 Abbreviations and Acronyms 51

# Introduction

This document captures the requirements for the DDR Controller used in the FDAS Intel Agilex F FPGA.

The Intel Agilex F Dev Kit DK-DEV-AGF014EA is fitted with the AGFB014R24B2E2V which supports up to four 72-bit DDR4 SDRAM Interfaces.

The supplied SDRAM modules are:-

DDR4 SDRAM Modules: RDIMM DDR4 8GB

K41197-001

MTA9ASF1G72PZ-2G9E1UI

For the FDAS version translated from Arria 10 to Agilex two DDR4 SDRAM Interfaces were required.

For the FDAS design in Agilex with improved processing times all four DDR SDRAM interfaces (including the DDR interface normally used by the on-board Hard Processor Sub-System) shall be used.

This document shall describe the DDR Controller and associated Calibration Blocks for the FDAS version with four DDR4 SDRAM interfaces, with each DDR4 SDRAM interface supported by a DDR Controller and with a Calibration block supporting each pair of DDR interfaces on the same side of the Agilex device.

DDR channels 0 and 1 are on one side of the Agilex device and DDR channels 2 and 3 are on the opposite side. On each side of the device is a single DDR Calibration block which serves all DDR Controllers in that side of the device.

DDR channel 1 is normally associated with an on-board Hard Processor System (HPS), however with appropriate settings in the Intel Quartus software design tool this DDR Controller can be re-purposed to be used by the FDAS function. Hence DDR Controller channel 1 requires different Intel Quartus software design tool settings compared to DDR Controller channels 0, 2 and 3.

The two DDR Controllers and associated DDR Calibration block for each side of the device are placed in a Wrapper to make instantiation in the FDAS Top Level structure more convenient. Since Channel 1 is different to the other channels this infers that two variants of the Wrapper are required. The one containing channels 2 and 3 shall be the “FDAS\_DDR\_CONTROLLER\_CALIBRATION” wrapper and the one containing channels 0 and 1 Wrapper shall be the “FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS” wrapper to uniquely identify them.

The internal DDR Controller connection towards the core of the FDAS design shall be via a 512-bit data bus, operating at a maximum clock rate allowed by the Intel Agilex AGFB014R24B2E2V device. In the case of the AGFB014R24B2E2V Agilex F device the maximum DDR clock rate (to the external DDR SDRAMs) is 1333.333MHz, which infers a maximum internal clock of 333.333MHz to the core of the FDAS.

The intention is to use this clock frequency but currently the only DDR Controller parameters that support error free traffic are 1200MHz. These parameters have been obtained from the Intel Reference design.

The DDR Controller and associated Calibration Block shall be created using Intel IP via the Quartus Prime software version 22.2.

Note that the FDAS design only uses 4GByte of the DDR4 SDRAM

# Place in the System

The DDR Controller’s place in the FDAS FPGA is shown highlighted in the two figures 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 #34 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 ‑ – DDR Controller Module Locations in FDAS

The figure below shows the detailed connectivity of the DDR Controller modules the FDAS design.

Figure ‑: Detailed DDR Controller Connectivity

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

# Intel Agilex F DDR Controller and Calibration Block IP

## Overview of External Memory Interfaces in Agilex F

The External Memory Interfaces are supported by blocks at the upper and lower edges of the Agilex F device.

An Intel document describes the External Memory Interface in Agilex [Ref: Agilex DDR User Guide].

Figure 3‑1 below shows the positions of the I/O banks in two rows (2 & 3) which support the external memory interfaces in the AGFB014R24B2E2V device. Each bank is sub-divided into sub-bank “top” and “bottom” with the outer sub-bank designated as “top”. The “HPS” is the Hard Processor Sub-System which can use Bank 3D to provide an external memory interface. The Zipper block performs routing adjustments where routing wires cross the Zipper.

Transceiver Block

Transceiver Block

3A

Top

3A

Bottom

3B

Top

3B

Bottom

3C

Top

3C

Bottom

3D

Top

3D

Bottom

2A

Bottom

2A

Top

2B

Bottom

2B

Top

2C

Bottom

2C

Top

2D

Bottom

2D

Top

HPS

Zipper

Row 3 External Memory Banks

Row 2 External Memory Banks

72-bitDDR I/F Channel 0

72-bit DDR I/F Channel 3

72-bit DDR I/F Channel 1

72-bit DDRI/F Channel 2

Figure 3‑1: External Memory Banks in Agilex AGFB014R24B2E2V

Each row includes one I/O subsystem manager which contains a NIOS II processor which is used to provide the calibration of the external memory interfaces of that row.

Each sub-bank contains:

* Hard Memory Controller
* Sequencer Components
* I/O PLL and PHY clock trees
* DLL
* Input DQS clock trees
* 48 pins, organised into for lanes each of 12 pins

Each sub-bank contains all the functions to build an external memory interface. A wider interface can be made by connecting multiple adjacent sub-banks together in the order shown below:-

The Top Row sub-bank ordering for the AGFB014R24B2E2V device is shown in Figure 3‑2 below:-

Figure 3‑2: Top Row Sub-Bank Ordering When Connecting Adjacent Sub-banks

Bank 3C

Top Sub-bank

Lane 0 (48-59

Lane 1 (60-71)

Lane 2 (72-83)

Lane 3 (84-95)

Bottom Sub-bank

Lane 0 (0-11)

Lane 1 (12-23)

Lane 2 (24-35)

Lane 3 (36-47)

Lane 0 (0-11)

Bank 3A

Top Sub-bank

Lane 3 (84-95)

Lane 2 (72-83)

Lane 1 (60-71)

Lane 0 (48-59)

Bottom Sub-bank

Lane 3 (36-47)

Lane 2 (24-35)

Lane 1 (12-23)

Lane 0 (0-11)

Bank 3B

Top Sub-bank

Lane 3 (84-95)

Lane 2 (72-83)

Lane 1 (60-71)

Lane 0 (48-59)

Bottom Sub-bank

Lane 3 (36-47)

Lane 2 (24-35)

Lane 1 (12-23)

Lane 0 (0-11)

Bank 3D

Top Sub-bank

Lane 0 (48-59)

Lane 1 (60-71)

Lane 2 (72-83)

Lane 3 (8495)

Bottom Sub-bank

Lane 0 (0-11)

Lane 1 (12-23)

Lane 2 (24-35)

Lane 3 (36-47)

Zipper

The Bottom Row sub-bank ordering for the AGFB014R24B2E2V device is shown in Figure 3‑3 below:-

Bank 2C

Bottom Sub-bank

Lane 0 (0-11)

Lane 1 (12-23)

Lane 2 (24-35

Lane 3 (36-47

Top Sub-bank

Lane 0 (48-59)

Lane 1 (60-71)

Lane 2 (72-83)

Lane 3 (84-95)

Lane 0 (0-11)

Bank 2A

Bottom Sub-bank

Lane 3 (36-47)

Lane 2 (24-35)

Lane 1 (12-23)

Lane 0 (0-11)

Top Sub-bank

Lane 3 (84-95)

Lane 2 (72-83)

Lane 1 (60-71)

Lane 0 (48-59)

Bank 2B

Bottom Sub-bank

Lane 3 (36-47)

Lane 2 (24-35)

Lane 1 (12-23)

Lane 0 (0-11)

Top Sub-bank

Lane 3 (84-95)

Lane 2 (72-83)

Lane 1 (60-71)

Lane 0 (48-59)

Bank2D

Bottom Sub-bank

Lane 0 (0-11)

Lane 1 (12-23)

Lane 2 (24-35)

Lane 3 (36-47)

Top Sub-bank

Lane 0 (48-59)

Lane 1 (60-71)

Lane 2 (72-83)

Lane 3 (74-95)

Zipper

Figure 3‑3: Bottom Row Sub-Bank Ordering When Connecting Adjacent Sub-banks

If a DDR SDRAM memory interface spans more than one sub-bank then the control and address pins must be in the central sub-bank and the data pins can be assigned to outer sub-banks.

**A sub-bank cannot be shared across different external memory interfaces.**

This effectively limits the Agilex device AGFB014R24B2E2V to four external 72-bit DDR4 SDRAM interfaces, since each interface uses three sub-banks.

## FDAS Memory Bank Selection

The FDAS FPGA requires four 64-bit DDR4 Interfaces to provide the maximum performance. Hence all DDR Interfaces of the Intel Agilex F device are used.

#### External Memory Controller IP for DDR Channels 0, 2 and 3

The External Memory Controller IP (i.e. DDR Controller”) is generated using the Intel Quartus Prime software version 22.2.0.

Quartus Prime software version 22.2 IP Catalog.

The “IP Catalog” shall be used with the following selected:-

Memory Interfaces and Controllers > External Memory Interfaces Intel Agilex FPGA IP

This launches “IP Platform Designer” which then asks for a name for the IP Variation which shall be entered as “FDAS\_DDR\_CONTROLLER”

The intention is to use the DDR Controller at its maximum declared frequency of 1333.333MHz. However, currently no parameters are available to support error free traffic operation.

Hence the 1200MHz parameters available in an Intel Reference design shall be used. **However with ECC enabled the DDR bandwidth seems to reduce by approximately 60%. Hence ECC shall be disabled.**

The full list of settings is:-

**General Tab**

=======

**Speed Grade:** E2V

**Configuration:** Hard PHY and Hard Controller

**Use Clamshell layout:** OFF

**Memory Clock Frequency:** 1200.0MHz

**Use recommended PLL reference clock frequency:** OFF

**PLL ref clock frequency:**  33.333MHz

**PLL ref clock jitter:** 10ps

**Clock rate of user logic:**  Quarter

**Specify additional core clocks based on existing PLL:** OFF

**Mimic HPS EMIF:** OFF

**Memory Tab**

======

**Memory Format:** RDIMM

**DQ Width:** 72

**DQ pins per DQS group:** 8

**Number of DQS groups:** 9

**Number of Clocks:** 1

**Number of DIMMs:** 1

**Chip ID width:** 0 (non-3DS)

**Number of Physical Ranks per DIMM:** 1

**Number of Chip Selects per DIMM:** 1

**Row Address Width:** 16

**Column Address Width:** 10

**Bank Address Width:** 2

**Bank Group Width:** 2

**Data Mask:** ON

**Write DBI:**  OFF

**Read DBI:** ON

**ALERT# Pin Placement:** Address/Command

Lane 3, Pin 8

**Memory CAS latency setting:** 21

**Memory Write CAS latency setting:** 16

**Memory additive CAS latency setting:** Disabled

**Addr/CMD parity latency:** Disabled

**Fine granularity refresh:** Fixed 1x

**Mem I/O Tab**

=======

**Use Default Memory I/O settings:** ON

**Output drive strength setting:** RZQ/7 (34 Ohm)

**Dynamic ODT (Rtt\_WR) value:** Dynamic ODT off

**ODT Rtt nominal value:** ODT Disabled

**RTT PARK:** RZQ/4 (60 Ohm)

**RCD CA Input Bus Termination:** 100 Ohm

**RDC DCS[3:0]\_n Input Bus Termination:** 100 Ohm

**RCD DCKE Input Bus Termination:** 100 Ohm

**RCD DODT Input Bus Termination:** 100 Ohm

**Use recommended initial VrefDQ value:** ON

**VrefDQ training value:** 70.0

**VrefDQ training range:** Range 1 - 60% to 92.5%

**SPD Byte 137 - RCD Drive Strength for Command/Address:** 0x65

**SPD Byte 138 - RCD Drive Strength for CK:** 0x05

**Use Default ODT Assertion Tables:** ON

**Derived ODT Matrix for Read Access** Rank 0 (Drive)

RZQ/7 (34 Ohm)

**Derived ODT Matrix for Write Access** Rank 0 (Park)

RZQ/4 (60 Ohm)

**FPGA I/O Tab**

========

**Voltage:** 1.2V

**Use Default I/O settings:** OFF

**Address/Command:**

**I/O standard:**  SSTL-12

**Output mode:** 40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** OFF

(unset in ref design)

**Memory Clock:**

**I/O standard:** SSTL-12

**Output mode:** 40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** OFF

(unset in ref design)

**Data Bus:**

**I/O standard**: 1.2V-POD

**Output mode:**  40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** HIGH

(unset in ref design)

**Input mode:** 60 Ohm with calibration

**Use recommended initial Vrefin** ON

**Initial Vrefin:** 68%

**PHY Inputs:**

**PLL reference clock I/O standard**: True Differential signalling

with On-Chip Termination

**RZQ I/O standard:** 1.2-V

**RZQ resistor:** 240 Ohm

**Mem Timing Tab**

===========

**Speed Bin:** -2666

**tlS (base):** 62 ps

**tlS (base) AC level:** 100mV

**tlH (base):** 87ps

**tlH (base) DC level:** 75mV

**TdivW\_total:** 0.2UI

**VdiVW\_total:** 130mV

**tDQSQ:** 0.14UI

**tQH:** 0.74UI

**tDVWp:** 0.72UI

**tDQSCK:** 175ps

**tDQSS:** 0.27 cycles

**tQSH:** 0.4 cycles

**tDSH:** 0.18 cycles

**tDSS:** 0.18 cycles

**tWLS:** 0.13 cycles

**tWLH:** 0.13 cycles

**tINIT:** 500us

**tRMD:** 8 cycles

**tRAS:** 32.0ns

**tRCD:** 14.16ns

**tRP:** 14.16ns

**tWR:** 15.0ns

**tRRD\_S:** 4 cycles

**tRRD\_L:** 6 cycles

**tFAW:** 21.0ns

**tCCD\_S:** 4 cycles

**tCCD\_L:** 6 cycles

**tWTR\_S:** 3 cycles

**tWTR\_L:** 9 cycles

**tRFC:** 350.0ns

**tREFI:** 7.8us

**Board Tab**

======

Refer to board layout guidelines in EMIF user

guide to design your board to the to the

given memory configuration.

**Controller Tab**

===========

**Enable Auto Power-Down:** OFF

**Auto Power-Down cycles:** 32 cycles

**Enable User Refresh Control:** OFF

**Enable Auto-Precharge Control:** OFF

**Address Ordering:** CS-CID-Row-Bank-Col-BG

**Enable Re-ordering:** ON

**Starvation Limit for each command:** 10

**Enable Command Priority Control:**  OFF

**Enable controller major mode:** OFF (not in Ref design)

**Enable controller post-pay refresh:** OFF (not in Ref design)

**Enable controller pre-pay refresh:** OFF (not in Ref design)

**Enable Memory-Mapped Configuration**

**and Status Register (MMR) Interface:** OFF

**Enable Error Detection and Error Correction Logic**

**with ECC:**  OFF

**Enable Auto correction to External Memory** OFF

**Enable ctrl\_ecc\_readdataerror signal to indicate**

**Uncorrectable data errors** OFF

**Export error-correction code (ECC) status ports:**  OFF

**Additional read-to-write turnaround time (same rank):** 0 cycles

**Additional write-to-read turnaround time (same rank):** 0 cycles

**Additional read-to-read turnaround time (different ranks):** 0 cycles

**Additional read-to-write turnaround time (different ranks):** 0 cycles

**Additional write-to-write turnaround time (different ranks):** 0 cycles

**Additional write-to-read turnaround time (different ranks)):** 0 cycles

This populates all the necessary External Memory settings. This can then be saved and the HDL can be generated (click “Generate HDL” button) ensuring that the selected language is VHDL.

#### External Memory Controller IP for DDR Channel 1

The External Memory Controller IP (i.e. DDR Controller”) is generated using the Intel Quartus Prime software version 22.2 IP Catalog.

The “IP Catalog” shall be used with the following selected:-

Memory Interfaces and Controllers > External Memory Interfaces Intel Agilex FPGA IP

This launches “IP Platform Designer” which then asks for a name for the IP Variation which shall be entered as “FDAS\_DDR\_CONTROLLER\_HPS”

The intention is to use the DDR Controller at its maximum declared frequency of 1333.333MHz. However, currently no parameters are available to support error free traffic operation.

Hence the 1200MHz parameters available in an Intel Reference design shall be used.

The full list of settings is:-

**General Tab**

=======

**Speed Grade:** E2V

**Configuration:** Hard PHY and Hard Controller

**Use Clamshell layout:** OFF

**Memory Clock Frequency:** 1200.0MHz

**Use recommended PLL reference clock frequency:** OFF

**PLL ref clock frequency:**  33.333MHz

**PLL ref clock jitter:** 10ps

**Clock rate of user logic:**  Quarter

**Specify additional core clocks based on existing PLL:** OFF

**Mimic HPS EMIF:** ON

**Memory Tab**

======

**Memory Format:** RDIMM

**DQ Width:** 72

**DQ pins per DQS group:** 8

**Number of DQS groups:** 9

**Number of Clocks:** 1

**Number of DIMMs:** 1

**Chip ID width:** 0 (non-3DS)

**Number of Physical Ranks per DIMM:** 1

**Number of Chip Selects per DIMM:** 1

**Row Address Width:** 16

**Column Address Width:** 10

**Bank Address Width:** 2

**Bank Group Width:** 2

**Data Mask:** ON

**Write DBI:**  OFF

**Read DBI:** ON

**ALERT# Pin Placement:** Address/Command

Lane 2, Pin 8

**Memory CAS latency setting:** 21

**Memory Write CAS latency setting:** 16

**Memory additive CAS latency setting:** Disabled

**Addr/CMD parity latency:** Disabled

**Fine granularity refresh:** Fixed 1x

**Mem I/O Tab**

=======

**Use Default Memory I/O settings:** ON

**Output drive strength setting:** RZQ/7 (34 Ohm)

**Dynamic ODT (Rtt\_WR) value:** Dynamic ODT off

**ODT Rtt nominal value:** ODT Disabled

**RTT PARK:** RZQ/4 (60 Ohm)

**RCD CA Input Bus Termination:** 100 Ohm

**RDC DCS[3:0]\_n Input Bus Termination:** 100 Ohm

**RCD DCKE Input Bus Termination:** 100 Ohm

**RCD DODT Input Bus Termination:** 100 Ohm

**Use recommended initial VrefDQ value:** ON

**VrefDQ training value:** 70.0

**VrefDQ training range:** Range 1 - 60% to 92.5%

**SPD Byte 137 - RCD Drive Strength for Command/Address:** 0x65

**SPD Byte 138 - RCD Drive Strength for CK:** 0x05

**Use Default ODT Assertion Tables:** ON

**Derived ODT Matrix for Read Access** Rank 0 (Drive)

RZQ/7 (34 Ohm)

**Derived ODT Matrix for Write Access** Rank 0 (Park)

RZQ/4 (60 Ohm)

**FPGA I/O Tab**

========

**Voltage:** 1.2V

**Use Default I/O settings:** OFF

**Address/Command:**

**I/O standard:**  SSTL-12

**Output mode:** 40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** OFF

(unset in ref design)

**Memory Clock:**

**I/O standard:** SSTL-12

**Output mode:** 40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** OFF

(unset in ref design)

**Data Bus:**

**I/O standard**: 1.2V-POD

**Output mode:**  40 Ohm with calibration

**Slew rate:** FAST

(unset in ref design)

**Deemphasis mode:** HIGH

(unset in ref design)

**Input mode:** 60 Ohm with calibration

**Use recommended initial Vrefin** ON

**Initial Vrefin:** 68%

**PHY Inputs:**

**PLL reference clock I/O standard**: True Differential signalling

with On-Chip Termination

**RZQ I/O standard:** 1.2-V

**RZQ resistor:** 240 Ohm

**Mem Timing Tab**

===========

**Speed Bin:** -2666

**tlS (base):** 62 ps

**tlS (base) AC level:** 100mV

**tlH (base):** 87ps

**tlH (base) DC level:** 75mV

**TdivW\_total:** 0.2UI

**VdiVW\_total:** 130mV

**tDQSQ:** 0.14UI

**tQH:** 0.74UI

**tDVWp:** 0.72UI

**tDQSCK:** 175ps

**tDQSS:** 0.27 cycles

**tQSH:** 0.4 cycles

**tDSH:** 0.18 cycles

**tDSS:** 0.18 cycles

**tWLS:** 0.13 cycles

**tWLH:** 0.13 cycles

**tINIT:** 500us

**tRMD:** 8 cycles

**tRAS:** 32.0ns

**tRCD:** 14.16ns

**tRP:** 14.16ns

**tWR:** 15.0ns

**tRRD\_S:** 4 cycles

**tRRD\_L:** 6 cycles

**tFAW:** 21.0ns

**tCCD\_S:** 4 cycles

**tCCD\_L:** 6 cycles

**tWTR\_S:** 3 cycles

**tWTR\_L:** 9 cycles

**tRFC:** 350.0ns

**tREFI:** 7.8us

**Board Tab**

======

Refer to board layout guidelines in EMIF user

guide to design your board to the to the

given memory configuration.

**Controller Tab**

===========

**Enable Auto Power-Down:** OFF

**Auto Power-Down cycles:** 32 cycles

**Enable User Refresh Control:** OFF

**Enable Auto-Precharge Control:** OFF

**Address Ordering:** CS-CID-Row-Bank-Col-BG

**Enable Re-ordering:** ON

**Starvation Limit for each command:** 10

**Enable Command Priority Control:**  OFF

**Enable controller major mode:** OFF (not in Ref design)

**Enable controller post-pay refresh:** OFF (not in Ref design)

**Enable controller pre-pay refresh:** OFF (not in Ref design)

**Enable Memory-Mapped Configuration**

**and Status Register (MMR) Interface:** OFF

**Enable Error Detection and Error Correction Logic**

**with ECC:**  ON

**Enable Auto correction to External Memory** OFF

**Enable ctrl\_ecc\_readdataerror signal to indicate**

**Uncorrectable data errors** OFF

**Export error-correction code (ECC) status ports:**  OFF

**Additional read-to-write turnaround time (same rank):** 0 cycles

**Additional write-to-read turnaround time (same rank):** 0 cycles

**Additional read-to-read turnaround time (different ranks):** 0 cycles

**Additional read-to-write turnaround time (different ranks):** 0 cycles

**Additional write-to-write turnaround time (different ranks):** 0 cycles

**Additional write-to-read turnaround time (different ranks)):** 0 cycles

This populates all the necessary External Memory settings. This can then be saved and the HDL can be generated (click “Generate HDL” button) ensuring that the selected language is VHDL.

#### External Memory Interface Calibration IP

The External Memory Interface Calibration IP (i.e. DDR Controller) is generated using the Intel Quartus Prime software version 22.2 IP Catalog.

The “IP Catalog” shall be used with the following selected:-

Memory Interfaces and Controllers > External Memory Interfaces Intel Calibration IP

This launches “IP Platform Designer” which then asks for a name for the IP Variation which shall be entered as “FDAS\_EMIF\_CALIBRATION”

Enter the following settings:-

**Number of Calibration Interfaces:** 2

**Quartus Prime RMIF Debug toolkit/On-chip Debug port:** Disabled

**Calibration for Simulation:** Skip Calibration

**Show verbose simulation debug messages:** OFF

This can then be saved and the HDL can be generated (click “Generate HDL” button) ensuring that the selected language is VHDL.

#### Instantiation of the External Memory Interface

The FDAS\_DDR\_CONTROLLER, FDAS\_DDR\_CONTROLLER\_HPS and associated FDAS\_EMIF\_CALIBRATION modules are combined in a VHDL Wrapper.

Two FDAS\_DDR\_CONTROLLER blocks and an FDAS\_EMIF\_CALIBRATION block are contained in an FDAS\_DDR\_CONTROLLER\_CALIBRATION VHDL Wrapper.

An FDAS\_DDR\_CONTROLLER block, an FDAS\_DDR\_CONTROLLER\_HPS block and an FDAS\_EMIF\_CALIBRATION block are contained in an FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS VHDL Wrapper.

## DDR4 SDRAM Pinout

The DDR4 pinout in the .qsf file is consistent with the Intel Agilex F-Series Development Board which supports the AGFB014R24B2E2V Intel Agilex device [Ref: Agilex Development Board].

**FDAS External Memory Interface #1 for CLD :**

**Connected to Banks 3C/3D (DDR I/F Channel 1)**

PIN\_L10 -to PLL\_REF\_CLK\_1

PIN\_T17 -to MEM1\_A[0]

PIN\_V17 -to MEM1\_A[1]

PIN\_U16 -to MEM1\_A[2]

PIN\_W16 -to MEM1\_A[3]

PIN\_T15 -to MEM1\_A[4]

PIN\_V15 -to MEM1\_A[5]

PIN\_U14 -to MEM1\_A[6]

PIN\_W14 -to MEM1\_A[7]

PIN\_T13 -to MEM1\_A[8]

PIN\_V13 -to MEM1\_A[9]

PIN\_U12 -to MEM1\_A[10]

PIN\_W12 -to MEM1\_A[11]

PIN\_P9 -to MEM1\_A[12]

PIN\_L8 -to MEM1\_A[13]

PIN\_N8 -to MEM1\_A[14]

PIN\_M7 -to MEM1\_A[15]

PIN\_P7 -to MEM1\_A[16]

PIN\_N16 -to MEM1\_ACT\_N[0]

PIN\_L6 -to MEM1\_ALERT\_N[0]

PIN\_N6 -to MEM1\_BA[0]

PIN\_M5 -to MEM1\_BA[1]

PIN\_P5 -to MEM1\_BG[0]

PIN\_M17 -to MEM1\_BG[1]

PIN\_M13 -to MEM1\_CK[0]

PIN\_P13 -to MEM1\_CK\_N[0]

PIN\_L14 -to MEM1\_CKE[0]

PIN\_L16 -to MEM1\_CS\_N[0]

PIN\_M15 -to MEM1\_ODT[0]

PIN\_A10 -to MEM1\_DQ[0]

PIN\_C10 -to MEM1\_DQ[1]

PIN\_B9 -to MEM1\_DQ[2]

PIN\_D9 -to MEM1\_DQ[3]

PIN\_A6 -to MEM1\_DQ[4]

PIN\_B5 -to MEM1\_DQ[5]

PIN\_C6 -to MEM1\_DQ[6]

PIN\_D5 -to MEM1\_DQ[7]

PIN\_G10 -to MEM1\_DQ[8]

PIN\_J10 -to MEM1\_DQ[9]

PIN\_F9 -to MEM1\_DQ[10]

PIN\_H9 -to MEM1\_DQ[11]

PIN\_G6 -to MEM1\_DQ[12]

PIN\_J6 -to MEM1\_DQ[13]

PIN\_F5 -to MEM1\_DQ[14]

PIN\_H5 -to MEM1\_DQ[15]

PIN\_F17 -to MEM1\_DQ[16]

PIN\_H17 -to MEM1\_DQ[17]

PIN\_G16 -to MEM1\_DQ[18]

PIN\_J16 -to MEM1\_DQ[19]

PIN\_F13 -to MEM1\_DQ[20]

PIN\_J12 -to MEM1\_DQ[21]

PIN\_H13 -to MEM1\_DQ[22]

PIN\_G12 -to MEM1\_DQ[23]

PIN\_B17 -to MEM1\_DQ[24]

PIN\_D17 -to MEM1\_DQ[25]

PIN\_A16 -to MEM1\_DQ[26]

PIN\_C16 -to MEM1\_DQ[27]

PIN\_B13 -to MEM1\_DQ[28]

PIN\_D13 -to MEM1\_DQ[29]

PIN\_A12 -to MEM1\_DQ[30]

PIN\_C12 -to MEM1\_DQ[31]

PIN\_U24 -to MEM1\_DQ[32]

PIN\_W24 -to MEM1\_DQ[33]

PIN\_T23 -to MEM1\_DQ[34]

PIN\_V23 -to MEM1\_DQ[35]

PIN\_U20 -to MEM1\_DQ[36]

PIN\_W20 -to MEM1\_DQ[37]

PIN\_T19 -to MEM1\_DQ[38]

PIN\_V19 -to MEM1\_DQ[39]

PIN\_L24 -to MEM1\_DQ[40]

PIN\_N24 -to MEM1\_DQ[41]

PIN\_M23 -to MEM1\_DQ[42]

PIN\_P23 -to MEM1\_DQ[43]

PIN\_L20 -to MEM1\_DQ[44]

PIN\_P19 -to MEM1\_DQ[45]

PIN\_N20 -to MEM1\_DQ[46]

PIN\_M19 -to MEM1\_DQ[47]

PIN\_M31 -to MEM1\_DQ[48]

PIN\_P31 -to MEM1\_DQ[49]

PIN\_L30 -to MEM1\_DQ[50]

PIN\_N30 -to MEM1\_DQ[51]

PIN\_M27 -to MEM1\_DQ[52]

PIN\_P27 -to MEM1\_DQ[53]

PIN\_L26 -to MEM1\_DQ[54]

PIN\_N26 -to MEM1\_DQ[55]

PIN\_T31 -to MEM1\_DQ[56]

PIN\_V31 -to MEM1\_DQ[57]

PIN\_U30 -to MEM1\_DQ[58]

PIN\_W30 -to MEM1\_DQ[59]

PIN\_T27 -to MEM1\_DQ[60]

PIN\_W26 -to MEM1\_DQ[61]

PIN\_V27 -to MEM1\_DQ[62]

PIN\_U26 -to MEM1\_DQ[63]

PIN\_U10 -to MEM1\_DQ[64]

PIN\_W10 -to MEM1\_DQ[65]

PIN\_T9 -to MEM1\_DQ[66]

PIN\_V9 -to MEM1\_DQ[67]

PIN\_U6 -to MEM1\_DQ[68]

PIN\_W6 -to MEM1\_DQ[69]

PIN\_T5 -to MEM1\_DQ[70]

PIN\_V5 -to MEM1\_DQ[71]

PIN\_A8 -to MEM1\_DQS[0]

PIN\_C8 -to MEM1\_DQS\_N[0]

PIN\_G8 -to MEM1\_DQS[1]

PIN\_J8 -to MEM1\_DQS\_N[1]

PIN\_F15 -to MEM1\_DQS[2]

PIN\_H15 -to MEM1\_DQS\_N[2]

PIN\_B15 -to MEM1\_DQS[3]

PIN\_D15 -to MEM1\_DQS\_N[3]

PIN\_U22 -to MEM1\_DQS[4]

PIN\_W22 -to MEM1\_DQS\_N[4]

PIN\_L22 -to MEM1\_DQS[5]

PIN\_N22 -to MEM1\_DQS\_N[5]

PIN\_M29 -to MEM1\_DQS[6]

PIN\_P29 -to MEM1\_DQS\_N[6]

PIN\_T29 -to MEM1\_DQS[7]

PIN\_V29 -to MEM1\_DQS\_N[7]

PIN\_U8 -to MEM1\_DQS[8]

PIN\_W8 -to MEM1\_DQS\_N[8]

PIN\_B7 -to MEM1\_DBI\_N[0]

PIN\_F7 -to MEM1\_DBI\_N[1]

PIN\_G14 -to MEM1\_DBI\_N[2]

PIN\_A14 -to MEM1\_DBI\_N[3]

PIN\_T21 -to MEM1\_DBI\_N[4]

PIN\_M21 -to MEM1\_DBI\_N[5]

PIN\_L28 -to MEM1\_DBI\_N[6]

PIN\_U28 -to MEM1\_DBI\_N[7]

PIN\_T7 -to MEM1\_DBI\_N[8]

PIN\_N12 -to MEM1\_PAR[0]

PIN\_P17 -to MEM1\_RESET\_N[0]

PIN\_M9 -to OCT\_RZQIN1

**FDAS External Memory Interface #0 for CONV/HSUM :**

**Connected to Banks 3A/3B (DDR I/F Channel 0)**

PIN\_L40 -to PLL\_REF\_CLK\_0

PIN\_T33 -to MEM0\_A[0]

PIN\_V33 -to MEM0\_A[1]

PIN\_U34 -to MEM0\_A[2]

PIN\_W34 -to MEM0\_A[3]

PIN\_T35 -to MEM0\_A[4]

PIN\_V35 -to MEM0\_A[5]

PIN\_U36 -to MEM0\_A[6]

PIN\_W36 -to MEM0\_A[7]

PIN\_T37 -to MEM0\_A[8]

PIN\_V37 -to MEM0\_A[9]

PIN\_U38 -to MEM0\_A[10]

PIN\_W38 -to MEM0\_A[11]

PIN\_P41 -to MEM0\_A[12]

PIN\_L42 -to MEM0\_A[13]

PIN\_N42 -to MEM0\_A[14]

PIN\_M43 -to MEM0\_A[15]

PIN\_P43 -to MEM0\_A[16]

PIN\_N34 -to MEM0\_ACT\_N[0]

PIN\_U44 -to MEM0\_ALERT\_N[0]

PIN\_N44 -to MEM0\_BA[0]

PIN\_M45 -to MEM0\_BA[1]

PIN\_P45 -to MEM0\_BG[0]

PIN\_M33 -to MEM0\_BG[1]

PIN\_M37 -to MEM0\_CK[0]

PIN\_P37 -to MEM0\_CK\_N[0]

PIN\_L36 -to MEM0\_CKE[0]

PIN\_L34 -to MEM0\_CS\_N[0]

PIN\_M35 -to MEM0\_ODT[0]

PIN\_F33 -to MEM0\_DQ[0]

PIN\_H33 -to MEM0\_DQ[1]

PIN\_G34 -to MEM0\_DQ[2]

PIN\_J34 -to MEM0\_DQ[3]

PIN\_J38 -to MEM0\_DQ[4]

PIN\_G38 -to MEM0\_DQ[5]

PIN\_F37 -to MEM0\_DQ[6]

PIN\_H37 -to MEM0\_DQ[7]

PIN\_B33 -to MEM0\_DQ[8]

PIN\_D33 -to MEM0\_DQ[9]

PIN\_A34 -to MEM0\_DQ[10]

PIN\_C34 -to MEM0\_DQ[11]

PIN\_D37 -to MEM0\_DQ[12]

PIN\_A38 -to MEM0\_DQ[13]

PIN\_B37 -to MEM0\_DQ[14]

PIN\_C38 -to MEM0\_DQ[15]

PIN\_A40 -to MEM0\_DQ[16]

PIN\_C40 -to MEM0\_DQ[17]

PIN\_B41 -to MEM0\_DQ[18]

PIN\_D41 -to MEM0\_DQ[19]

PIN\_D45 -to MEM0\_DQ[20]

PIN\_B45 -to MEM0\_DQ[21]

PIN\_A44 -to MEM0\_DQ[22]

PIN\_C44 -to MEM0\_DQ[23]

PIN\_G40 -to MEM0\_DQ[24]

PIN\_J40 -to MEM0\_DQ[25]

PIN\_F41 -to MEM0\_DQ[26]

PIN\_H41 -to MEM0\_DQ[27]

PIN\_J44 -to MEM0\_DQ[28]

PIN\_H45 -to MEM0\_DQ[29]

PIN\_G44 -to MEM0\_DQ[30]

PIN\_F45 -to MEM0\_DQ[31]

PIN\_G48 -to MEM0\_DQ[32]

PIN\_F47 -to MEM0\_DQ[33]

PIN\_J48 -to MEM0\_DQ[34]

PIN\_H47 -to MEM0\_DQ[35]

PIN\_F51 -to MEM0\_DQ[36]

PIN\_H51 -to MEM0\_DQ[37]

PIN\_G52 -to MEM0\_DQ[38]

PIN\_J52 -to MEM0\_DQ[39]

PIN\_F55 -to MEM0\_DQ[40]

PIN\_G54 -to MEM0\_DQ[41]

PIN\_H55 -to MEM0\_DQ[42]

PIN\_J54 -to MEM0\_DQ[43]

PIN\_J58 -to MEM0\_DQ[44]

PIN\_F59 -to MEM0\_DQ[45]

PIN\_G58 -to MEM0\_DQ[46]

PIN\_H59 -to MEM0\_DQ[47]

PIN\_B55 -to MEM0\_DQ[48]

PIN\_A54 -to MEM0\_DQ[49]

PIN\_D55 -to MEM0\_DQ[50]

PIN\_C54 -to MEM0\_DQ[51]

PIN\_D59 -to MEM0\_DQ[52]

PIN\_C58 -to MEM0\_DQ[53]

PIN\_F61 -to MEM0\_DQ[54]

PIN\_H61 -to MEM0\_DQ[55]

PIN\_V55 -to MEM0\_DQ[56]

PIN\_T55 -to MEM0\_DQ[57]

PIN\_W54 -to MEM0\_DQ[58]

PIN\_U54 -to MEM0\_DQ[59]

PIN\_W58 -to MEM0\_DQ[60]

PIN\_T59 -to MEM0\_DQ[61]

PIN\_U58 -to MEM0\_DQ[62]

PIN\_V59 -to MEM0\_DQ[63]

PIN\_A48 -to MEM0\_DQ[64]

PIN\_B47 -to MEM0\_DQ[65]

PIN\_C48 -to MEM0\_DQ[66]

PIN\_D47 -to MEM0\_DQ[67]

PIN\_C52 -to MEM0\_DQ[68]

PIN\_D51 -to MEM0\_DQ[69]

PIN\_B51 -to MEM0\_DQ[70]

PIN\_A52 -to MEM0\_DQ[71]

PIN\_F35 -to MEM0\_DQS[0]

PIN\_H35 -to MEM0\_DQS\_N[0]

PIN\_B35 -to MEM0\_DQS[1]

PIN\_D35 -to MEM0\_DQS\_N[1]

PIN\_A42 -to MEM0\_DQS[2]

PIN\_C42 -to MEM0\_DQS\_N[2]

PIN\_G42 -to MEM0\_DQS[3]

PIN\_J42 -to MEM0\_DQS\_N[3]

PIN\_F49 -to MEM0\_DQS[4]

PIN\_H49 -to MEM0\_DQS\_N[4]

PIN\_G56 -to MEM0\_DQS[5]

PIN\_J56 -to MEM0\_DQS\_N[5]

PIN\_A56 -to MEM0\_DQS[6]

PIN\_C56 -to MEM0\_DQS\_N[6]

PIN\_U56 -to MEM0\_DQS[7]

PIN\_W56 -to MEM0\_DQS\_N[7]

PIN\_B49 -to MEM0\_DQS[8]

PIN\_D49 -to MEM0\_DQS\_N[8]

PIN\_G36 -to MEM0\_DBI\_N[0]

PIN\_A36 -to MEM0\_DBI\_N[1]

PIN\_B43 -to MEM0\_DBI\_N[2]

PIN\_F43 -to MEM0\_DBI\_N[3]

PIN\_G50 -to MEM0\_DBI\_N[4]

PIN\_F57 -to MEM0\_DBI\_N[5]

PIN\_B57 -to MEM0\_DBI\_N[6]

PIN\_T57 -to MEM0\_DBI\_N[7]

PIN\_A50 -to MEM0\_DBI\_N[8]

PIN\_N38 -to MEM0\_PAR[0]

PIN\_P33 -to MEM0\_RESET\_N[0]

PIN\_M41 -to OCT\_RZQIN0

**FDAS External Memory Interface #2 for CONV/HSUM :**

**Connected to Banks 2A/2B (DDR I/F Channel 2)**

PIN\_CN38 -to PLL\_REF\_CLK\_2

PIN\_CH31 -to MEM2\_A[0]

PIN\_CF31 -to MEM2\_A[1]

PIN\_CG32 -to MEM2\_A[2]

PIN\_CE32 -to MEM2\_A[3]

PIN\_CH33 -to MEM2\_A[4]

PIN\_CF33 -to MEM2\_A[5]

PIN\_CG34 -to MEM2\_A[6]

PIN\_CE34 -to MEM2\_A[7]

PIN\_CH35 -to MEM2\_A[8]

PIN\_CF35 -to MEM2\_A[9]

PIN\_CG36 -to MEM2\_A[10]

PIN\_CE36 -to MEM2\_A[11]

PIN\_CK39 -to MEM2\_A[12]

PIN\_CN40 -to MEM2\_A[13]

PIN\_CL40 -to MEM2\_A[14]

PIN\_CM41 -to MEM2\_A[15]

PIN\_CK41 -to MEM2\_A[16]

PIN\_CL32 -to MEM2\_ACT\_N[0]

PIN\_CG42 -to MEM2\_ALERT\_N[0]

PIN\_CL42 -to MEM2\_BA[0]

PIN\_CM43 -to MEM2\_BA[1]

PIN\_CK43 -to MEM2\_BG[0]

PIN\_CM31 -to MEM2\_BG[1]

PIN\_CM35 -to MEM2\_CK[0]

PIN\_CK35 -to MEM2\_CK\_N[0]

PIN\_CN34 -to MEM2\_CKE[0]

PIN\_CN32 -to MEM2\_CS\_N[0]

PIN\_CM33 -to MEM2\_ODT[0]

PIN\_CE52 -to MEM2\_DQ[0]

PIN\_CF53 -to MEM2\_DQ[1]

PIN\_CG52 -to MEM2\_DQ[2]

PIN\_CH53 -to MEM2\_DQ[3]

PIN\_CE56 -to MEM2\_DQ[4]

PIN\_CG56 -to MEM2\_DQ[5]

PIN\_CF57 -to MEM2\_DQ[6]

PIN\_CH57 -to MEM2\_DQ[7]

PIN\_CR52 -to MEM2\_DQ[8]

PIN\_CT53 -to MEM2\_DQ[9]

PIN\_CU52 -to MEM2\_DQ[10]

PIN\_CV53 -to MEM2\_DQ[11]

PIN\_CR56 -to MEM2\_DQ[12]

PIN\_CU56 -to MEM2\_DQ[13]

PIN\_CT57 -to MEM2\_DQ[14]

PIN\_CV57 -to MEM2\_DQ[15]

PIN\_DA52 -to MEM2\_DQ[16]

PIN\_CY53 -to MEM2\_DQ[17]

PIN\_DB53 -to MEM2\_DQ[18]

PIN\_DC52 -to MEM2\_DQ[19]

PIN\_CY57 -to MEM2\_DQ[20]

PIN\_DB57 -to MEM2\_DQ[21]

PIN\_DA56 -to MEM2\_DQ[22]

PIN\_DC56 -to MEM2\_DQ[23]

PIN\_DA46 -to MEM2\_DQ[24]

PIN\_DC46 -to MEM2\_DQ[25]

PIN\_DB45 -to MEM2\_DQ[26]

PIN\_CY45 -to MEM2\_DQ[27]

PIN\_DC50 -to MEM2\_DQ[28]

PIN\_DA50 -to MEM2\_DQ[29]

PIN\_DB49 -to MEM2\_DQ[30]

PIN\_CY49 -to MEM2\_DQ[31]

PIN\_CT39 -to MEM2\_DQ[32]

PIN\_CV39 -to MEM2\_DQ[33]

PIN\_CU38 -to MEM2\_DQ[34]

PIN\_CR38 -to MEM2\_DQ[35]

PIN\_CU42 -to MEM2\_DQ[36]

PIN\_CV43 -to MEM2\_DQ[37]

PIN\_CR42 -to MEM2\_DQ[38]

PIN\_CT43 -to MEM2\_DQ[39]

PIN\_CY39 -to MEM2\_DQ[40]

PIN\_DB39 -to MEM2\_DQ[41]

PIN\_DC38 -to MEM2\_DQ[42]

PIN\_DA38 -to MEM2\_DQ[43]

PIN\_DC42 -to MEM2\_DQ[44]

PIN\_DB43 -to MEM2\_DQ[45]

PIN\_DA42 -to MEM2\_DQ[46]

PIN\_CY43 -to MEM2\_DQ[47]

PIN\_DA32 -to MEM2\_DQ[48]

PIN\_DC32 -to MEM2\_DQ[49]

PIN\_DB31 -to MEM2\_DQ[50]

PIN\_CY31 -to MEM2\_DQ[51]

PIN\_DA36 -to MEM2\_DQ[52]

PIN\_DC36 -to MEM2\_DQ[53]

PIN\_DB35 -to MEM2\_DQ[54]

PIN\_CY35 -to MEM2\_DQ[55]

PIN\_CR32 -to MEM2\_DQ[56]

PIN\_CU32 -to MEM2\_DQ[57]

PIN\_CV31 -to MEM2\_DQ[58]

PIN\_CT31 -to MEM2\_DQ[59]

PIN\_CV35 -to MEM2\_DQ[60]

PIN\_CU36 -to MEM2\_DQ[61]

PIN\_CT35 -to MEM2\_DQ[62]

PIN\_CR36 -to MEM2\_DQ[63]

PIN\_CU46 -to MEM2\_DQ[64]

PIN\_CT45 -to MEM2\_DQ[65]

PIN\_CR46 -to MEM2\_DQ[66]

PIN\_CV45 -to MEM2\_DQ[67]

PIN\_CT49 -to MEM2\_DQ[68]

PIN\_CU50 -to MEM2\_DQ[69]

PIN\_CV49 -to MEM2\_DQ[70]

PIN\_CR50 -to MEM2\_DQ[71]

PIN\_CG54 -to MEM2\_DQS[0]

PIN\_CE54 -to MEM2\_DQS\_N[0]

PIN\_CU54 -to MEM2\_DQS[1]

PIN\_CR54 -to MEM2\_DQS\_N[1]

PIN\_DC54 -to MEM2\_DQS[2]

PIN\_DA54 -to MEM2\_DQS\_N[2]

PIN\_DB47 -to MEM2\_DQS[3]

PIN\_CY47 -to MEM2\_DQS\_N[3]

PIN\_CU40 -to MEM2\_DQS[4]

PIN\_CR40 -to MEM2\_DQS\_N[4]

PIN\_DC40 -to MEM2\_DQS[5]

PIN\_DA40 -to MEM2\_DQS\_N[5]

PIN\_DB33 -to MEM2\_DQS[6]

PIN\_CY33 -to MEM2\_DQS\_N[6]

PIN\_CV33 -to MEM2\_DQS[7]

PIN\_CT33 -to MEM2\_DQS\_N[7]

PIN\_CV47 -to MEM2\_DQS[8]

PIN\_CT47 -to MEM2\_DQS\_N[8]

PIN\_CH55 -to MEM2\_DBI\_N[0]

PIN\_CV55 -to MEM2\_DBI\_N[1]

PIN\_DB55 -to MEM2\_DBI\_N[2]

PIN\_DC48 -to MEM2\_DBI\_N[3]

PIN\_CV41 -to MEM2\_DBI\_N[4]

PIN\_DB41 -to MEM2\_DBI\_N[5]

PIN\_DC34 -to MEM2\_DBI\_N[6]

PIN\_CU34 -to MEM2\_DBI\_N[7]

PIN\_CU48 -to MEM2\_DBI\_N[8]

PIN\_CL36 -to MEM2\_PAR[0]

PIN\_CK31 -to MEM2\_RESET\_N[0]

PIN\_CM39 -to OCT\_RZQIN2

**FDAS External Memory Interface #3 for CONV/HSUM :**

**Connected to Banks 2C/2D (DDR I/F Channel 3)**

PIN\_DC8 -to PLL\_REF\_CLK\_3

PIN\_CV15 -to MEM3\_A[0]

PIN\_CT15 -to MEM3\_A[1]

PIN\_CU14 -to MEM3\_A[2]

PIN\_CR14 -to MEM3\_A[3]

PIN\_CV13 -to MEM3\_A[4]

PIN\_CT13 -to MEM3\_A[5]

PIN\_CU12 -to MEM3\_A[6]

PIN\_CR12 -to MEM3\_A[7]

PIN\_CV11 -to MEM3\_A[8]

PIN\_CT11 -to MEM3\_A[9]

PIN\_CU10 -to MEM3\_A[10]

PIN\_CR10 -to MEM3\_A[11]

PIN\_CY7 -to MEM3\_A[12]

PIN\_DC6 -to MEM3\_A[13]

PIN\_DA6 -to MEM3\_A[14]

PIN\_DB5 -to MEM3\_A[15]

PIN\_CY5 -to MEM3\_A[16]

PIN\_DA14 -to MEM3\_ACT\_N[0]

PIN\_CU4 -to MEM3\_ALERT\_N[0]

PIN\_CY3 -to MEM3\_BA[0]

PIN\_CV1 -to MEM3\_BA[1]

PIN\_CT1 -to MEM3\_BG[0]

PIN\_DB15 -to MEM3\_BG[1]

PIN\_DB11 -to MEM3\_CK[0]

PIN\_CY11 -to MEM3\_CK\_N[0]

PIN\_DC12 -to MEM3\_CKE[0]

PIN\_DC14 -to MEM3\_CS\_N[0]

PIN\_DB13 -to MEM3\_ODT[0]

PIN\_CN28 -to MEM3\_DQ[0]

PIN\_CL28 -to MEM3\_DQ[1]

PIN\_CK29 -to MEM3\_DQ[2]

PIN\_CM29 -to MEM3\_DQ[3]

PIN\_CK25 -to MEM3\_DQ[4]

PIN\_CM25 -to MEM3\_DQ[5]

PIN\_CN24 -to MEM3\_DQ[6]

PIN\_CL24 -to MEM3\_DQ[7]

PIN\_CG28 -to MEM3\_DQ[8]

PIN\_CH29 -to MEM3\_DQ[9]

PIN\_CE28 -to MEM3\_DQ[10]

PIN\_CF29 -to MEM3\_DQ[11]

PIN\_CE24 -to MEM3\_DQ[12]

PIN\_CH25 -to MEM3\_DQ[13]

PIN\_CF25 -to MEM3\_DQ[14]

PIN\_CG24 -to MEM3\_DQ[15]

PIN\_CH21 -to MEM3\_DQ[16]

PIN\_CF21 -to MEM3\_DQ[17]

PIN\_CE22 -to MEM3\_DQ[18]

PIN\_CG22 -to MEM3\_DQ[19]

PIN\_CE18 -to MEM3\_DQ[20]

PIN\_CG18 -to MEM3\_DQ[21]

PIN\_CH17 -to MEM3\_DQ[22]

PIN\_CF17 -to MEM3\_DQ[23]

PIN\_DC28 -to MEM3\_DQ[24]

PIN\_DA28 -to MEM3\_DQ[25]

PIN\_CY29 -to MEM3\_DQ[26]

PIN\_DB29 -to MEM3\_DQ[27]

PIN\_CY25 -to MEM3\_DQ[28]

PIN\_DB25 -to MEM3\_DQ[29]

PIN\_DC24 -to MEM3\_DQ[30]

PIN\_DA24 -to MEM3\_DQ[31]

PIN\_CN14 -to MEM3\_DQ[32]

PIN\_CL14 -to MEM3\_DQ[33]

PIN\_CK15 -to MEM3\_DQ[34]

PIN\_CM15 -to MEM3\_DQ[35]

PIN\_CK11 -to MEM3\_DQ[36]

PIN\_CM11 -to MEM3\_DQ[37]

PIN\_CN10 -to MEM3\_DQ[38]

PIN\_CL10 -to MEM3\_DQ[39]

PIN\_CG14 -to MEM3\_DQ[40]

PIN\_CH15 -to MEM3\_DQ[41]

PIN\_CE14 -to MEM3\_DQ[42]

PIN\_CF15 -to MEM3\_DQ[43]

PIN\_CE10 -to MEM3\_DQ[44]

PIN\_CH11 -to MEM3\_DQ[45]

PIN\_CF11 -to MEM3\_DQ[46]

PIN\_CG10 -to MEM3\_DQ[47]

PIN\_CM7 -to MEM3\_DQ[48]

PIN\_CN8 -to MEM3\_DQ[49]

PIN\_CK7 -to MEM3\_DQ[50]

PIN\_CL8 -to MEM3\_DQ[51]

PIN\_CK3 -to MEM3\_DQ[52]

PIN\_CN4 -to MEM3\_DQ[53]

PIN\_CL4 -to MEM3\_DQ[54]

PIN\_CM3 -to MEM3\_DQ[55]

PIN\_CH7 -to MEM3\_DQ[56]

PIN\_CF7 -to MEM3\_DQ[57]

PIN\_CE8 -to MEM3\_DQ[58]

PIN\_CG8 -to MEM3\_DQ[59]

PIN\_CE4 -to MEM3\_DQ[60]

PIN\_CG4 -to MEM3\_DQ[61]

PIN\_CH3 -to MEM3\_DQ[62]

PIN\_CF3 -to MEM3\_DQ[63]

PIN\_CM21 -to MEM3\_DQ[64]

PIN\_CN22 -to MEM3\_DQ[65]

PIN\_CK21 -to MEM3\_DQ[66]

PIN\_CL22 -to MEM3\_DQ[67]

PIN\_CK17 -to MEM3\_DQ[68]

PIN\_CL18 -to MEM3\_DQ[69]

PIN\_CN18 -to MEM3\_DQ[70]

PIN\_CM17 -to MEM3\_DQ[71]

PIN\_CM27 -to MEM3\_DQS[0]

PIN\_CK27 -to MEM3\_DQS\_N[0]

PIN\_CH27 -to MEM3\_DQS[1]

PIN\_CF27 -to MEM3\_DQS\_N[1]

PIN\_CG20 -to MEM3\_DQS[2]

PIN\_CE20 -to MEM3\_DQS\_N[2]

PIN\_DB27 -to MEM3\_DQS[3]

PIN\_CY27 -to MEM3\_DQS\_N[3]

PIN\_CM13 -to MEM3\_DQS[4]

PIN\_CK13 -to MEM3\_DQS\_N[4]

PIN\_CH13 -to MEM3\_DQS[5]

PIN\_CF13 -to MEM3\_DQS\_N[5]

PIN\_CN6 -to MEM3\_DQS[6]

PIN\_CL6 -to MEM3\_DQS\_N[6]

PIN\_CG6 -to MEM3\_DQS[7]

PIN\_CE6 -to MEM3\_DQS\_N[7]

PIN\_CN20 -to MEM3\_DQS[8]

PIN\_CL20 -to MEM3\_DQS\_N[8]

PIN\_CN26 -to MEM3\_DBI\_N[0]

PIN\_CG26 -to MEM3\_DBI\_N[1]

PIN\_CH19 -to MEM3\_DBI\_N[2]

PIN\_DC26 -to MEM3\_DBI\_N[3]

PIN\_CN12 -to MEM3\_DBI\_N[4]

PIN\_CG12 -to MEM3\_DBI\_N[5]

PIN\_CM5 -to MEM3\_DBI\_N[6]

PIN\_CH5 -to MEM3\_DBI\_N[7]

PIN\_CM19 -to MEM3\_DBI\_N[8]

PIN\_DA10 -to MEM3\_PAR[0]

PIN\_CY15 -to MEM3\_RESET\_N[0]

PIN\_DB7 -to OCT\_RZQIN3

# FDAS DDR Controller Simulation

## Generation of DDR4 SDRAM Simulation Model

In order to simulate the FDAS\_DDR\_CONTROLLER/ FDAS\_DDR\_CONTROLLER\_HPS it is necessary to have a realistic simulation model of the External DDR SDRAM.

This can be generated by using pressing the “Create Example Design” button in the Intel Quartus Prime Platform Designer window for the FDAS\_DDR\_CONTROLLER/ FDAS\_DDR\_CONTROLLER\_HPS, ensuring that in the “Example Designs” tab that the simulation HDL format is set to VHDL. (The name can left as emif\_0\_example\_design)

This shall generate a set of components that can aid simulation, one of them being the simulation model for the external memory.

The design is written to a directory “emif\_0\_example\_design” in the location chosen for the project.

## Creating Simulation Compile Script

This description assumes that relevant files are copied to a “simulation area”.

The steps are:-

1. Copy the complete directory containing the “FDAS\_DDR\_CONTROLLER” / “FDAS\_DDR\_CONTROLLER\_HPS” and “FDAS\_EMIF\_CALIBRATION” directories generated by Platform Designer to the “simulation area”.
2. Copy the “ed\_sim\_mem” directory residing in the “emif\_0\_example\_design/sim/ip/ed\_sim” directory generated by Platform Designer to the “simulation area”.
3. Use the “msim\_setup.tcl” file from the directory “sim/mentor” within the complete “FDAS\_DDR\_CONTROLLER” / “FDAS\_DDR\_CONTROLLER\_HPS” directory, and the “msim\_setup.tcl” file from the directory “sim/mentor” within the “ed\_sim\_mem”directory to create a compile script for the simulation, for example “modelsim\_script\_ddrif2\_ddr\_controller\_ddr\_memory.tcl”
4. Launch Modelsim Questa and change the directory to the “simulation area”.
5. In the GUI type “source modelsim\_script\_ddrif2\_ddr\_controller\_ddr\_memory.tcl” to run the compile script.
6. Once compiled run the test bench using normal methods

# FDAS\_DDR\_CONTROLLER\_CALIBRATION Architecture for DDR Channels 2 and 3

The FDAS\_DDR\_CONTROLLER\_CALIBRATION VHDL Wrapper contains the FDAS\_DDR\_CONTROLLER and FDAS\_EMIF\_CALIBRATION Intel Agilex IP Blocks.

**FDAS\_DDR\_**

**CONTROLLER**

**Intel**

**Agilex IP**

**Block**

PLL\_REF\_CLK\_2\_I

LOCAL\_RESET\_REQ\_2\_I

LOCAL\_RESET\_DONE\_2\_O

LOCAL\_CAL\_SUCCESS\_2\_O

LOCAL\_CAL\_FAIL\_2\_O

EMIF\_USR\_CLK\_2\_O

EMIF\_USER\_RESET\_N\_2\_O

AMM\_READY\_2\_O

AMM\_READ\_2\_I

AMM\_WRITE\_2\_I

AMM\_ADDRESS\_2\_I[25:0]

AMM\_READDATA\_2\_O[511:0]

AMM\_WRITEDATA\_2\_I[511:0]

AMM\_BURSTCOUNT\_2\_I[6:0]

AMM\_BYTEENABLE\_2\_I[63:0]

AMM\_READDATAVALID\_2\_O

**FDAS\_DDR\_CONTROLLER\_CALIBRATION**

External Reference Clock 33.333MHz

pll\_ref\_clk

local\_reset\_req

local\_reset\_done

local\_cal\_success

local\_cal\_fail

emif\_usr\_clk

emif\_usr\_reset\_n

amm\_ready\_0

amm\_read\_0

amm\_write\_0

amm\_address\_0[25:0]

amm\_readdata\_0[511:0]

amm\_writedata\_0[511:0]

amm\_burstcount\_0[6:0]

amm\_byteenable\_0[63:0]

amm\_readdatavalid\_0

amm\_readdata\_0[575:512]

amm\_address\_0[26]

amm\_writedata\_0[575:512]

amm\_byteenable\_0[71:64]

mem\_ck

mem\_ck\_n

mem\_a[16:0]

mem\_act\_n

mem\_ba[1:0]

mem\_bg[1:0]

mem\_cke

mem\_cs\_n

mem\_odt

mem\_reset\_n

mem\_par

mem\_alert\_n

mem\_dqs[8:0]

mem\_dqs\_n[8:0]

mem\_dq[71:0]

mem\_dbi\_n

oct\_rzqin

MEM2\_CK\_O

MEM2\_CK\_N\_O

MEM2\_A\_O[16:0]

MEM2\_ACT\_N\_O

MEM2\_BA\_O[1:0]

MEM2\_BG\_O[1:0]

MEM2\_CKE\_O

MEM2\_CS\_N\_O

MEM2\_ODT\_O

MEM2\_RESET\_N\_O

MEM2\_PAR\_O

MEM2\_ALERT\_N\_I

MEM2\_DQS\_IO[8:0]

MEM2\_DQS\_N\_IO[8:0]

MEM2\_DQ\_IO[71:0]

MEM2\_DBI\_N\_IO

OCT\_RZQIN2\_I

External DDR4 SDRAM Interface

Internal Interface to

DDRIF2 module

Internal Interface to

MCI\_TOP module

calbus\_read

calbus\_write

calbus\_address[19:0]

calbus\_wdata[31:0]

calbus\_rdata[31:0

calbus\_seq\_param\_tbl[4095:0]

calbus\_clk

‘0’

**FDAS\_DDR\_**

**CONTROLLER**

**Intel**

**Agilex IP**

**Block**

PLL\_REF\_CLK\_3\_I

LOCAL\_RESET\_REQ\_3\_I

LOCAL\_RESET\_DONE\_3\_O

LOCAL\_CAL\_SUCCESS\_3\_O

LOCAL\_CAL\_FAIL\_3\_O

EMIF\_USR\_CLK\_3\_O

EMIF\_USER\_RESET\_N\_3\_O

AMM\_READY\_3\_O

AMM\_READ\_3\_I

AMM\_WRITE\_3\_I

AMM\_ADDRESS\_3\_I[25:0]

AMM\_READDATA\_3\_O[511:0]

AMM\_WRITEDATA\_3\_I[511:0]

AMM\_BURSTCOUNT\_3\_I[6:0]

AMM\_BYTEENABLE\_3\_I[63:0]

AMM\_READDATAVALID\_3\_O

pll\_ref\_clk

local\_reset\_req

local\_reset\_done

local\_cal\_success

local\_cal\_fail

emif\_usr\_clk

emif\_usr\_reset\_n

amm\_ready\_0

amm\_read\_0

amm\_write\_0

amm\_address\_0[25:0]

amm\_readdata\_0[511:0]

amm\_writedata\_0[511:0]

amm\_burstcount\_0[6:0]

amm\_byteenable\_0[63:0]

amm\_readdatavalid\_0

 amm\_readdata\_0[575:512]

amm\_address\_0[26]

amm\_writedata\_0[575:512]

amm\_byteenable\_0[71:64]

mem\_ck

mem\_ck\_n

mem\_a[16:0]

mem\_act\_n

mem\_ba[1:0]

mem\_bg[1:0]

mem\_cke

mem\_cs\_n

mem\_odt

mem\_reset\_n

mem\_par

mem\_alert\_n

mem\_dqs[8:0]

mem\_dqs\_n[8:0]

mem\_dq[71:0]

mem\_dbi\_n

oct\_rzqin

MEM3\_CK\_O

MEM3\_CK\_N\_O

MEM3\_A\_O[16:0]

MEM3\_ACT\_N\_O

MEM3\_BA\_O[1:0]

MEM3\_BG\_O[1:0]

MEM3\_CKE\_O

MEM3\_CS\_N\_O

MEM3\_ODT\_O

MEM3\_RESET\_N\_O

MEM3\_PAR\_O

MEM3\_ALERT\_N\_I

MEM3\_DQS\_IO[8:0]

MEM3\_DQS\_N\_IO[8:0]

MEM3\_DQ\_IO[71:0]

MEM3\_DBI\_N\_IO

OCT\_RZQIN3\_I

Internal Interface to

DDRIF2 module

Internal Interface to

MCI\_TOP module

calbus\_clk

calbus\_read

calbus\_write

calbus\_address[19:0]

calbus\_wdata[31:0]

calbus\_rdata[31:0

calbus\_seq\_param\_tbl[4095:0]

External Reference Clock 33.333MHz

External DDR4 SDRAM Interface

**FDAS\_EMIF\_**

**CALIBRATION**

**Intel Agilex**

**IP Block**

calbus\_read\_0

calbus\_write\_0

calbus\_address\_0[19:0]

calbus\_wdata\_0[31:0]

calbus\_rdata\_0[31:0

calbus\_seq\_param\_tbl\_0[4095:0]

calbus\_clk

calbus\_read\_1

calbus\_write\_1

calbus\_address\_1[19:0]

calbus\_wdata\_1[31:0]

calbus\_rdata\_1[31:0

calbus\_seq\_param\_tbl\_1[4095:0]

calbus\_clk\_1

‘0’s

‘0’s

‘0’

‘0’s

‘0’s

Figure ‑: FDAS\_DDR\_CONTROLLER\_CALIBRATION Wrapper

# FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS Architecture for DDR Channels 0 and 1

The FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS VHDL Wrapper contains the FDAS\_DDR\_CONTROLLER, FDAS\_DDR\_CONTROLLER\_HPS and FDAS\_EMIF\_CALIBRATION Intel Agilex IP Blocks.

**FDAS\_EMIF\_**

**CALIBRATION**

**Intel Agilex**

**IP Block**

**FDAS\_DDR\_**

**CONTROLLER**

**Intel**

**Agilex IP**

**Block**

PLL\_REF\_CLK\_0\_I

LOCAL\_RESET\_REQ\_0\_I

LOCAL\_RESET\_DONE\_0\_O

LOCAL\_CAL\_SUCCESS\_0\_O

LOCAL\_CAL\_FAIL\_0\_O

EMIF\_USR\_CLK\_0\_O

EMIF\_USER\_RESET\_N\_0\_O

AMM\_READY\_0\_O

AMM\_READ\_0\_I

AMM\_WRITE\_0\_I

AMM\_ADDRESS\_0\_I[25:0]

AMM\_READDATA\_0\_O[511:0]

AMM\_WRITEDATA\_0\_I[511:0]

AMM\_BURSTCOUNT\_0\_I[6:0]

AMM\_BYTEENABLE\_0\_I[63:0]

AMM\_READDATAVALID\_0\_O

**FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS**

External Reference Clock 33.333MHz

pll\_ref\_clk

local\_reset\_req

local\_reset\_done

local\_cal\_success

local\_cal\_fail

emif\_usr\_clk

emif\_usr\_reset\_n

amm\_ready\_0

amm\_read\_0

amm\_write\_0

amm\_address\_0[25:0]

amm\_readdata\_0[511:0]

amm\_writedata\_0[511:0]

amm\_burstcount\_0[6:0]

amm\_byteenable\_0[63:0]

amm\_readdatavalid\_0

amm\_readdata\_0[575:512]

amm\_address\_0[26]

amm\_writedata\_0[575:512]

amm\_byteenable\_0[71:64]

mem\_ck

mem\_ck\_n

mem\_a[16:0]

mem\_act\_n

mem\_ba[1:0]

mem\_bg[1:0]

mem\_cke

mem\_cs\_n

mem\_odt

mem\_reset\_n

mem\_par

mem\_alert\_n

mem\_dqs[8:0]

mem\_dqs\_n[8:0]

mem\_dq[71:0]

mem\_dbi\_n

oct\_rzqin

MEM0\_CK\_O

MEM0\_CK\_N\_O

MEM0\_A\_O[16:0]

MEM0\_ACT\_N\_O

MEM0\_BA\_O[1:0]

MEM0\_BG\_O[1:0]

MEM0\_CKE\_O

MEM0\_CS\_N\_O

MEM0\_ODT\_O

MEM0\_RESET\_N\_O

MEM0\_PAR\_O

MEM0\_ALERT\_N\_I

MEM0\_DQS\_IO[8:0]

MEM0\_DQS\_N\_IO[8:0]

MEM0\_DQ\_IO[71:0]

MEM0\_DBI\_N\_IO

OCT\_RZQIN0\_I

External DDR4 SDRAM Interface

Internal Interface to

DDRIF2 module

Internal Interface to

MCI\_TOP module

calbus\_read\_0

calbus\_write\_0

calbus\_address\_0[19:0]

calbus\_wdata\_0[31:0]

calbus\_rdata\_0[31:0

calbus\_seq\_param\_tbl\_0[4095:0]

calbus\_clk

calbus\_read

calbus\_write

calbus\_address[19:0]

calbus\_wdata[31:0]

calbus\_rdata[31:0

calbus\_seq\_param\_tbl[4095:0]

calbus\_clk

calbus\_read\_1

calbus\_write\_1

calbus\_address\_1[19:0]

calbus\_wdata\_1[31:0]

calbus\_rdata\_1[31:0

calbus\_seq\_param\_tbl\_1[4095:0]

calbus\_clk\_1

**FDAS\_DDR\_**

**CONTROLLER\_HPS**

**Intel**

**Agilex IP**

**Block**

PLL\_REF\_CLK\_1\_I

LOCAL\_RESET\_REQ\_1\_I

LOCAL\_RESET\_DONE\_1\_O

LOCAL\_CAL\_SUCCESS\_1\_O

LOCAL\_CAL\_FAIL\_1\_O

EMIF\_USR\_CLK\_1\_O

EMIF\_USER\_RESET\_N\_1\_O

AMM\_READY\_1\_O

AMM\_READ\_1\_I

AMM\_WRITE\_1\_I

AMM\_ADDRESS\_1\_I[25:0]

AMM\_READDATA\_1\_O[511:0]

AMM\_WRITEDATA\_1\_I[511:0]

AMM\_BURSTCOUNT\_1\_I[6:0]

AMM\_BYTEENABLE\_1\_I[63:0]

AMM\_READDATAVALID\_1\_O

pll\_ref\_clk

local\_reset\_req

local\_reset\_done

local\_cal\_success

local\_cal\_fail

emif\_usr\_clk

emif\_usr\_reset\_n

amm\_ready\_0

amm\_read\_0

amm\_write\_0

amm\_address\_0[25:0]

amm\_readdata\_0[511:0]

amm\_writedata\_0[511:0]

amm\_burstcount\_0[6:0]

amm\_byteenable\_0[63:0]

amm\_readdatavalid\_0

amm\_address\_0[26]

mem\_ck

mem\_ck\_n

mem\_a[16:0]

mem\_act\_n

mem\_ba[1:0]

mem\_bg[1:0]

mem\_cke

mem\_cs\_n

mem\_odt

mem\_reset\_n

mem\_par

mem\_alert\_n

mem\_dqs[8:0]

mem\_dqs\_n[8:0]

mem\_dq[71:0]

mem\_dbi\_n

oct\_rzqin

MEM1\_CK\_O

MEM1\_CK\_N\_O

MEM1\_A\_O[16:0]

MEM1\_ACT\_N\_O

MEM1\_BA\_O[1:0]

MEM1\_BG\_O[1:0]

MEM1\_CKE\_O

MEM1\_CS\_N\_O

MEM1\_ODT\_O

MEM1\_RESET\_N\_O

MEM1\_PAR\_O

MEM1\_ALERT\_N\_I

MEM1\_DQS\_IO[8:0]

MEM1\_DQS\_N\_IO[8:0]

MEM1\_DQ\_IO[71:0]

MEM1\_DBI\_N\_IO

OCT\_RZQIN1\_I

Internal Interface to

DDRIF2 module

Internal Interface to

MCI\_TOP module

calbus\_ckk

calbus\_read

calbus\_write

calbu\_address[19:0]

calbus\_wdata[31:0]

calbus\_rdata[31:0

calbus\_seq\_param\_tbl[4095:0]

External Reference Clock 33.333MHz

External DDR4 SDRAM Interface

‘0’

‘0’s

‘0’s

‘0’

Figure ‑: FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS Wrapper

# Design Requirement Tags

The relevant design tags from the FDAS Design Specification Document for the DDR\_CONTROLLER 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: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. |

Table 7‑1 : DDR Controller Design Requirement Tags

# Interface Specifications

## FDAS\_DDR\_CONTROLLER IP Component

| Signal | Direction | Clock Domain | Description |
| --- | --- | --- | --- |
| **Interface to DDRIF2** |  |  |  |
| amm\_ready\_0 | OUT | emif\_usr\_clk | Indication that the DDR Controller is ready. This is inverted when it is passed to the DDRIF2 module which uses the Avalon MM Wait\_Request signal. |
| amm\_write\_0 | IN | emif\_usr\_clk | Write Request from the DDRIF2 module. |
| amm\_read\_0 | IN | emif\_usr\_clk | Read Request from the DDRIF2 module. |
| amm\_address\_0[26:0] | IN | emif\_usr\_clk | DDR SDRAM Memory address from the DDRIF2 module.  Since each DDR SDRAM memory location contains a 64-byte word in this case only bits [31:6] of the address from the DDRIF2 module map to amm\_address\_0[25:0] .  Note that within the wrapper bit[26] of the address to the DDR Controller is set to 0 This is because the DDR Controller supports the 8GB SDRAM but FDAS only uses 4GB. |
| amm\_writedata\_0[575:0] | IN | emif\_usr\_clk | Write Data from the DDRIF2 module. Only bits [511:0] are used, hence bits [575:512] are set to 0. |
| amm\_burstcount\_0[6:0] | IN | emif\_usr\_clk | This is set to “0000001” by DDRIF2 as the DDRIF2 module terminates the data bursts. |
| amm\_byteenable\_0[71:0] | IN | emif\_usr\_clk | Bits[63:0] are the Byte Enables for amm\_writedata\_0[511:0] .  Bits[71:64] are set to ‘0 as they are unused. |
| amm\_readdata\_0[575:0] | OUT | emif\_usr\_clk | Read Data to the DDRIF2 module. Only bits [511:0] are used. |
| amm\_readdatavalid\_0 | OUT | emif\_usr\_clk | Read Data Valid indication to the DDRIF2 module. |
|  |  |  |  |
| **Interface to External SDRAM** |  |  |  |
| mem\_ck | OUT | - | Clock (True) to External SDRAM. 1333.333MHz in this application. |
| mem\_ck\_n | OUT | - | Clock (Compliment) to External SDRAM. 1333.333MHz in this application. |
| mem\_a[16:0] | OUT | mem\_ck | Row Address for ACTIVATE commands/ Col Address for READ/WRITE Commands to External DDR4 SDRAM UDIMM.  Dual Use  A[10]: Auto Precharge  A[12]: Burst Chop  A[14]: WE Command  A[15]: CAS Command  A[16]: RAS Command |
| mem\_act\_n | OUT | mem\_ck | ACTIVATE Command to External DDR4 SDRAM UDIMM. |
| mem\_ba[1:0] | OUT | mem\_ck | Bank within the Bank Group to which REFRESH, ACTIVATE, READ or WRITE command is being applied. Connection to External DDR4 SDRAM UDIMM. |
| mem\_bg[1:0] | OUT | mem\_ck | Bank Group to which REFRESH, ACTIVATE, READ or WRITE command is being applied. Connection to External DDR4 SDRAM UDIMM. |
| mem\_cke | OUT | mem\_ck | Clock Enable to External DDR4 SDRAM UDIMM. |
| mem\_cs\_n | OUT | mem\_ck | Chip Select to External DDR4 SDRAM UDIMM. |
| mem\_odt | OUT | mem\_ck | On Die Termination. |
| mem\_reset\_n | OUT | mem\_ck | Reset (Active Low) to the External DDR4 SDRAM UDIMM. |
| mem\_par | OUT | mem\_ck | Parity for Command and Address to the External DDR4 SDRAM UDIMM. |
| mem\_alert\_n | IN | mem\_ck | ALERT from the DDR4 SDRAM UDIMM to the DDR Controller. |
| mem\_dqs[8:0] | IN/OUT | mem\_ck | Data Strobe (True) to External DDR4 SDRAM UDIMM. Output with READ data, Input with WRITE data.  Strobe per Byte, with a Byte per Micron Device. |
| mem\_dqs\_n[8:0] | IN/OUT | mem\_ck | Data Strobe (Compliment) to External DDR4 SDRAM UDIMM. Output with READ data, Input with WRITE data.  Strobe per Byte, with a Byte per Micron Device. |
| mem\_dq[71:0] | IN/OUT | mem\_ck | Data Input/Output to External DDR4 SDRAM UDIMM. |
| mem\_dbi\_n[8:0] | IN/OUT | mem\_ck | Data Bus Inversion to External DDR4 SDRAM UDIMM. |
| oct\_rzqin | IN | mem\_ck | Reference for ZQ calibration from External DDR4 SDRAM UDIMM. |
|  |  |  |  |
| **Indication Signals** |  |  |  |
| local\_cal\_success | IN | mem\_ck | External DDR4 SDRAM UDIMM is successful. |
| local\_cal\_fail | IN | mem\_ck | External DDR4 SDRAM UDIMM has failed. |
|  |  |  |  |
|  |  |  |  |
| **Global Clock/Resets** |  |  |  |
| emif\_usr\_clk | OUT | - | This is the CLK\_DDR generated by the DDR\_CONTROLLER to be used by the DDRIF2 module.  It shall be 333.333MHz in this application. |
| emif\_usr\_reset\_n | OUT | CLK\_DDR | Reset (active low) generated by the DDR\_CONTROLLER for the DDRIF2 module. |
| local\_reset\_req | IN | - | Signal from user logic to request the memory interface to be reset and recalibrated. Reset request is sent by transitioning the local\_reset\_req signal from low to high, then keeping the signal at the high state for a minimum of 2 EMIF core clock cycles, then transitioning the signal from high to low. local\_reset\_req is asynchronous in that there is no setup/hold timing to meet, but it must meet the minimum pulse width requirement of 2 EMIF core clock cycles. |
| local\_reset\_done | OUT | - | Signal from memory interface to indicate whether it has completed a reset sequence, is currently out of reset, and is ready for a new reset request. When local\_reset\_done is low, the memory interface is in reset. |
| pll\_ref\_clk | IN | - | PLL Reference Clock into the DDR\_CONTROLLER. (33.33MHz) |
|  |  |  |  |
| **Calibration Interface** |  |  |  |
| calbus\_read | IN | calbus\_clk | Calibration bus Read control from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_write | IN | calbus\_clk | Calibration bus Write control from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_address[19:0] | IN | calbus\_clk | Calibration bus Address from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_wdata[31:0] | IN | calbus\_clk | Calibration bus Write Data from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_rdata[31:0] | OUT | calbus\_clk | Calibration bus Read Data to FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_seq\_param\_tbl[4094:0] | OUT | calbus\_clk | Calibration bus Parameter Table to FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_clk | IN | - | Calibration bus clock |

Table 8‑1 : FDAS\_DDR\_CONTROLLER IP Component Pinout

## FDAS\_DDR\_CONTROLLER\_HPS IP Component

| Signal | Direction | Clock Domain | Description |
| --- | --- | --- | --- |
| **Interface to DDRIF2** |  |  |  |
| amm\_ready\_0 | OUT | emif\_usr\_clk | Indication that the DDR Controller is ready. This is inverted when it is passed to the DDRIF2 module which uses the Avalon MM Wait\_Request signal. |
| amm\_write\_0 | IN | emif\_usr\_clk | Write Request from the DDRIF2 module. |
| amm\_read\_0 | IN | emif\_usr\_clk | Read Request from the DDRIF2 module. |
| amm\_address\_0[26:0] | IN | emif\_usr\_clk | DDR SDRAM Memory address from the DDRIF2 module.  Since each DDR SDRAM memory location contains a 64-byte word in this case only bits [31:6] of the address from the DDRIF2 module map to amm\_address\_0[25:0] .  Note that within the wrapper bit[26] of the address to the DDR Controller is set to 0 This is because the DDR Controller supports the 8GB SDRAM but FDAS only uses 4GB. |
| amm\_writedata\_0[511:0] | IN | emif\_usr\_clk | Write Data from the DDRIF2 module. |
| amm\_burstcount\_0[6:0] | IN | emif\_usr\_clk | This is set to “0000001” by DDRIF2 as the DDRIF2 module terminates the data bursts. |
| amm\_byteenable\_0[63:0] | IN | emif\_usr\_clk | Bits[63:0] are the Byte Enables for amm\_writedata\_0[511:0]. |
| amm\_readdata\_0[511:0] | OUT | emif\_usr\_clk | Read Data to the DDRIF2 module. |
| amm\_readdatavalid\_0 | OUT | emif\_usr\_clk | Read Data Valid indication to the DDRIF2 module. |
|  |  |  |  |
| **Interface to External SDRAM** |  |  |  |
| mem\_ck | OUT | - | Clock (True) to External SDRAM. 1333.333MHz in this application. |
| mem\_ck\_n | OUT | - | Clock (Compliment) to External SDRAM. 1333.333MHz in this application. |
| mem\_a[16:0] | OUT | mem\_ck | Row Address for ACTIVATE commands/ Col Address for READ/WRITE Commands to External DDR4 SDRAM UDIMM.  Dual Use  A[10]: Auto Precharge  A[12]: Burst Chop  A[14]: WE Command  A[15]: CAS Command  A[16]: RAS Command |
| mem\_act\_n | OUT | mem\_ck | ACTIVATE Command to External DDR4 SDRAM UDIMM. |
| mem\_ba[1:0] | OUT | mem\_ck | Bank within the Bank Group to which REFRESH, ACTIVATE, READ or WRITE command is being applied. Connection to External DDR4 SDRAM UDIMM. |
| mem\_bg[1:0] | OUT | mem\_ck | Bank Group to which REFRESH, ACTIVATE, READ or WRITE command is being applied. Connection to External DDR4 SDRAM UDIMM. |
| mem\_cke | OUT | mem\_ck | Clock Enable to External DDR4 SDRAM UDIMM. |
| mem\_cs\_n | OUT | mem\_ck | Chip Select to External DDR4 SDRAM UDIMM. |
| mem\_odt | OUT | mem\_ck | On Die Termination. |
| mem\_reset\_n | OUT | mem\_ck | Reset (Active Low) to the External DDR4 SDRAM UDIMM. |
| mem\_par | OUT | mem\_ck | Parity for Command and Address to the External DDR4 SDRAM UDIMM. |
| mem\_alert\_n | IN | mem\_ck | ALERT from the DDR4 SDRAM UDIMM to the DDR Controller. |
| mem\_dqs[8:0] | IN/OUT | mem\_ck | Data Strobe (True) to External DDR4 SDRAM UDIMM. Output with READ data, Input with WRITE data.  Strobe per Byte, with a Byte per Micron Device. |
| mem\_dqs\_n[8:0] | IN/OUT | mem\_ck | Data Strobe (Compliment) to External DDR4 SDRAM UDIMM. Output with READ data, Input with WRITE data.  Strobe per Byte, with a Byte per Micron Device. |
| mem\_dq[71:0] | IN/OUT | mem\_ck | Data Input/Output to External DDR4 SDRAM UDIMM. |
| mem\_dbi\_n[8:0] | IN/OUT | mem\_ck | Data Bus Inversion to External DDR4 SDRAM UDIMM. |
| oct\_rzqin | IN | mem\_ck | Reference for ZQ calibration from External DDR4 SDRAM UDIMM. |
|  |  |  |  |
| **Indication Signals** |  |  |  |
| local\_cal\_success | IN | mem\_ck | External DDR4 SDRAM UDIMM is successful. |
| local\_cal\_fail | IN | mem\_ck | External DDR4 SDRAM UDIMM has failed. |
|  |  |  |  |
|  |  |  |  |
| **Global Clock/Resets** |  |  |  |
| emif\_usr\_clk | OUT | - | This is the CLK\_DDR generated by the DDR\_CONTROLLER to be used by the DDRIF2 module.  It shall be 333.333MHz in this application. |
| emif\_usr\_reset\_n | OUT | CLK\_DDR | Reset (active low) generated by the DDR\_CONTROLLER for the DDRIF2 module. |
| local\_reset\_req | IN | - | Signal from user logic to request the memory interface to be reset and recalibrated. Reset request is sent by transitioning the local\_reset\_req signal from low to high, then keeping the signal at the high state for a minimum of 2 EMIF core clock cycles, then transitioning the signal from high to low. local\_reset\_req is asynchronous in that there is no setup/hold timing to meet, but it must meet the minimum pulse width requirement of 2 EMIF core clock cycles. |
| local\_reset\_done | OUT | - | Signal from memory interface to indicate whether it has completed a reset sequence, is currently out of reset, and is ready for a new reset request. When local\_reset\_done is low, the memory interface is in reset. |
| pll\_ref\_clk | IN | - | PLL Reference Clock into the DDR\_CONTROLLER. (33.33MHz) |
|  |  |  |  |
| **Calibration Interface** |  |  |  |
| calbus\_read | IN | calbus\_clk | Calibration bus Read control from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_write | IN | calbus\_clk | Calibration bus Write control from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_address[19:0] | IN | calbus\_clk | Calibration bus Address from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_wdata[31:0] | IN | calbus\_clk | Calibration bus Write Data from FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_rdata[31:0] | OUT | calbus\_clk | Calibration bus Read Data to FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_seq\_param\_tbl[4094:0] | OUT | calbus\_clk | Calibration bus Parameter Table to FDAS\_EMIF\_CALIBRATION IP Component |
| calbus\_clk | IN | - | Calibration bus clock |

Table 8‑2 : FDAS\_DDR\_CONTROLLER\_HPS IP Component Pinout

## FDAS\_EMIF\_CALIBRATION IP Component

| Signal | Direction | Clock Domain | Description |
| --- | --- | --- | --- |
| **Calibration Interface** |  |  |  |
| calbus\_read\_0 | OUT | calbus\_clk | Calibration bus Read control to FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_write\_0 | OUT | calbus\_clk | Calibration bus Write control to FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_address\_0[19:0] | OUT | calbus\_clk | Calibration bus Address to FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_wdata\_0[31:0] | OUT | calbus\_clk | Calibration bus Write Data to FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_rdata\_0[31:0] | IN | calbus\_clk | Calibration bus Read Data from FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_seq\_param\_tbl\_0[4094:0] | IN | calbus\_clk | Calibration bus Parameter from FDAS\_DDR\_CONTROLLER IP Component |
| calbus\_clk\_0 | OUT | - | Calibration bus clock |

Table 8‑3 : FDAS\_EMIF\_CALIBRATION IP Component Pinout

# MCI Memory Mapped Interface

The FDAS\_DDR\_CONTROLLER\_CALIBRATION and FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS modules do not have a memory mapped interface.

# Design Parameterisation

The FDAS\_DDR\_CONTROLLER\_CALIBRATION and FDAS\_DDR\_CONTROLLER\_CALIBRATION\_HPS modules do 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. |
| [Ref: Agilex Development Board] | AgilexF\_FPGA\_DK\_2V\_ES.pdf containing:-  AgileX F-Series FPGA Dev Kit\_Enpirion schematics  Document Number: K57065-001-A  Date: Thursday, May 07, 2020 | Intel Agilex F Development Board schematics. This board is fitted with an Agilex AGFB014R24A2E2VR0 FPGA. The board supports a PCIe interface and four DDR4 SDRAM interfaces. |

# Abbreviations and Acronyms

|  |  |
| --- | --- |
| 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 |
| HPS | Hard Processor Sub-System |
| IP | Intellectual Property |
| MC | Micro Controller Interface |
| MSI-X | Extended Message Signalled Interrupt |
| PCIe | Peripheral Component Interconnect Express |
| SDRAM | Synchronous Dynamic RAM |
| TLP | Transaction Layer Packet |