AOCL now offers the capability to compile individual libraries and
consolidate them into a unified binary. With the Build-It-Yourself
feature, you can choose one or more AOCL libraries and merge them into a
single library by configuring the appropriate CMake options. This
unified binary is assigned a default name: libaocl.so/ libaocl.a for
Linux or aocl.dll/ aocl.lib for Windows. This approach simplifies
integration by eliminating dependencies on library linking order and
preventing API duplication, ensuring smooth and efficient incorporation
of multiple AOCL libraries.
Note
Currently, Build-It-Yourself supports selection of AOCL-BLAS, AOCL-Utils, AOCL-LAPACK, AOCL-Sparse, AOCL-LibM, AOCL-Compression, AOCL-Cryptography, AOCL-Data-Analytics, and AOCL-LibMem libraries only.
Additionally, we provide all AOCL library sources as git submodules in
the submodules branch of this repository. This enables offline development
and ensures consistent versioning across all components, making it easier to
build and work with the complete AOCL ecosystem without external dependencies.
- AOCL Build-It-Yourself
The project is structured as follows:
aocl_blis_build.cmake: CMake script for building AOCL-BLAS.aocl_compression_build.cmake: CMake script for building AOCL-COMPRESSION.aocl_crypto_build.cmake: CMake script for building AOCL-CRYPTO.aocl_da_build.cmake: CMake script for building AOCL-DATA-ANALYTICS.aocl_libflame_build.cmake: CMake script for building AOCL-LAPACK.aocl_libm_build.cmake: CMake script for building AOCL-LIBM.aocl_libmem_build.cmake: CMake script for building AOCL-LIBMEM.aocl_sparse_build.cmake: CMake script for building AOCL-SPARSE.aocl_utils_build.cmake: CMake script for building AOCL-UTILS.CMakeLists.txt: Main CMake script for the AOCL project.CMakePresets.json: CMake presets for different build configurations.LICENSE.txt: This is consolidated LICENSE file.NOTICES.txt: This is Third-Party Notices file.README.md: This README file.commands.txt: Build and test commands for symbol renaming feature.rename_symbols.py: Python script for renaming library symbols with custom prefix.presets/: Directory containing preset configurations for different platforms.submodules/: Directory containing AOCL library sources as git submodules.test/: Directory containing test code for validating library functionality.test/CMakeLists.txt: CMake configuration for building test executables.test/test_aocl_symbols.c: Test program to validate both original and renamed symbols.test/test_aocl_cpp.cpp: C++ test program for AOCL libraries (original + renamed symbol modes).test/test_rename_symbols_cpp.py: Python unit tests for C/C++ symbol renaming logic (mangled names, namespace/wrapper/header rewrites).
For easier access to all AOCL library sources, we have included the AOCL library sources
as git submodules under the submodules branch of the repository:
$ git clone --recurse-submodules https://github.com/AMD-AOCL/aocl.git -b submodules
$ cd aocl/submodules # Navigate to AOCL library sourcesor
$ git clone --recurse-submodules git@github.com:AMD-AOCL/aocl.git -b submodules
$ cd aocl/submodules # Navigate to AOCL library sourcesThe git submodules include: AOCL-BLAS, AOCL-Compression, AOCL-Cryptography, AOCL-DA, AOCL-LAPACK, AOCL-LibM, AOCL-LibMem, AOCL-ScaLAPACK, AOCL-Sparse, and AOCL-Utils.
Alternatively, only selected submodules can be downloaded. The following table shows the mapping between AOCL library names and their corresponding submodule names:
| AOCL Library Name | Submodule Name |
|---|---|
| AOCL-BLAS | submodules/blis |
| AOCL-Compression | submodules/aocl-compression |
| AOCL-Cryptography | submodules/aocl-crypto |
| AOCL-DA | submodules/aocl-data-analytics |
| AOCL-LAPACK | submodules/libflame |
| AOCL-LibM | submodules/aocl-libm |
| AOCL-LibMem | submodules/aocl-libmem |
| AOCL-ScaLAPACK | submodules/aocl-scalapack |
| AOCL-Sparse | submodules/aocl-sparse |
| AOCL-Utils | submodules/aocl-utils |
Example 1: Download only AOCL-BLAS, AOCL-LAPACK, and AOCL-Utils
$ git clone https://github.com/AMD-AOCL/aocl.git -b submodules
$ cd aocl
$ git submodule init
$ git submodule update submodules/blis submodules/libflame submodules/aocl-utilsExample 2: Download only AOCL-Sparse and AOCL-Compression
$ git clone https://github.com/AMD-AOCL/aocl.git -b submodules
$ cd aocl
$ git submodule init
$ git submodule update submodules/aocl-sparse submodules/aocl-compressionNote: AOCL-Utils (submodules/aocl-utils) is required as a dependency for all AOCL libraries except AOCL-BLAS.
When downloading selective submodules, ensure that submodules/aocl-utils is included unless you are only building AOCL-BLAS.
This approach provides:
- All AOCL library sources locally available
- Consistent versioning across all components
- Simplified build process without external dependencies
- Offline development capability
This section explains how to configure the CMake options and the procedure to build the unified AOCL binary on both Linux and Windows platforms. Note that the procedure to configure is the same for both OSs but the only difference is in the prerequisites for each OS.
The following sub-sections describe the process:
- Meeting the prerequisites
- Cloning the repository
- Configuring the build options
- Building the unified binary
The following dependencies must be met for installing AOCL on Linux:
-
Target CPU with support for FMA, AVX2 or higher
-
Git
-
Python
-
CMake
-
GCC, g++, and Gfortran
-
AOCC
-
OpenSSL for AOCL-Cryptography:
- Define the environment variable
OPENSSL_INSTALL_DIRto point to OpenSSL installation:
$ export OPENSSL_INSTALL_DIR=/home/user/openssl - Define the environment variable
-
Boost libraries for AOCL-Data-Analytics:
- Define the environment variable
BOOST_ROOTto point to Boost installation:
$ export BOOST_ROOT=/home/user/boost - Define the environment variable
Note
To build the AOCL-Cryptography library, the libcrypto.so and
libssl.so libraries are required. Set the OPENSSL_INSTALL_DIR
environment variable to the path where OpenSSL is installed. Ensure this
directory includes the include folder and either lib or lib64.
Within the lib or lib64 folder, verify that the libcrypto.so and
libssl.so libraries are present.
The following dependencies must be met for building AOCL on Windows:
-
Target CPU with support for FMA, AVX2 or higher
-
LLVM
-
CMake
-
Microsoft Visual Studio IDE
-
Microsoft Visual Studio tools:
- Python development
- Desktop development with C++: C++ Clang-Cl for v142 build tool(x64/x86)
-
OpenSSL for AOCL-Cryptography:
- Define the environment variable
OPENSSL_INSTALL_DIRto point to OpenSSL installation:
$ set OPENSSL_INSTALL_DIR=C:/Program Files/OpenSSL-Win64 - Define the environment variable
-
Boost libraries for AOCL-Data-Analytics.
Note
To build the AOCL-Cryptography library, the libcrypto.lib and
libssl.lib libraries are required. Set the OPENSSL_INSTALL_DIR
environment variable to the directory where OpenSSL is installed. Make
sure this directory includes the include and lib folders. Within the
lib folder, ensure that the libcrypto.lib and libssl.lib libraries
are present.
For more information on validated versions of compiler/LLVM, CMake and
Python, OpenSSL, and Boost libraries refer to Validation Matrix chapter in
AOCL userguide document.
To set up and use Build-It-Yourself, you must clone the repository, configure the build options, and build the unified binary.
First, clone the AOCL repository from GitHub:
$ git clone https://github.com/amd/aocl.git
$ cd aoclThere are multiple CMake options you can configure. The following sections explain the CMake options to:
- Include or exclude individual AOCL libraries (see CMake Options to Select Libraries).
- Provide the source code for the selected libraries by using one of
the following options:
- Setting the path of the AOCL libraries source code (see CMake Options to Set Library Source Path)
- Setting the GIT repository and tag or branch name (see CMake Options to Set GIT Repository and Tag/Branch)
- Static or Shared Library:
- Static Library
-DBUILD_SHARED_LIBS=OFF - Shared Library
-DBUILD_SHARED_LIBS=ON(default)
- Static Library
- Select Data Type (LP64 or ILP64):
- LP64
-DENABLE_ILP64=OFF(default) - ILP64
-DENABLE_ILP64=ON
- LP64
- Enable or disable threading:
- Multithreading
-DENABLE_MULTITHREADING=ON - Single threading
-DENABLE_MULTITHREADING=OFF(default)
- Multithreading
- Link Desired OpenMP library using
-DOpenMP_libomp_LIBRARY=<path to OpenMP library>when,-DENABLE_MULTITHREADING=ON.
Here is an example of a configuration command:
Linux
$ cmake -S . -B build -DCMAKE_BUILD_TYPE=Release -DBUILD_SHARED_LIBS=OFF
-DENABLE_ILP64=OFF -DENABLE_AOCL_BLAS=ON -DENABLE_AOCL_UTILS=ON
-DENABLE_AOCL_LAPACK=ON -DENABLE_MULTITHREADING=ON -DOpenMP_libomp_LIBRARY=""
-DCMAKE_INSTALL_PREFIX=$PWD/install_packageWindows
$ cmake -S . -B build -G "Visual Studio 17 2022" -DCMAKE_BUILD_TYPE=Release
-DBUILD_SHARED_LIBS=OFF -DENABLE_ILP64=OFF -DENABLE_AOCL_BLAS=ON
-DENABLE_AOCL_UTILS=ON -DENABLE_AOCL_LAPACK=ON -DENABLE_MULTITHREADING=ON -TClangCl
-DCMAKE_INSTALL_PREFIX=%CD%/install_package -DCMAKE_CONFIGURATION_TYPES=ReleaseUse the following command to build the unified binary:
$ cmake --build build --config release --target installThe AOCL project provides a set of CMake presets to simplify the configuration and build process for different platforms and compilers. Some of these presets are:
- aocl-linux-make-lp-ga-gcc-config: Linux with GNU Make and GCC
- aocl-linux-make-ilp-ga-gcc-config: Linux with GNU Make and GCC (ILP64)
- aocl-linux-make-lp-ga-aocc-config: Linux with GNU Make and AOCC
- aocl-linux-make-ilp-ga-aocc-config: Linux with GNU Make and AOCC (ILP64)
- aocl-win-msvc-lp-ga-config: Windows with Visual Studio and Clang/LLVM
- aocl-win-msvc-ilp-ga-config: Windows with Visual Studio and Clang/LLVM (ILP64)
- aocl-win-ninja-lp-ga-config: Windows with Ninja and Clang/LLVM
- aocl-win-ninja-ilp-ga-config: Windows with Ninja and Clang/LLVM (ILP64)
Details of aocl-linux-make-lp-ga-gcc-config are given here.
The aocl-linux-make-lp-ga-gcc-config preset is a convenient and
efficient way to build AOCL on Linux platforms with GCC. It provides a
stable, production-ready configuration while allowing flexibility for
customization based on specific requirements.
-
How is the Name Derived?
- aocl: Refers to AMD Optimized Libraries.
- linux: Indicates that the preset is for Linux platforms.
- make: Specifies the use of the GNU Make build system.
- lp: Refers to the LP64 data model, which is the default for most Linux systems.
- ga: Stands for General Availability Release, indicating that this preset is stable and production-ready.
- gcc: Specifies the use of the GCC compiler.
-
Default Configuration: By default, this preset builds a shared multithreaded library. It can be customized to build static or single-threaded libraries by modifying the relevant CMake variables.
- CMAKE_BUILD_TYPE:
Release(default) Specifies that the build is optimized for performance. - BUILD_SHARED_LIBS:
ONIndicates that shared libraries are built by default. - ENABLE_ILP64:
OFFConfigures the build to use the LP64 data model. - ENABLE_MULTITHREADING:
ONEnables multithreading support by default. - CMAKE_C_COMPILER:
gccSpecifies GCC as the C compiler. - CMAKE_CXX_COMPILER:
g++Specifies G++ as the C++ compiler. - CMAKE_Fortran_COMPILER:
gfortranSpecifies GFortran as the Fortran compiler.
- CMAKE_BUILD_TYPE:
-
Required Environment Variables: Before running this preset, ensure the following environment variables are set:
-
OPENSSL_INSTALL_DIR: Points to the directory where OpenSSL is installed. This is required for building the AOCL-Cryptography library. Ensure this directory contains the
includefolder and either theliborlib64folder withlibcrypto.soandlibssl.solibraries. -
ONEAPI_ROOT / oneAPI_ROOT: Specifies the root directory of the Intel oneAPI toolkit. Use ONEAPI_ROOT for Linux and oneAPI_ROOT for Windows. This is mandatory for Windows and optional for Linux. It is required if you want to use the Intel OpenMP runtime library.
- Linux: The library is typically located at:
$env{ONEAPI_ROOT}/compiler/latest/lib/libiomp5.so. - Windows: The library is typically located at:
$env{oneAPI_ROOT}/compiler/latest/lib/libiomp5md.lib.
Ensure that the appropriate environment variable (
ONEAPI_ROOToroneAPI_ROOT) is set to the correct path where the oneAPI toolkit is installed. - Linux: The library is typically located at:
-
-
Example Command to Use This Preset: To configure the build using this preset, run the following command:
$ cmake --preset aocl-linux-make-lp-ga-gcc-config --fresh
This command will set up the build environment with the predefined configuration for this preset.
-
Customization Options: You can customize the build by overriding the default CMake variables. For example:
- To build a static library, set
-DBUILD_SHARED_LIBS=OFF. - To disable multithreading, set
-DENABLE_MULTITHREADING=OFF.
For more customization options, refer to the CMake variables
configure-the-build-options{.interpreted-text role="ref"}. - To build a static library, set
The following sections provide examples of configuration and build commands on Linux using the CMake build system.
Note
Use the [-DOpenMP_libomp_LIBRARY]{.title-ref} option to link the desired OpenMP library.
Complete the following steps to build and install a single-thread AOCL:
-
Clone the AOCL from Git repository (https://github.com/amd/aocl.git).
$ git clone https://github.com/amd/aocl.git $ cd aocl -
Configure the library as required:
# CMake commands # GCC (Default) and LP64 $ cmake --preset aocl-linux-make-lp-ga-gcc-config -DENABLE_MULTITHREADING=OFF --fresh # GCC and ILP64 $ cmake --preset aocl-linux-make-ilp-ga-gcc-config -DENABLE_MULTITHREADING=OFF --fresh # AOCC and LP64 $ cmake --preset aocl-linux-make-lp-ga-aocc-config -DENABLE_MULTITHREADING=OFF --fresh # AOCC and ILP64 $ cmake --preset aocl-linux-make-ilp-ga-aocc-config -DENABLE_MULTITHREADING=OFF --fresh
-
Build the unified binary and install using the command:
$ cmake --build build --config release -j --target install
Complete the following steps to install a multi-thread AOCL:
-
Clone the AOCL from Git repository (https://github.com/amd/aocl.git).
$ git clone https://github.com/amd/aocl.git $ cd aocl -
Configure the library as required:
# CMake commands # GCC (Default) and LP64 $ cmake --preset aocl-linux-make-lp-ga-gcc-config --fresh # GCC and ILP64 $ cmake --preset aocl-linux-make-ilp-ga-gcc-config --fresh # AOCC and LP64 $ cmake --preset aocl-linux-make-lp-ga-aocc-config --fresh # AOCC and ILP64 $ cmake --preset aocl-linux-make-ilp-ga-aocc-config --fresh # GCC (Default) and LP64 with Desired OpenMP library Path $ cmake --preset aocl-linux-make-lp-ga-gcc-config --fresh -DOpenMP_libomp_LIBRARY=<path to OpenMP library>
-
Build the unified binary and install using the command:
$ cmake --build build --config Release -j --target install
Configure the Project in Command Prompt
# CMake commands using Visual Studio 17 2022 Generator
"C:\\Program Files\\Microsoft Visual Studio\\2022\\Community\\VC\\Auxiliary\\Build\\vcvarsall.bat" x64
# Clang/LLVM (Default) and LP64
$ cmake --preset aocl-win-msvc-lp-ga-config --fresh
# Clang/LLVM and ILP64
$ cmake --preset aocl-win-msvc-ilp-ga-config --fresh
# Clang/LLVM (Default) and LP64 with Desired OpenMP library Path
$ cmake --preset aocl-win-msvc-lp-ga-config --fresh -DOpenMP_libomp_LIBRARY=<path to OpenMP library># CMake commands using Ninja Generator
$ "C:\\Program Files\\Microsoft Visual Studio\\2022\\Community\\VC\\Auxiliary\\Build\\vcvarsall.bat" x64
$ set PATH="C:\\Program Files\\Microsoft Visual Studio\\2022\\Community\\Common7\\IDE\\CommonExtensions\\Microsoft\\CMake\\Ninja";%PATH%
# Clang/LLVM (Default) and LP64
$ cmake --preset aocl-win-ninja-lp-ga-config --fresh
# Clang/LLVM and ILP64
$ cmake --preset aocl-win-ninja-ilp-ga-config --fresh
# Clang/LLVM (Default) and LP64 with Desired OpenMP library Path
$ cmake --preset aocl-win-ninja-lp-ga-config --fresh -DOpenMP_libomp_LIBRARY=<path to OpenMP library>Build the Project in Command Prompt
$ cmake --build build --config Release --target installThe AOCL package will be installed in the install_package directory
which is created inside the AOCL source directory.
There are two subfolders within the install_package folder: lib and
include.
- The
includefolder contains the header files required for using the AOCL libraries in applications. - The
libfolder contains the compiled binaries:- On Linux:
libaocl.soandlibaocl.a. - On Windows:
aocl.dllandaocl.lib.
- On Linux:
The AOCL Build-It-Yourself project includes comprehensive test executables to validate library functionality.
Tests can be enabled by setting -DENABLE_TESTS=ON during CMake configuration.
Build with Tests:
cmake --preset aocl-linux-make-lp-ga-gcc-config \
-DENABLE_TESTS=ON
cd build
cmake --build . --target install -j 10
cmake --build . --target test_original_symbols -j 10
./test/test_original_symbolsTest Coverage:
- 75 test functions covering 9 AOCL libraries
- Tests include: BLAS, LAPACK, Sparse, LibM, Crypto, Compression, Data Analytics, LibMem, Utils
- Validates library functionality and API correctness
Symbol Renaming Tests:
When symbol renaming is enabled (with -DSYMBOL_RENAME_PREFIX=<prefix>), an additional test executable
test_renamed_symbols (executable) is built to validate renamed symbols:
cmake --preset aocl-linux-make-lp-ga-gcc-config \
-DENABLE_TESTS=ON \
-DSYMBOL_RENAME_PREFIX=AOCL_
cd build
cmake --build . --target install -j 10
cmake --build . --target test_original_symbols test_renamed_symbols -j 10
./test/test_original_symbols # Tests original symbols
./test/test_renamed_symbols # Tests renamed symbols with prefixNote: When symbol renaming is disabled, only test_original_symbols executable is built. When enabled, both
test_original_symbols and test_renamed_symbols (executable) executables are built simultaneously.
In addition to runtime tests, C++ symbol/header rewrite behavior is validated by unit tests in:
test/test_rename_symbols_cpp.py
These tests verify C++ mangled symbol rewriting, namespace fallback updates, API family rewrite behavior, and C++ wrapper identifier renaming in generated headers.
For detailed build commands and troubleshooting, see commands.txt in the project root.
AOCL Build-It-Yourself now supports automatic symbol renaming with custom prefixes. This feature allows multiple versions
of AOCL libraries to coexist in the same application or system without symbol conflicts. For example, you can have both
AOCL 5.1 and AOCL 5.2 installed simultaneously by using different prefixes (e.g., AOCL51_ and AOCL52_).
Key Features:
- Custom Prefix: Add any prefix to all exported symbols (e.g.,
AOCL_,AOCL51_,MYLIB_) - Case-Aware Renaming: Automatically applies correct case for different symbol types
- Symbols beginning with uppercase letters (e.g.,
DGEMM_→AOCL_DGEMM_,LAPACKE_dgetrf→AOCL_LAPACKE_dgetrf) - Symbols beginning with lowercase letters (e.g.,
cblas_dgemm→aocl_cblas_dgemm)
- Symbols beginning with uppercase letters (e.g.,
- Automatic Process: Symbol renaming happens automatically during installation
- Testing Support: Built-in test executables to validate both original and renamed symbols
Recent updates address C++ header-level renaming gaps that were not always covered by ELF symbol replacement alone.
What is now handled:
- C++ namespace fallback rewrites in wrapper headers:
namespace blis→<prefix>blis(for example,aocl_bliswith prefixaocl_, oraoclbliswith prefixaocl)namespace libflame→<prefix>libflame(for example,aocl_libflamewith prefixaocl_, oraocllibflamewith prefixaocl)
- C++ wrapper identifier rewrites in selected wrapper headers:
blis.hh(for wrapper APIs such asrotg,gemm, etc.)libflame_interface.hh(for wrapper APIs such aspotrf,getrf, etc.)
- API-family header rewrites for declarations/wrappers not present as concrete ELF symbols:
cblas_*,lapacke_*,blis_*,bli_*,da_*,aoclsparse_*
Safety rules applied during header rewrites:
- Function-like identifiers are rewritten only when they are callable tokens.
- Type/callback-like identifiers (for example, DA callback typedef names such as
*_t_*) are not rewritten. std::and C++ ABI/runtime symbols are excluded from mangled-symbol renaming.- Mangled C++ prefix token preserves caller intent for trailing underscore (for example, prefix
aoclproducesaoclfoo, whileAOCL_producesAOCL_foo).
Important: Symbol renaming is not compatible with AOCL-LibMem. LibMem uses IFUNC (indirect functions)
for runtime CPU dispatch, which requires standard C library names (memcpy, memset, etc.) and cannot be renamed.
If you enable both LibMem and symbol renaming, the build will fail with an error. To use symbol renaming,
set -DENABLE_AOCL_LIBMEM=OFF.
To enable symbol renaming, add the -DSYMBOL_RENAME_PREFIX=<prefix> option when configuring CMake:
cmake --preset aocl-linux-make-lp-ga-gcc-config \
-DENABLE_TESTS=ON \
-DSYMBOL_RENAME_PREFIX=AOCL_Configuration Options:
- With Symbol Renaming:
-DSYMBOL_RENAME_PREFIX=AOCL_(or any custom prefix) - Without Symbol Renaming: Omit the option or use
-DSYMBOL_RENAME_PREFIX=""
Build Process:
cd build
cmake --build . --target install -j 10Installation Structure:
- Original libraries:
install_package/lib/ - Renamed libraries:
install_package/renamed/lib/
1. Default AOCL_ Prefix:
cmake --preset aocl-linux-make-lp-ga-gcc-config -DSYMBOL_RENAME_PREFIX=AOCL_Result: DGEMM_ → AOCL_DGEMM_, cblas_dgemm → aocl_cblas_dgemm
2. Multi-Version Deployment:
# Build AOCL 5.1 with prefix
cmake -DSYMBOL_RENAME_PREFIX=AOCL51_ ...
# Build AOCL 5.2 with different prefix
cmake -DSYMBOL_RENAME_PREFIX=AOCL52_ ...Result: Both versions can coexist in the same application
3. Custom Company Prefix:
cmake --preset aocl-linux-make-lp-ga-gcc-config -DSYMBOL_RENAME_PREFIX=MYCOMPANY_Result: DGEMM_ → MYCOMPANY_DGEMM_, cblas_dgemm → mycompany_cblas_dgemm
This section provides a detailed reference for the CMake variables used to configure the Build-It-Yourself AOCL project. These variables allow customization of the build process, including selecting libraries and specifying source paths. Use these options to tailor the unified AOCL binary to specific requirements.
The following table lists the CMake variables used to include or exclude individual AOCL libraries.
| CMake Variable or Option | Usage |
|---|---|
| ENABLE_AOCL_UTILS | -DENABLE_AOCL_UTILS=ON (default) or -DENABLE_AOCL_UTILS=OFF to exclude from the library. |
| ENABLE_AOCL_BLAS | -DENABLE_AOCL_BLAS=OFF (default) or -DENABLE_AOCL_BLAS=ON to include in the library. |
| ENABLE_AOCL_LAPACK | -DENABLE_AOCL_LAPACK=OFF (default) or -DENABLE_AOCL_LAPACK=ON to include in the library. |
| ENABLE_AOCL_SPARSE | -DENABLE_AOCL_SPARSE=OFF (default) or -DENABLE_AOCL_SPARSE=ON to include in the library. |
| ENABLE_AOCL_CRYPTO | -DENABLE_AOCL_CRYPTO=OFF (default) or -DENABLE_AOCL_CRYPTO=ON to include in the library. |
| ENABLE_AOCL_LIBM | -DENABLE_AOCL_LIBM=OFF (default) or -DENABLE_AOCL_LIBM=ON to include in the library. |
| ENABLE_AOCL_COMPRESSION | -DENABLE_AOCL_COMPRESSION=OFF (default) or -DENABLE_AOCL_COMPRESSION=ON to include in the library. |
| ENABLE_AOCL_DA | -DENABLE_AOCL_DA=OFF (default) or -DENABLE_AOCL_DA=ON to include in the library. |
| ENABLE_AOCL_LIBMEM | -DENABLE_AOCL_LIBMEM=OFF (default) or -DENABLE_AOCL_LIBMEM=ON to include in the library. |
The following table lists additional CMake variables used to configure how selected AOCL libraries integrate and interact with each other.
| CMake Variable or Option | Usage |
|---|---|
| ENABLE_AOCL_LAPACK_BLAS_COUPLING | -DENABLE_AOCL_LAPACK_BLAS_COUPLING=OFF (default) or -DENABLE_AOCL_LAPACK_BLAS_COUPLING=ON to enable tight coupling between AOCL-LAPACK and AOCL-BLAS library. This option controls whether AOCL-LAPACK should be tightly integrated with AOCL-BLAS implementation. Note: This is different from ENABLE_AOCL_BLAS, which controls whether to include AOCL-BLAS into the unified library. |
The following table lists the CMake variable used to enable ISA-specific optimizations for AMD processors.
| CMake Variable or Option | Usage |
|---|---|
| AMD_CONFIG | -DAMD_CONFIG=<value> to enable architecture-specific optimizations. Supported values: zen, zen2, zen3, zen4, zen5, amdzen. If not specified (empty), defaults to amdzen for generic AMD builds. |
AMD_CONFIG Impact on Libraries:
- AOCL-BLAS (BLIS): Maps directly to
BLIS_CONFIG_FAMILYconfiguration. - AOCL-LAPACK (LibFlame):
zen,zen2,zen3→ AVX2-STRICT optimizationszen4,zen5→ AVX512-STRICT optimizations- Default: AVX2
- AOCL-LibM:
zen→ Static dispatch with AVX2zen2→ Static dispatch with ZEN2zen3→ Static dispatch with ZEN3zen4→ Static dispatch with ZEN4zen5→ Static dispatch with ZEN5- Default: Dynamic dispatch (runtime detection)
- AOCL-DA:
zen,zen2→znver2zen3→znver3zen4→znver4zen5→znver5amdzen→dynamic- Default:
dynamic
- AOCL-Sparse:
zen,zen2,zen3→OFF(AVX512 code paths disabled at build time)zen4,zen5,amdzen→ON(AVX512 code paths enabled at build time)- Default:
ON - Runtime dispatch remains automatic and can be guided using
AOCL_ENABLE_INSTRUCTIONS
Examples:
# Build with Zen 4 optimizations (AVX512 for LAPACK and LibM)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DAMD_CONFIG=zen4 --fresh
# Build with Zen 2 optimizations (AVX2 for LAPACK, static dispatch for LibM)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DAMD_CONFIG=zen2 --fresh
# Build with generic AMD optimizations (dynamic dispatch)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DAMD_CONFIG=amdzen --freshThe following table lists the CMake variable used to control parallel build performance.
| CMake Variable or Option | Usage |
|---|---|
| BUILD_CORES | -DBUILD_CORES=<number> to specify the number of CPU cores to use for parallel builds. If not specified (empty), automatically uses 50% of available cores to balance performance and memory usage. |
BUILD_CORES Usage:
- Auto (Default): If
BUILD_CORESis not specified or empty, the build system automatically detects available CPU cores and uses 50% of them for parallel compilation. This prevents memory exhaustion on systems with many cores. - User-Specified: Provide an exact number to use a specific core count (e.g.,
-DBUILD_CORES=8). The build system (make) will handle any invalid values appropriately.
Examples:
# Use default (50% of available cores)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config --fresh
# Use 8 cores for compilation
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DBUILD_CORES=8 --fresh
# Use all available cores (assumes 16 cores available)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DBUILD_CORES=16 --fresh
# Use single core (for debugging or low-memory systems)
$ cmake --preset aocl-linux-make-lp-ga-gcc-config -DBUILD_CORES=1 --freshNote: This option is particularly useful on high-core-count systems where using all cores simultaneously may cause memory issues during compilation of large libraries.
The following table lists CMake variables to specify the path of AOCL library sources. These variables are useful when local copies of the repositories are available, particularly in environments without internet access.
| CMake Variable or Option | Usage |
|---|---|
| UTILS_PATH | -DUTILS_PATH=<Directory Path where AOCL-Utils is present>. |
| BLAS_PATH | -DBLAS_PATH=<Directory Path where AOCL-BLAS is present>. |
| LAPACK_PATH | -DLAPACK_PATH=<Directory Path where AOCL-LAPACK is present>. |
| SPARSE_PATH | -DSPARSE_PATH=<Directory Path where AOCL-Sparse is present>. |
| CRYPTO_PATH | -DCRYPTO_PATH=<Directory Path where AOCL-Cryptography is present>. |
| LIBM_PATH | -DLIBM_PATH=<Directory Path where AOCL-LibM is present>. |
| COMPRESSION_PATH | -DCOMPRESSION_PATH=<Directory Path where AOCL-Compression is present>. |
| DA_PATH | -DDA_PATH=<Directory Path where AOCL-Data-Analytics is present>. |
| LIBMEM_PATH | -DLIBMEM_PATH=<Directory Path where AOCL-LibMem is present>. |
The following table lists CMake variables to specify the GIT repository
and tag or branch name for cloning individual AOCL libraries. If the
source code path is not provided, CMake uses the specified GIT
repository and tag or branch. This is useful for building source code
from the dev branch of individual libraries. If neither the source
code path nor the GIT repository and tag are provided, CMake defaults to
the repository and branch/tag for the AOCL stable public release.
| CMake Variable or Option | Default Value | Usage |
|---|---|---|
| UTILS_GIT_REPOSITORY | https://github.com/amd/aocl-utils.git | -DUTILS_GIT_REPOSITORY=<AOCL-Utils Repository URL> |
| UTILS_GIT_TAG | main |
-DUTILS_GIT_TAG=<AOCL-Utils Git Tag or Branch Name> |
| BLAS_GIT_REPOSITORY | https://github.com/amd/blis.git | -DBLAS_GIT_REPOSITORY=<AOCL-BLAS Repository URL> |
| BLAS_GIT_TAG | master |
-DBLAS_GIT_TAG=<AOCL-BLAS Git Tag or Branch Name> |
| LAPACK_GIT_REPOSITORY | https://github.com/amd/libflame.git | -DLAPACK_GIT_REPOSITORY=<AOCL-LAPACK Repository URL> |
| LAPACK_GIT_TAG | master |
-DLAPACK_GIT_TAG=<AOCL-LAPACK Git Tag or Branch Name> |
| SPARSE_GIT_REPOSITORY | https://github.com/amd/aocl-sparse.git | -DSPARSE_GIT_REPOSITORY=<AOCL-Sparse Repository URL> |
| SPARSE_GIT_TAG | master |
-DSPARSE_GIT_TAG=<AOCL-Sparse Git Tag or Branch Name> |
| CRYPTO_GIT_REPOSITORY | https://github.com/amd/aocl-crypto.git | -DCRYPTO_GIT_REPOSITORY=<AOCL-Cryptography Repository URL> |
| CRYPTO_GIT_TAG | main |
-DCRYPTO_GIT_TAG=<AOCL-Cryptography Git Tag or Branch Name> |
| LIBM_GIT_REPOSITORY | https://github.com/amd/aocl-libm-ose.git | -DLIBM_GIT_REPOSITORY=<AOCL-LibM Repository URL> |
| LIBM_GIT_TAG | master |
-DLIBM_GIT_TAG=<AOCL-LibM Git Tag or Branch Name> |
| COMPRESSION_GIT_REPOSITORY | https://github.com/amd/aocl-compression.git | -DCOMPRESSION_GIT_REPOSITORY=<AOCL-Compression Repository URL> |
| COMPRESSION_GIT_TAG | amd-main |
-DCOMPRESSION_GIT_TAG=<AOCL-Compression Git Tag or Branch Name> |
| DA_GIT_REPOSITORY | https://github.com/amd/aocl-data-analytics.git | -DDA_GIT_REPOSITORY=<AOCL-Data-Analytics Repository URL> |
| DA_GIT_TAG | main |
-DDA_GIT_TAG=<AOCL-Data-Analytics Git Tag or Branch Name> |
| LIBMEM_GIT_REPOSITORY | https://github.com/amd/aocl-libmem.git | -DLIBMEM_GIT_REPOSITORY=<AOCL-LibMem Repository URL> |
| LIBMEM_GIT_TAG | main |
-DLIBMEM_GIT_TAG=<AOCL-LibMem Git Tag or Branch Name> |