# arm

## **Arm RAN Acceleration Library**

Product revision: 22.07

## **Release Note**

#### Non-Confidential

Copyright <sup>©</sup> 2020, 2022 Arm Limited (or its affiliates). Document ID: All rights reserved.

107561

|  |  |  | <br>0   |
|--|--|--|---------|
|  |  |  | 0       |
|  |  |  | т<br>А. |
|  |  |  |         |

## Arm RAN Acceleration Library Release Note

Copyright <sup>©</sup> 2020, 2022 Arm Limited (or its affiliates). All rights reserved.

### Non-Confidential Proprietary Notice

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, has undertaken no analysis to identify or understand the scope and content of, patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with <sup>®</sup> or <sup>™</sup> are registered trademarks or trademarks of Arm Limited (or its affiliates) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at

#### https://www.arm.com/company/policies/trademarks.

Copyright <sup>©</sup> 2020, 2022 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England. 110 Fulbourn Road, Cambridge, England CB1 9NJ. (LES-PRE-20349)

Copyright  $^{\odot}$  2020, 2022 Arm Limited (or its affiliates). All rights reserved. Non-Confidential

#### Confidentiality Status

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

Unrestricted Access is an Arm internal classification.

#### Product status

The information in this document is Final, that is for a developed product.

#### Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on Arm RAN Acceleration Library, create a ticket on **https://support.developer.arm.com**.

To provide feedback on the document, fill the following survey: https://developer.arm.com/documentation-feedback-survey.

#### Inclusive language commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used language that can be offensive. Arm strives to lead the industry and create change.

To report offensive language in this document, email **terms@arm.com**.

| 1     | Release overview                  | 6 |
|-------|-----------------------------------|---|
| 1.1   | Product description               | 6 |
| 1.2   | Release status                    | 6 |
| 2     | Release contents                  | 7 |
| 2.1   | Downloading and unpacking         | 7 |
| 2.2   | Deliverables                      | 7 |
| 2.3   | Differences from previous release | 8 |
| 2.3.1 | Additions and changes             | 8 |
| 2.3.2 | Resolved issues                   | 9 |
| 2.4   | Known limitations                 | 9 |
| 3     | Support                           |   |
| 3.1   | Tools                             |   |
| 4     | Release history                   |   |
| 5     | Conventions                       |   |
| 5.1   | Glossary                          |   |

# 1 Release overview

The following sections describe the product that this release note describes and its quality status at time of release.

Use of Arm RAN Acceleration Library is subject to the terms and conditions of the applicable End User License Agreement ("EULA"). A copy of the EULA can be found in the `license\_terms` folder of your product installation.

You do not require a license to use this Arm RAN Acceleration Library package.

### **1.1 Product description**

The Arm RAN Acceleration Library (ArmRAL) contains a set of functions for accelerating telecommunications applications such as, but not limited to, 5G Radio Access Networks (RANs).

The Arm RAN Acceleration Library 22.07 package provides a library that is optimized for Arm AArch64-based processors, and also provides optimized routines for processors that support the SVE and SVE2 architecture extensions.

Arm RAN Acceleration Library provides:

- Vector functions
- Matrix functions
- Lower PHY support functions
- Upper PHY support functions
- DU-RU Interface support functions

Arm RAN Acceleration Library includes functions that operate on 16-bit signed integers and 32-bit floating-point values.

### **1.2 Release status**

This is the 22.07 release of Arm RAN Acceleration Library.

These deliverables are being released under the terms of the agreement between Arm and each licensee (the "Agreement"). All planned verification and validation is complete.

The release is suitable for volume production under the terms of the Agreement.

## 2 Release contents

Arm releases can contain documentation and source files such as RTL, testbenches, or software.

The following sections describe:

- Downloading and unpacking the product.
- The contents of this release.
- Any changes since the previous release.
- Any known issues and limitations that exist at the time of this release.

## 2.1 Downloading and unpacking

You must download the Arm RAN Acceleration Library deliverable from the Arm Developer website, then unpack the contents.

#### Procedure

- 1. Go to https://developer.arm.com/solutions/infrastructure/developer-resources/5g/ran/download.
- 2. Complete the form and click **Submit**. The package downloads.
- 3. Locate the downloaded .tar.gz file.
- 4. Copy the .tar.gz file to the directory where these files are to be built.
- Extract the tar file contents using a tar utility, type: tar -zxvf arm-ran-acceleration-library-22.07-aarch64.tar.gz

### 2.2 Deliverables

The downloaded product includes the deliverables listed in this section.

- Arm RAN Acceleration Library 22.07
- Release Notes (this document)
- Documentation

Product documentation is available on the Arm Developer website at:

https://developer.arm.com/documentation/102249/2204



Documentation, errata and release notes might change between product releases. For the latest documentation bundle, check the product download page.



Arm tests its PDFs only in Adobe Acrobat and Acrobat Reader. Arm cannot guarantee the quality of this document when used with any other PDF reader. A suitable PDF reader can be downloaded from Adobe at **http://www.adobe.com**.

## 2.3 Differences from previous release

The following subsections describe differences from the previous release of Arm RAN Acceleration Library.

### 2.3.1 Additions and changes

Describes new features or components added, or any technical changes to features or components, in this release.

- Renamed the Polar encoding and decoding routines to `armral\_polar\_encode\_block` and `armral\_polar\_decode\_block`. This ensures the naming is consistent with the LDPC and Turbo coding implementations. This naming scheme makes it clear that the encoding and decoding routines operate on a single code block.

- Improved the performance of the following implementations:

- SVE2 mu law compression and decompression (`armral\_mu\_law\_compr\_\*` and `armral\_mu\_law\_decompr\_\*`).
- SVE2 block float compression and decompression (`armral\_block\_float\_compr\_\*` and `armral\_block\_float\_decompr\_\*`).
- SVE2 8-bit block scaling compression (`armral\_block\_scaling\_compr\_8bit`).
- Neon and SVE2 16-QAM modulation (`armral\_modulation` with `armral\_modulation\_type` set to `ARMRAL\_MOD\_16QAM`).
- 32-bit floating-point and 16-bit fixed-point complex valued FFTs (`armral\_fft\_execute\_cf32`, `armral\_fft\_execute\_cs16`) with large prime factors.
- Added SVE2 optimized implementations of the following routines:
- Equalization with four subcarriers (`armral\_solve\_\*x\*\_4sc\_f32`).

- Added matrix-vector multiplication functions for batches of 32-bit complex floating-point matrices and vectors. There are two versions of this routine:

Copyright  $^{\odot}$  2020, 2022 Arm Limited (or its affiliates). All rights reserved. Non-Confidential

`armral\_cmplx\_mat\_vec\_mult\_batch\_f32` and `armral\_cmplx\_mat\_vec\_mult\_batch\_f32\_pa`. These assume that the batches are organized differently in memory. For a description of the batched layout, see the comments for these functions in `armral.h`.

- Added routine for LTE Turbo encoding (`armral\_turbo\_encode\_block`) that implements the encoding scheme defined in section 5.1.3.2 of the 3GPP Technical Specification (TS) 36.212 "Multiplexing and channel coding".

- Added routine for LTE Turbo decoding (`armral\_turbo\_decode\_block`) that implements a maximum a posteriori (MAP) algorithm to return a hard decision (either 0 or 1) for each output bit. The routine takes a parameter that specifies the maximum number of iterations that the decoder will perform. The algorithm will terminate in fewer iterations if there is no change in the computed log-likelihood ratios between consecutive iterations. The routine does not implement CRC checking and so does not ascertain whether or not the chosen output is valid.

- Added routine to perform rate matching for Polar coding. This implements the specification in section 5.4.1 of the 3GPP Technical Specification (TS) 38.212.

- Added routine to perform rate recovery for Polar coding. This implements the inverse operations of rate matching. Rate matching is described in section 5.4.1 of the 3GPP Technical Specification (TS) 38.212.

- Added utilities to simulate the error correction performance for Polar coding over a noisy channel. More information can be found in the simulation/README.md file.

- Added routine to perform rate matching for LDPC coding. This implements the specification in section 5.4.2 of the 3GPP Technical Specification (TS) 38.212.

- Added routine to perform rate recovery for LDPC coding. This implements the inverse operations of rate matching. Rate matching is described in section 5.4.2 of the 3GPP Technical Specification (TS) 38.212.

- Added utilities to simulate the error correction performance for LDPC coding over a noisy channel. More information can be found in the simulation/README.md file.

- Added utilities to simulate the error correction performance for Turbo coding over a noisy channel. More information can be found in the simulation/README.md file.

### 2.3.2 Resolved issues

There are no resolved issues in this release.

## 2.4 Known limitations

There are no known issues with this release.

# 3 Support

If you have any issues with the installation, content or use of this release, create a ticket on **https://support.developer.arm.com**. Arm will respond as soon as possible.



Support for this release of the product is only provided by Arm to partners who have a current support and maintenance contract for the product.

## 3.1 Tools

The following points list the tools that are required to build or run Arm RAN Acceleration Library:

• A recent version of a C/C++ compiler, such as GCC. Arm RAN Acceleration Library has been tested with GCC 7.5.0, 8.2.0, 9.3.0, 10.2.0, and 11.1.0.



If you are cross-compiling, you need a cross-toolchain compiler that targets AArch64. You can download open-source cross-toolchain builds of the GCC compiler on the Arm Developer website:

https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-a/downloads

The variant to use for an AArch64 GNU/Linux target is `aarch64-none-linux-gnu`.

• A recent version of CMake (version 3.3.0, or higher).

In addition to the preceding requirements:

- To run the benchmarks, you must have the Linux utility tool `perf` installed and a recent version of Python 3. Arm RAN Acceleration Library has been tested with Python 3.8.5.
- To build a local version of the documentation, you must have Doxygen installed. Arm RAN Acceleration Library has been tested with Doxygen version 1.8.13.
- To generate code coverage HTML pages, you must have `gcovr` installed. The library has been tested with `gcovr` version 4.2.



Arm RAN Acceleration Library runs on AArch64 cores, however to use the CRC functions, you must run on a core that supports the AArch64 PMULL extension. If your machine supports the PMULL extension, pmull is listed under the "Features" list given in the /proc/cpuinfo file.

## 4 Release history

A full release history (with release notes) for Arm RAN Acceleration Library is available on the Arm Developer website:

https://developer.arm.com/solutions/infrastructure/developer-resources/5g/ran/release-history

# **5** Conventions

The following subsections describe conventions used in Arm documents.

## 5.1 Glossary

The Arm Glossary is a list of terms that are used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the Arm Glossary for more information: https://developer.arm.com/glossary.