

#### September 26, 2017, Revision A

## DO-254 AXI Interconnect 1.10a Certifiable Data Package (DAL A)

#### **General Description**

The AXI Interconnect DO-254 Certifiable Data Package is made up of the artifacts produced by applying the DO-254 lifecycle to the Xilinx® AXI Interconnect IP v1.06a 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 AXI Interconnect IP Core 1.10a, created and designed by Logicircuit, connects one or more AXI memory-mapped master devices to one or more memory-mapped slave

devices in Xilinx Field Programmable Gate Arrays (FPGAs).

This version of the DO-254 AXI Interconnect IP 1.10a does not have any built-in safety features.

#### Features

- AXI protocol compliant (AXI4 only), including:
  - Burst lengths up to 256 for incremental (INCR) bursts
  - Propagates Quality of Service (QoS) signals, if any; not used by the AXI Interconnect core (optional)
- Interface data widths:
  - o 32, 64, 128, 256, 512, or 1024 bits
- Address width: 12 to 64 bits
- Up to 16 Slave interfaces (to accept transactions from up to 16 connected master devices) and one Master Interface (to issue transactions to one connected slave device)
  - When connecting one master to one slave, the AXI Interconnect core can optionally perform any of the optional data-width conversions, clock-rate conversions, register pipelining, and datapath buffering functions
- Built-in data-width conversion:
  - Each master and slave connection can independently use data widths of 32, 64, 128, 256, 512, or 1024 bits:
    - The internal crossbar can be configured to have a native data width of 32, 64, 128, 256, 512, or 1024 bits.
    - Data-width conversion is performed for each master and slave connection that



does not match the crossbar native data width.

- When converting to a wider interface (upsizing), data is packed (merged) when permitted by address channel control signals (CACHE modifiable bit is asserted).
- When converting to a narrower interface (downsizing), burst transactions are split into multiple transactions if the maximum burst length otherwise would be exceeded.
- Built-in clock-rate conversion
- Optional register-slice pipelining
- Optional datapath FIFO buffering
- Supports multiple outstanding transactions
- Fixed priority and round-robin arbitration
- Support for Read-only and Write-only master devices, resulting in reduced resource utilization

## **Core Diagram**



# **Supported FPGA Families**

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

# **Development Tools**

QuestaSim<sup>®</sup> v10.2c or later Xilinx<sup>®</sup> ISIM 14.6 or later Xilinx<sup>®</sup> XST 14.6 or later Xilinx<sup>®</sup> Vivado<sup>°</sup> 2016.1 or later

# Configuration

The DO-254 AXI Interconnect version 1.10a is configurable as shown below:

| Settable Parameter              | Definition                                                   |  |
|---------------------------------|--------------------------------------------------------------|--|
| C_NUM_SLAVE_SLOTS               | Number of slave slots                                        |  |
| C_NUM_MASTER_                   | Number of master                                             |  |
| SLOTS                           | slots                                                        |  |
| C_FAMILY                        | Xilinx part family                                           |  |
| C_AXI_ID_WIDTH                  | ID signal width                                              |  |
| C_AXI_ADDR_WIDTH                | Address signal width                                         |  |
| C_S_AXI_IS_<br>INTERCONNECT     | Master/AXI<br>interconnect<br>connection                     |  |
| C_INTERCONNECT_<br>DATA_WIDTH   | Interconnect data<br>width                                   |  |
| C_INTERCONNECT_<br>ACLK RATIO   | Clock frequency ratio                                        |  |
| C_AXI_SUPPORTS_<br>USER_SIGNALS | Support user signals                                         |  |
| C_AXI_AWUSER_<br>WIDTH          | AWUSER signal width                                          |  |
| C_AXI_ARUSER_WIDTH              | ARUSER signal width                                          |  |
| C_AXI_WUSER_WIDTH               | WUSER signal width                                           |  |
| C_AXI_RUSER_WIDTH               | RUSER signal width                                           |  |
| C_AXI_BUSER_WIDTH               | BUSER signal width                                           |  |
| C_AXI_CONNECTIVITY              | Connectivity                                                 |  |
| C_INTERCONNECT_                 | Connectivity mode                                            |  |
| CONNECTIVITY_MODE               |                                                              |  |
| C_INTERCONNECT_R_<br>REGISTER   | Insert register slice on<br>R channel inside<br>interconnect |  |
| C_RANGE_CHECK                   | Range check                                                  |  |



| Settable Parameter                | Definition                                                                        |  |  |  |
|-----------------------------------|-----------------------------------------------------------------------------------|--|--|--|
| Slave Interface                   |                                                                                   |  |  |  |
| C_S_AXI_PROTOCOL                  | AXI protocol                                                                      |  |  |  |
| C_S_AXI_DATA_WIDTH                | Data width                                                                        |  |  |  |
| C_S_AXI_BASE_ID                   | Base ID                                                                           |  |  |  |
| C_S_AXI_THREAD_ID_<br>WIDTH       | Low order ID bits                                                                 |  |  |  |
| C_S_AXI_SINGLE_                   | ID thread support                                                                 |  |  |  |
| THREAD                            |                                                                                   |  |  |  |
| C_S_AXI_ACLK_RATIO                | Clock frequency ratio                                                             |  |  |  |
| C_S_AXI_IS_ACLK_<br>ASYNC         | Indicates if SI slot clock<br>is synchronous or<br>asynchronous                   |  |  |  |
| C_S_AXI_ARB_<br>PRIORITY          | Arbitration priority                                                              |  |  |  |
| C_S_AXI_WRITE_<br>ACCEPTANCE      | Number of data-active write transactions                                          |  |  |  |
| C_S_AXI_READ_<br>ACCEPTANCE       | Number of active read transactions                                                |  |  |  |
| C_S_AXI_SUPPORTS_<br>WRITE        | Indicates whether each<br>SI slot uses Write-<br>related channels                 |  |  |  |
| C_S_AXI_SUPPORTS_<br>READ         | Indicates whether each<br>SI slot uses Read-<br>related channels.                 |  |  |  |
| C_S_AXI_SUPPORTS_<br>NARROW_BURST | Indicates whether the<br>connected master<br>device can produce<br>narrow bursts. |  |  |  |
| C_S_AXI_WRITE_FIFO_<br>DEPTH      | Depth of SI-side Write<br>data FIFO                                               |  |  |  |
| C_S_AXI_WRITE_FIFO_<br>DELAY      | Packet FIFO write<br>behavior                                                     |  |  |  |
| C_S_AXI_READ_FIFO_<br>DEPTH       | Depth of SI-side Read<br>data FIFO                                                |  |  |  |

| Settable Parameter          | Definition                                                             |  |  |  |
|-----------------------------|------------------------------------------------------------------------|--|--|--|
| C_S_AXI_READ_FIFO_<br>DELAY | Packet FIFO read<br>behavior                                           |  |  |  |
| C_S_AXI_AW_<br>REGISTER     | Insert register slice on<br>AW channel                                 |  |  |  |
| C_S_AXI_AR_REGISTER         | Insert register slice on<br>AR channel                                 |  |  |  |
| C_S_AXI_W_REGISTER          | Insert register slice on<br>W channel                                  |  |  |  |
| C_S_AXI_R_REGISTER          | Insert register slice on<br>R channel                                  |  |  |  |
| C_S_AXI_B_REGISTER          | Insert register slice on<br>B channel                                  |  |  |  |
| Master Interface            |                                                                        |  |  |  |
| C_M_AXI_PROTOCOL            | AXI protocol                                                           |  |  |  |
| C_M_AXI_DATA_<br>WIDTH      | Data width                                                             |  |  |  |
| C_M_AXI_BASE_ADDR           | Base address                                                           |  |  |  |
| C_M_AXI_HIGH_ADDR           | High address of each range                                             |  |  |  |
| C_M_AXI_ACLK_RATIO          | Clock frequency ratio                                                  |  |  |  |
| C_M_AXI_IS_ACLK_<br>ASYNC   | Indicates if MI slot<br>clock is synchronous or<br>asynchronous        |  |  |  |
| C_M_AXI_SUPPORTS_<br>WRITE  | Indicates whether each<br>MI slot uses Write-<br>related channels.     |  |  |  |
| C_M_AXI_SUPPORTS_<br>READ   | Indicates whether each<br>MI slot Read-related<br>channels.            |  |  |  |
| C_M_AXI_WRITE_<br>ISSUING   | Number of data-active<br>Write transactions                            |  |  |  |
| C_M_AXI_READ_<br>ISSUING    | Number of active Read<br>transactions                                  |  |  |  |
| C_M_AXI_SECURE              | Indicates whether each<br>MI slot connects to a<br>secure slave device |  |  |  |



| Settable Parameter                | Definition                                                                            |  |
|-----------------------------------|---------------------------------------------------------------------------------------|--|
| C_M_AXI_SUPPORTS_<br>NARROW_BURST | Indicates whether the<br>connected slave device<br>is configured to<br>support bursts |  |
| C_M_AXI_WRITE_FIFO                | Depth of MI-side Write                                                                |  |
| _DEPTH                            | data FIFO                                                                             |  |
| C_M_AXI_WRITE_FIFO                | Packet FIFO write                                                                     |  |
| _DELAY                            | behavior                                                                              |  |
| C_M_AXI_READ_FIFO_                | Depth of MI-side Read                                                                 |  |
| DEPTH                             | data FIFO                                                                             |  |
| C_M_AXI_READ_FIFO_                | Packet FIFO read                                                                      |  |
| DELAY                             | behavior                                                                              |  |
| C_M_AXI_AW_                       | Insert register slice on                                                              |  |
| REGISTER                          | AW channel                                                                            |  |
| C_M_AXI_AR_                       | Insert register slice on                                                              |  |
| REGISTER                          | AR channel                                                                            |  |
| C_M_AXI_W_                        | Insert register slice on                                                              |  |
| REGISTER                          | W channel                                                                             |  |
| C_M_AXI_R_REGISTER                | Insert register slice on<br>R channel                                                 |  |
| C_M_AXI_B_REGISTER                | Insert register slice on<br>B channel                                                 |  |

## 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 AXI Interconnect 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 AXI Interconnect 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 AXI Interconnect 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 AXI Interconnect Core.

**Assumption 8**: The applicant is responsible for communicating with their Certification Authority relative to the implementation of the DO-254 AXI Interconnect 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 AXI Interconnect Core at the system level.

Assumption 10: The integrator is required to include a clock timing constraint for this DO-254 AXI Interconnect 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 10101-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 AXI Interconnect Core was done on a test board, the integrator is responsible for complete IP 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 1 has been formally released as Rev | 9/2/2014  | 131        |
| A        | PR-7-1678                                 | 9/26/2017 | 180        |