

October 3, 2019, Rev. -

## **General Description**

The 7 Series DDRx (Native-Limited) DO-254 Certifiable Data Package is made up of the artifacts produced by applying the DO-254 lifecycle to the Xilinx® AXI 7 Series DDRx IP v1.07a and an encrypted version of the source code. This includes the following completed documents:

- Plan for Hardware Aspects of Certification
- Hardware Validation and Verification Plan
- Hardware Configuration Management Plan
- Hardware Design Plan
- Hardware Process Assurance Plan
- Hardware Validation and Verification
  Standard
- Hardware Requirements Standard
- Hardware Design Standard
- Hardware Requirements Document
- Hardware Design Document
- Hardware Configuration Index (includes Hardware Lifecycle Environment Configuration Index)
- Verification Configuration Index
- Hardware Test Procedures
- Hardware Verification Results
- Hardware Elemental Analysis Results
- Hardware Requirements Traceability
  Matrix
- Hardware Accomplishment Summary

The above documents are available for certification efforts, however not all documents are included in the delivery package.

The DO-254 7 Series DDRx (Native-Limited) IP Core 1.00a, created and designed by Logicircuit, is a combined pre-engineered controller and

physical layer (PHY) for interfacing 7 series FPGA user designs and native interfaces to DDR3 and DDR2 SDRAM devices.

This version of the DO-254 7 Series DDRx (Native-Limited) IP includes the following builtin safety features:

• Error Correcting Code (ECC), for DDR3 memories with 72 bits data width.

#### Features

- Component support for interface widths up to 64 bits (supports up to 64 bits in data width, and an additional 8 bits in Error Code Correction [ECC] width when ECC is enabled)
- DDR3 (1.5 V) and DDR3L (1.35 V)
- 1, 2, and 4 Gb density device support
- 8-bank support
- x8 and x16 device support
- 8:1 DQ:DQS ratio support
- Configurable data bus widths (doubles from 8, up to 72 bits)
- 8-word burst support
- Support for 5 to 13 cycles of columnaddress strobe (CAS) latency (CL)
- On-die termination (ODT) support
- Support for 5 to 9 cycles of CAS write latency
- Write leveling support for DDR3 (fly-by routing topology required for DDR3 component designs)
- JEDEC-compliant DDR3 initialization support
- 4:1 and 2:1 memory to FPGA logic interface clock ratio
- ECC support
- I/O Power Reduction option reduces average I/O power by automatically disabling DQ/DQS IBUFs and internal



terminations during writes and periods of inactivity

- Internal VREF support
- Two controller request processing modes:
  - Normal: reorder requests to optimize system throughput and latency
  - Strict: memory requests are processed in the order received

DDR3 SDRAM specific features:

- ECC support
- Configurable data bus widths (doubles from 8, up to 72 bits)
- Support for 5 to 13 cycles of columnaddress strobe (CAS) latency (CL)
- Support for 5 to 9 cycles of CAS write latency
- JEDEC-compliant DDR3 initialization support

DDR2 SDRAM specific features:

- Component support for interface widths up to 64 bits (ECC is not available in DDR2 memories)
- Configurable data bus widths (doubles from 8, up to 64 bits)
- Support for 3 to 5 cycles of column address strobe (CAS) latency
- JEDEC-compliant DDR2 initialization support

## **Block Diagram**



#### **Supported FPGA Families**

Xilinx<sup>®</sup> 7-Series

### **Development Tools**

Xilinx<sup>®</sup> ISE<sup>®</sup> 14.4 or later ModelSim<sup>®</sup> v10.1c or later Xilinx<sup>®</sup> Vivado<sup>®</sup> 2019.1 or later

## Configuration

The DO-254 7 Series DDRx (Native-Limited) 1.00a is configurable as shown below:

| Parameter Name  | Description                                                                                                             |
|-----------------|-------------------------------------------------------------------------------------------------------------------------|
| C_ADDR_CMD_MODE | This is used by the<br>controller to<br>calculate timing on<br>the memory<br>addr/cmd bus.                              |
| C_BANK_WIDTH    | Memory bank<br>address bus width.                                                                                       |
| C_BM_CNT_WIDTH  | This is the number of<br>bits required to<br>index a bank<br>machine and is given<br>by<br>ceil(log2(nBANK_MA<br>CHS)). |
| C_ADDR_WIDTH    | This is the memory address bus width.                                                                                   |
| C_PAYLOAD_WIDTH | This is the actual DQ<br>bus used for user<br>data.                                                                     |
| C_BURST_MODE    | This is the memory<br>data burst length.                                                                                |



| Parameter Name   | Description                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------|
| C_BURST_TYPE     | This is an option for<br>the ordering of<br>accesses within a<br>burst.<br>This is the number of           |
|                  | CK/CK# outputs to memory.                                                                                  |
| C_CL             | This is the read CAS<br>latency. The<br>available option is<br>frequency<br>dependent in the<br>MIG tool.  |
| C_COL_WIDTH      | This is the number of<br>memory column<br>address bits.                                                    |
| C_CMD_PIPE_PLUS1 | This adds pipeline<br>stage between MC<br>and PHY.                                                         |
| C_CS_WIDTH       | This is the number of<br>unique CS outputs to<br>memory.                                                   |
| C_CKE_WIDTH      | This is the number of<br>CKE outputs to<br>memory.                                                         |
| C_CWL            | This is the write CAS<br>latency. The<br>available option is<br>frequency<br>dependent in the<br>MIG tool. |

| Parameter Name                | Description                                                                                                                                             |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_DATA_BUF_ADDR_WID<br>TH     | This is the bus width<br>of the request tag<br>passed to the<br>memory controller.<br>This parameter is set<br>to 5 for 4:1 mode<br>and 4 for 2:1 mode. |
| C_PHY_CONTROL_MASTE<br>R_BANK | This is the bank<br>number where<br>master<br>PHY_CONTROL<br>resides                                                                                    |
| C_DDR2_DQSN_ENABLE            | This enables<br>differential DQS for<br>DDR2.                                                                                                           |
| C_DM_WIDTH                    | This is the number of<br>data mask bits.                                                                                                                |
| C_DQ_WIDTH                    | This is the memory<br>DQ bus width.                                                                                                                     |
| C_DQS_WIDTH                   | This is the memory<br>DQS bus width.                                                                                                                    |
| C_DRAM_TYPE                   | This is the supported<br>memory standard<br>for the memory<br>controller.                                                                               |
| C_DRAM_WIDTH                  | This is the DQ bus<br>width per DRAM<br>component.                                                                                                      |
| C_NBANK_MACHS                 | This is the number of<br>bank machines. A<br>given bank machine<br>manages a single<br>DRAM bank at any<br>given time.                                  |



| Parameter Name            | Description                                                                                 |
|---------------------------|---------------------------------------------------------------------------------------------|
| C_NCK_PER_CLK             | This is the number of<br>memory clocks per<br>clock.                                        |
| C_NCS_PER_RANK            | This is the number of<br>unique CS outputs<br>per rank for the PHY.                         |
| C_ORDERING                | This option reorders<br>received requests to<br>optimize data<br>throughput and<br>latency. |
| C_IODELAY_HP_MODE         | This option enables<br>or disables the<br>IDELAY high-<br>performance mode.                 |
| C_BANK_TYPE               | IO bank type.                                                                               |
| C_DATA_IO_PRIM_TYPE       | Primitive type for IO<br>bank.                                                              |
| C_DATA_IO_IDLE_PWRD<br>WN | Disable/enable the<br>DQ and DQS input<br>buffer.                                           |
| C_IODELAY_GRP             | Design<br>implementation<br>constraint.                                                     |
| C_OUTPUT_DRV              | This is the DRAM<br>reduced output drive<br>option.                                         |
| C_REG_CTRL                | This is the option for<br>DIMM or unbuffered<br>DIMM selection.                             |

| Parameter Name | Description                                                                                                                                             |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_RTT_NOM      | This is the nominal<br>ODT value. The<br>"DISABLED" choice<br>cannot be<br>configured in the<br>MIG GUI, and can<br>only be set in the<br>MHS file.     |
| C_RTT_WR       | This is the dynamic<br>ODT write<br>termination used in<br>multiple-RANK<br>designs. For single-<br>component designs,<br>RTT_WR should be<br>disabled. |
| С_ТСК          | This is the memory<br>tCK clock period (ps).                                                                                                            |
| С_ТСКЕ         | This is the CKE<br>minimum pulse.                                                                                                                       |
| C_TFAW         | This is the minimum<br>interval of four<br>active commands.                                                                                             |
| C_TPRDI        | This is the periodic read.                                                                                                                              |
| C_TRAS         | This is the minimum<br>ACTIVE-to-<br>PRECHARGE period<br>for memory.                                                                                    |
| C_TRCD         | This is the ACTIVE-<br>to-READ or – WRITE<br>command delay.                                                                                             |
| C_TREFI        | This is the average<br>periodic refresh<br>interval for memory.                                                                                         |



| Parameter Name | Description                                                                         |
|----------------|-------------------------------------------------------------------------------------|
| C_TRFC         | This is the REFRESH-<br>to-ACTIVE or<br>REFRESH-to-<br>REFRESH command<br>interval. |
| C_TRP          | This is the<br>PRECHARGE<br>command period.                                         |
| C_TRRD         | This is the ACTIVE-<br>to-ACTIVE minimum<br>command period.                         |
| C_TRTP         | This is the READ-to-<br>PRECHARGE<br>command delay.                                 |
| C_TWTR         | This is the WRITE-to-<br>READ command<br>delay.                                     |
| C_TZQI         | This is the timing<br>window to perform<br>the ZQCL command<br>in DDR3 SDRAM.       |
| C_TZQCS        | This is the timing<br>window to perform<br>the ZQCS command<br>in DDR3 SDRAM.       |
| C_CAL_WIDTH    | This is the calibration width.                                                      |
| C_RANKS        | This is the number of ranks.                                                        |
| C_ODT_WIDTH    | This is the number of<br>ODT outputs to<br>memory.                                  |
| C_ROW_WIDTH    | This is the DRAM<br>component address<br>bus width.                                 |

| Parameter Name  | Description                                                                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_BYTE_LANES_B0 | Defines the byte<br>lanes being used in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used, and a "0"<br>indicates unused. |
| C_BYTE_LANES_B1 | Defines the byte<br>lanes being used in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used, and a "0"<br>indicates unused. |
| C_BYTE_LANES_B2 | Defines the byte<br>lanes being used in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used, and a "0"<br>indicates unused. |
| C_BYTE_LANES_B3 | Defines the byte<br>lanes being used in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used, and a "0"<br>indicates unused. |
| C_BYTE_LANES_B4 | Defines the byte<br>lanes being used in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used, and a "0"<br>indicates unused. |



| Parameter Name | Description                                                                                                                                                                                        | Parameter Name   | Description                                                                                                                                                                                        |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_DATA_CTL_B0  | Defines mode of use<br>of byte lanes in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used for data, and<br>a "0" indicates it is<br>used for<br>address/control. | C_DATA_CTL_B4    | Defines mode of use<br>of byte lanes in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used for data, and<br>a "0" indicates it is<br>used for<br>address/control. |
| C_DATA_CTL_B1  | Defines mode of use<br>of byte lanes in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used for data, and<br>a "0" indicates it is<br>used for<br>address/control. | C_PHY_0_BITLANES | 12-bit parameter per<br>byte lane used to<br>determine which I/O<br>locations are used to<br>generate the<br>necessary PHY<br>structures. This<br>parameter is<br>provided as per                  |
| C_DATA_CTL_B2  | Defines mode of use<br>of byte lanes in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used for data, and<br>a "0" indicates it is<br>used for<br>address/control. |                  | bank. Except CKE,<br>ODT, and RESET pins,<br>all Data and<br>Address/Control pins<br>are considered for<br>this parameter<br>generation.                                                           |
| C_DATA_CTL_B3  | Defines mode of use<br>of byte lanes in a<br>given I/O bank. A "1"<br>in a bit position<br>indicates a byte lane<br>is used for data, and<br>a "0" indicates it is<br>used for<br>address/control. |                  |                                                                                                                                                                                                    |



| Parameter Name   | Description                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_PHY_1_BITLANES | Description12-bit parameter perbyte lane used todetermine which I/Olocations are used togenerate thenecessary PHYstructures. Thisparameter isprovided as perbank. Except CKE,ODT, and RESET pins,all Data andAddress/Control pinsare considered forthis parameter                                                             |
| C_PHY_2_BITLANES | generation.<br>12-bit parameter per<br>byte lane used to<br>determine which I/O<br>locations are used to<br>generate the<br>necessary PHY<br>structures. This<br>parameter is<br>provided as per<br>bank. Except CKE,<br>ODT, and RESET pins,<br>all Data and<br>Address/Control pins<br>are considered for<br>this parameter |
| C_CK_BYTE_MAP    | generation.<br>Bank and byte lane<br>location information<br>for the CK/CK#. An 8-<br>bit parameter is<br>provided per pair of<br>signals.                                                                                                                                                                                    |

| Parameter Name | Description                                                                                                  |
|----------------|--------------------------------------------------------------------------------------------------------------|
| C_ADDR_MAP     | Bank and byte lane<br>position information<br>for the address. 12-<br>bit parameter<br>provided per pin.     |
| C_BANK_MAP     | Bank and byte lane<br>position information<br>for the bank address.                                          |
| C_CAS_MAP      | Bank and byte lane<br>position information<br>for the CAS<br>command.                                        |
| C_CKE_MAP      | Bank and byte lane<br>position information<br>for the Clock Enable.                                          |
| C_ODT_MAP      | Bank and byte lane<br>position information<br>for the On-Die<br>Termination.                                 |
| C_CKE_ODT_AUX  | This enables the aux_out signal.                                                                             |
| C_CS_MAP       | Bank and byte lane<br>position information<br>for the chip select. 1<br>2-bit parameter<br>provided per pin. |
| C_PARITY_MAP   | Bank and byte lane<br>position information<br>for the parity bit.<br>Parity bit exists for<br>RDIMMs only.   |
| C_RAS_MAP      | Bank and byte lane<br>position information<br>for the RAS<br>command.                                        |



| Parameter Name | Description                                                          |
|----------------|----------------------------------------------------------------------|
| C_WE_MAP       | Bank and byte lane<br>position information<br>for the WE<br>command. |
| C_DQS_BYTE_MAP | Bank and byte lane<br>position information<br>for the strobe.        |
| C_DATA0_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA1_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA2_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA3_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA4_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA5_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA6_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA7_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |
| C_DATA8_MAP    | Bank and byte lane<br>position information<br>for the data bus.      |

| Parameter Name  | Description                                                      |
|-----------------|------------------------------------------------------------------|
| C_DATA9_MAP     | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA10_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA11_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA12_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA13_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA14_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA15_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_DATA16_MAP    | Bank and byte lane<br>position information<br>for the data bus.  |
| C_MASK0_MAP     | Bank and byte lane<br>position information<br>for the data mask. |
| C_MASK1_MAP     | Bank and byte lane<br>position information<br>for the data mask. |
| C_SLOT_0_CONFIG | This is the rank<br>mapping for slot 1.                          |
| C_SLOT_1_CONFIG | This is the rank mapping for slot 2.                             |



| Parameter Name        | Description                                                                                                                                                              |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| C_MEM_ADDR_ORDER      | This is the memory address order.                                                                                                                                        |  |
| C_SIM_BYPASS_INIT_CAL | This simulation only<br>parameter is used to<br>speed up<br>simulations.                                                                                                 |  |
| C_REFCLK_FREQ         | This is the reference<br>clock frequency for<br>IODELAYCTRLs. This<br>can be set to 200.0<br>for any speed grade<br>device.                                              |  |
| C_USE_CS_PORT         | This enables the use of the CS port.                                                                                                                                     |  |
| C_USE_DM_PORT         | This is the enable<br>data mask option<br>used during memory<br>write operations.                                                                                        |  |
| C_USE_ODT_PORT        | This enables the use<br>of the ODT port. This<br>parameter cannot be<br>configured in the<br>MIG GUI, and can<br>only be set in the<br>MHS file. Defaults to<br>1.       |  |
| C_USE_EXTERNAL_XADC   | This instantiates or<br>uses external XADC.<br>This parameter<br>cannot be<br>configured in the<br>MIG GUI, and can<br>only be set in the<br>MHS file. Defaults to<br>0. |  |

| Parameter Name                  | Description                                                                                        |
|---------------------------------|----------------------------------------------------------------------------------------------------|
| C_USE_EXTERNAL_IODELA<br>Y_CTRL | This enables<br>"iodelay_ctrl_rdy_i"<br>when set to 1.                                             |
| C_ECC                           | This enables error<br>code correction<br>when set to "ON"<br>and disables it when<br>set to "OFF". |
| C_ECC_TEST                      | Only "OFF" is<br>supported.                                                                        |
| C_MC_ERR_ADDR_WIDTH             | This is the memory<br>controller error<br>address width.                                           |

#### Assumptions

Assumption 1: The integrator will develop a full set of DO-254 artifacts to reflect the objectives, activities, and lifecycle data related to the system/safety, implementation, target test, acceptance test, production transition aspects, related validation and verification, configuration management, process assurance, and certification liaison aspects of the system/LRU.

Assumption 2: The objectives, activities and lifecycle data related specifically to the DO-254 7 Series DDRx (Native-Limited) Core will be provided to the Integrator for inclusion into their overall certification package.

**Assumption 3**: Place and route, clock frequency, and parameter selection decisions related to the IP core will have an impact on critical areas such as timing. These decisions and the verification of these implementation decisions will be the responsibility of the integrator.



**Assumption 4**: All objectives related to the building, integration and production (including Production Testing — ATP) of the system/LRU will be the responsibility of the integrator.

Assumption 5: Objectives related to hardware components other than the DO-254 7 Series DDRx (Native-Limited) Core are the responsibility of the integrator.

**Assumption 6**: The integrator will develop all DO-254 artifacts that are related to the integration and testing of the DO-254 7 Series DDRx (Native-Limited) Core in their system.

**Assumption 7**: The integrator will perform implementation objectives related to the target hardware, including the integral process objectives, to verify the timing and other critical parameters of the DO-254 7 Series DDRx (Native-Limited) Core.

**Assumption 8**: The applicant is responsible for communicating with their Certification Authority relative to the implementation of the DO-254 7 Series DDRx (Native-Limited) Core into their system.

**Assumption 9**: Compliance with the objectives related to system (and safety-related) requirements allocated to the hardware will be the responsibility of the integrator. The requirement to feed all IP derived requirements to the System/Safety Process will be the responsibility of the integrator. The integrator will be required to generate hardware requirements allocated from the system requirements that exercise the DO-254 7 Series DDRx (Native-Limited) Core at the system level.

**Assumption 10**: The integrator is required to include a clock timing constraint for this DO-254

7 Series DDRx (Native-Limited) Core. This clock timing constraint will define the clock rate at which the IP core will operate. It is recommended that the integrator defines this constraint in the UCF file. The integrator typically would also include (at a minimum, but not limited to) pinout constraints, I/O electrical standards, etc. An example UCF file will be provided in Chapter 3 of the 10141-UG, but it is for reference only.

Assumption 11: The integrator is not required to rerun any elemental analysis (code coverage). Code coverage results indicate that all configurations required to attain 100% coverage are tested.

Assumption 12: Some testing of the DO-254 7 Series DDRx (Native-Limited) Core was done on a test board. The integrator is responsible for black box testing in their system to verify that the IP performs its intended function in the system. In order to assist the integrator with determining what should be tested at the system level, Logicircuit has included a list of potential target tests in the "Potential Target Test" section of the User Guide for each IP. The integrator should evaluate the list of tests against the hardware functions of the IP they are using in their system to determine which tests they should perform at the system level.



# **Revision History**

|          |                                           |           | Subversion |
|----------|-------------------------------------------|-----------|------------|
|          |                                           |           | repository |
| Revision | Reason/Description                        | Date      | revision   |
| -        | Draft 2 has formally been released as Rev | 10/3/2019 | 65         |
|          |                                           |           |            |