

## LDPC Encoder/Decoder v2.0

PB052 (v2.0) February 8, 2021

LogiCORE IP Product Brief

#### **IP Facts**

The LDPC Encoder/Decoder supports Low Density Parity Check (LDPC) decoding and encoding. The LDPC codes used are highly configurable, and the specific code used can be specified on a codeword-by-codeword basis.

#### **Additional Documentation**

A Product Guide is available for this core. Access to this material can be requested by clicking on this registration link: http://www.xilinx.com/member/ldpc-enc-dec.html.

#### Features

The soft IP core is a highly flexible soft-decision implementation for LDPC codes offering the following features.

- LDPC decode or encode of a range of customer specified Quasi-cyclic (QC) codes, including 5G New Radio codes
- Peak throughput up to:
  - 1.78 Gb/s LDPC decode @ 8 iterations
  - 12.5 Gb/s for LDPC encode
- High bandwidth AXI4-Stream interfaces

#### LDPC Decoding/Encoding

- Highly configurable codes
  - A range of quasi-cyclic codes can be configured over an AXI4-Lite interface
  - Code parameter memory can be shared across up to 128 codes
  - Codes can be selected on a block-by-block basis
  - <sup>o</sup> 5G support mode where tables are pre-loaded
- Normalized min-sum or offset min-sum decoding algorithm
  - Normalization factor programmable (from 0.0625 to 1 in steps of 0.0625) for layers
  - Offset factor can be specified per block (from 0.25 to 3.75 in steps of 0.25)

- Number of iterations between 1 and 63
  - Specified for each block using the AXI4-Stream control interface
- Early termination
  - Specified for each block to be none, one, or both of the following:
    - Parity check passes
    - No change in hard information or parity bits since last iteration
- When configured as a decoder, soft or hard outputs
  - Specified for each block to include information and optional parity
  - 6-bit soft log-likelihood ratio (LLR) input (8-bit interface, two fractional bits, with external saturation before input to symmetric range -7.75 to +7.75 assumed) and 8-bit output
- In- or out-of-order execution of blocks, with user specified ID field to identify blocks
- Encoder and decoder variants, with optional support for improved throughput when submatrix size is small
- Optional final parity check to update parity pass/fail for final output
- Optional initialization of codes from device configuration, avoiding download using AXI4-Lite interface

### Interfaces

- Wide data interfaces on input and output
- Ability to specify number of inputs and outputs on either a block-by-block basis or transfer basis
- Separate inputs to specify control parameters and receive status output on a block-by-block basis

#### **IP Facts**

| LogiCORE IP Facts Table<br>Core Specifics |                                                                                       |  |
|-------------------------------------------|---------------------------------------------------------------------------------------|--|
|                                           |                                                                                       |  |
| Supported User Interfaces                 | AXI4-Lite, AXI4-Stream                                                                |  |
| Resources                                 | Performance and Resource Utilization web page (registration required)                 |  |
|                                           | Provided with Core                                                                    |  |
| Design Files                              | N/A                                                                                   |  |
| Example Design                            | IP integrator Block Diagram                                                           |  |
| Test Bench                                | Verilog                                                                               |  |
| Constraints File                          | Not Provided                                                                          |  |
| Simulation Model                          | System Verilog SecureIP model<br>Bit-accurate C model<br>MEX file for use with MATLAB |  |
| Supported S/W Driver <sup>2</sup>         | Standalone                                                                            |  |
|                                           | Tested Design Flows <sup>3</sup>                                                      |  |
| Design Entry                              | Vivado® Design Suite                                                                  |  |
| Simulation                                | For supported simulators, see the Xilinx Design Tools: Release Notes Guide            |  |
| Synthesis                                 | Vivado                                                                                |  |
|                                           | Support                                                                               |  |
| Release Notes and Known Issues            | Master Answer Record: 69399                                                           |  |
| All Vivado IP Change Logs                 | Master Vivado IP Change Logs: 72775                                                   |  |
|                                           | Xilinx Support web page                                                               |  |

#### Notes:

- 1. For a complete list of supported devices, see the Vivado IP catalog.
- 2. Standalone driver details can be found in <Install Directory>/Vitis/2020.2/data/embeddedsw/XilinxProcessorIPLib/ drivers/.
- 3. For the supported versions of the tools, see the Xilinx Design Tools: Release Notes Guide.

#### **Overview**

Forward Error Correction (FEC) codes such as Low Density Parity Check (LDPC) codes provide a means to control errors in data transmissions over unreliable or noisy communication channels. The LDPC Encoder/Decoder core provides an optimized block for encoding and soft-decision decoding of these codes. Custom and standardized LDPC codes are supported through the ability to specify the parity check matrix either through configuration of code memory or alternatively over an AXI4-Lite bus.

### **Applications**

The LDPC Encoder/Decoder core is intended for use in applications requiring LDPC encode/ decode, such as:

- 5G wireless (3rd Generation Partnership Project; Technical Specification Group Radio Access Network; NR; Multiplexing and channel coding (Release 15) (3GPP Std TS 38.212 V15.0.0)).
- DOCSIS 3.1 cable modems (Data-Over-Cable Service Interface Specifications DOCSIS 3.1, Physical Layer Specification (DOCSIS 3.1)).
- WiFi 802.11ac-2012 High Throughput PHY (https://www.ieee802.org).
- Proprietary backhaul solutions.

## **Technical Support**

Xilinx provides technical support on the Xilinx Community Forums for this LogiCORE<sup>™</sup> IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To ask questions, navigate to the Xilinx Community Forums.

## **Licensing and Ordering**

This Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP module is provided at no additional cost with the Xilinx Vivado<sup>®</sup> Design Suite under the terms of the Xilinx End User License.

This Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP module is provided under the terms of the Xilinx Core License Agreement. The module is shipped as part of the Vivado<sup>®</sup> Design Suite. For full access to all core functionalities in simulation and in hardware, you must purchase a license for the core. To generate a full license, visit the product licensing web page. Evaluation licenses and hardware timeout licenses might be available for this core. Contact your local Xilinx sales representative for information about pricing and availability.

*Note*: To verify that you need a license, check the License column of the IP Catalog. Included means that a license is included with the Vivado<sup>®</sup> Design Suite; Purchase means that you have to purchase a license to use the core.

For more information about this core, visit the LDPC Encoder/Decoder product web page.

Information about other Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP modules is available at the Xilinx Intellectual Property page. For information about pricing and availability of other Xilinx LogiCORE IP modules and tools, contact your local Xilinx sales representative.

#### License Checkers

If the IP requires a license key, the key must be verified. The Vivado<sup>®</sup> design tools have several license checkpoints for gating licensed IP through the flow. If the license check succeeds, the IP can continue generation. Otherwise, generation halts with an error. License checkpoints are enforced by the following tools:

- Vivado Synthesis
- Vivado Implementation
- write\_bitstream (Tcl command)

**IMPORTANT!** IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.

## **Documentation Navigator and Design Hubs**

Xilinx<sup>®</sup> Documentation Navigator (DocNav) provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open DocNav:

- From the Vivado<sup>®</sup> IDE, select Help  $\rightarrow$  Documentation and Tutorials.
- On Windows, select Start → All Programs → Xilinx Design Tools → DocNav.
- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In DocNav, click the **Design Hubs View** tab.
- On the Xilinx website, see the Design Hubs page.

*Note*: For more information on DocNav, see the Documentation Navigator page on the Xilinx website.

## **Revision History**

| Section                | Revision Summary                                                                                          |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------|--|--|
| 02/08/2021 Version 2.0 |                                                                                                           |  |  |
| General updates        | <ul><li>Updated to align with Product Guide (PG281) updates.</li><li>Added Versal ACAP support.</li></ul> |  |  |
| 12/04/2019 Version 2.0 |                                                                                                           |  |  |
| General updates        | Updated to align with Product Guide (PG281) updates.                                                      |  |  |
| 04/04/2018             | Version 2.0                                                                                               |  |  |
| General updates        | Updated to align with Product Guide (PG281) updates.                                                      |  |  |
| 10/04/2017 Version 1.0 |                                                                                                           |  |  |
| Initial release.       | N/A                                                                                                       |  |  |

# **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY



PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at https:// www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos.

#### AUTOMOTIVE APPLICATIONS DISCLAIMER

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

#### Copyright

© Copyright 2017–2021 Xilinx, Inc. Xilinx, the Xilinx logo, Alveo, Artix, Kintex, Spartan, Versal, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

