commit | bd05e5783f14f3b62e57136404c61685a1867b5c | [log] [tgz] |
---|---|---|
author | Harrison Mutai <harrison.mutai@arm.com> | Wed Apr 16 14:20:35 2025 +0000 |
committer | Harrison Mutai <harrison.mutai@arm.com> | Fri Jun 13 11:25:35 2025 +0000 |
tree | 50bd86d0a9783190a777382e7f9f5923980c431e | |
parent | 7fb41222c596dcb5f9aee983f3cc7bd401f30637 [diff] |
fix: avoid macro redefinition by namespacing helpers Rename is_aligned and align_up to libtl_* variants and move header to private include path. Prevents clashes with external projects that define similar macros (e.g., TF-A). Change-Id: I7e13efa55fe120dccc68d2a941dea7cdd1f005a6 Signed-off-by: Harrison Mutai <harrison.mutai@arm.com>
The Transfer List Library (LibTL) implements the Firmware Handoff specification, providing a streamlined interface for managing transfer lists. LibTL offers a user-friendly interface for:
The library supports building with host tools such as Clang and GCC, and cross compilation with the Aarch64 GNU compiler.
Tool | Minimum Version |
---|---|
Clang-Format | 14 |
CMake | 3.15 |
To configure the project, use the following command. This will default to using GCC as the toolchain and create a build directory named build/
:
cmake -B build
To build the project, use:
cmake --build build
This will output libtl.a in the build directory.
For cross-compilation or selecting a different compiler, specify the target toolchain file using the CMAKE_TOOLCHAIN_FILE
option and the target with CROSS_COMPILE
:
export CROSS_COMPILE=aarch64-none-elf- cmake -B build -DCMAKE_TOOLCHAIN_FILE=toolchains/host/gnu.cmake
Tests for LibTL are provided in the folder test
, to configure the project for test builds, run:
cmake -B build -DTARGET_GROUP=test cmake --build build
Then, to run the tests with ctest
, use:
ctest --test-dir build/