Build ICICLE from source
This guide will help you get started with building, testing, and installing ICICLE, whether you're using C++, Rust, or Go. It also covers installation of the CUDA backend and important build options.
Building and Testing ICICLE frontend
C++: Build, Test, and Install (Frontend)
ICICLE can be built and tested in C++ using CMake. The build process is straightforward, but there are several flags you can use to customize the build for your needs.
Build Commands
-
Clone the ICICLE repository:
git clone https://github.com/ingonyama-zk/icicle.git
cd icicle -
Configure the build:
mkdir -p build && rm -rf build/*
cmake -S icicle -B build -DFIELD=babybear
To specify the field, use the flag -DFIELD=field, where field can be one of the following: babybear, stark252, m31, koalabear.
To specify a curve, use the flag -DCURVE=curve, where curve can be one of the following: bn254, bls12_377, bls12_381, bw6_761, grumpkin.
If you have access to cuda backend repo, it can be built along ICICLE frontend by adding the following to the cmake command
-DCUDA_BACKEND=local
# if you have it locally-DCUDA_BACKEND=<commit|branch>
# to pull CUDA backend, given you have access
-
Build the project:
cmake --build build -j
This is building the libicicle_device and the libicicle_field_babybear frontend lib that correspond to the field or curve.
-
Link: Link you application (or library) to ICICLE:
target_link_libraries(yourApp PRIVATE icicle_field_babybear icicle_device)
- Installation (optional):
To install the libs, specify the install prefix in the cmake command
-DCMAKE_INSTALL_PREFIX=/install/dir/
. Default install path on linux is/usr/local
if not specified. For other systems it may differ. The cmake command will print it to the log
-- CMAKE_INSTALL_PREFIX=/install/dir/for/cmake/install
Then after building, use cmake to install the libraries:
cmake -S icicle -B build -DFIELD=babybear -DCMAKE_INSTALL_PREFIX=/path/to/install/dir/
cmake --build build -j # build
cmake --install build # install icicle to /path/to/install/dir/
- Run tests (optional):
Add
-DBUILD_TESTS=ON
to the cmake command and build. Execute all tests
cmake -S icicle -B build -DFIELD=babybear -DBUILD_TESTS=ON
cmake --build build -j
cd build/tests
ctest
or choose the test-suite
./build/tests/test_field_api # or another test suite
# can specify tests using regex. For example for tests with ntt in the name:
./build/tests/test_field_api --gtest_filter="*ntt*"
Most tests assume a cuda backend exists and will fail otherwise if cannot find a CUDA device.
Build Flags
You can customize your ICICLE build with the following flags:
-DCPU_BACKEND=ON/OFF
: Enable or disable built-in CPU backend.default=ON
.-DCMAKE_INSTALL_PREFIX=/install/dir
: Specify install directory.default=/usr/local
.-DBUILD_TESTS=ON/OFF
: Enable or disable tests.default=OFF
.-DBUILD_BENCHMARKS=ON/OFF
: Enable or disable benchmarks.default=OFF
.
Features
By default, all features are enabled. This is since installed backends may implement and register all APIs. Missing APIs in the frontend would cause linkage to fail due to missing symbols. Therefore by default we include them in the frontend part too.
To disable features, add the following to the cmake command.
- ntt:
-DNTT=OFF
- msm:
-DMSM=OFF
- g2 msm:
-DG2=OFF
- ecntt:
-DECNTT=OFF
- extension field:
-DEXT_FIELD=OFF
Disabling features is useful when developing with a backend that is slow to compile (e.g. CUDA backend);
Rust: Build, Test, and Install
To build and test ICICLE in Rust, follow these steps:
- Navigate to the Rust bindings directory:
cd wrappers/rust # or go to a specific field/curve 'cd wrappers/rust/icicle-fields/icicle-babybear'
- Build the Rust project:
cargo build --release
By default, all supported features are enabled. Cargo features are used to disable features, rather than enable them, for the reason explained here:
no_g2
to disable G2 MSMno_ecntt
to disable ECNTT
They can be disabled as follows:
cargo build --release --features=no_ecntt,no_g2
If you have access to cuda backend repo, it can be built along ICICLE frontend by using the following cargo features:
cuda_backend
: if the cuda backend resides inicicle/backend/cuda
pull_cuda_backend
: to pull main branch and build it
- Run tests:
cargo test # optional: --features=no_ecntt,no_g2,cuda_backend
Most tests assume a CUDA backend is installed and fail otherwise.
- Install the library:
By default, the libraries are installed to the target/<buildmode>/deps/icicle
dir. If you want them installed elsewhere, define the env variable:
export ICICLE_INSTALL_DIR=/path/to/install/dir
Use as cargo dependency
In cargo.toml, specify the ICICLE libs to use:
[dependencies]
icicle-runtime = { git = "https://github.com/ingonyama-zk/icicle.git", branch="main" }
icicle-core = { git = "https://github.com/ingonyama-zk/icicle.git", branch="main" }
icicle-babybear = { git = "https://github.com/ingonyama-zk/icicle.git", branch="main" }
# add other ICICLE crates here if need additional fields/curves
Can specify branch = <branch-name>
or tag = <tag-name>
or rev = <commit-id>
.
To disable features:
icicle-bls12-377 = { git = "https://github.com/ingonyama-zk/icicle.git", features = ["no_g2"] }
As explained above, the libs will be built and installed to target/<buildmode>/deps/icicle
so you can easily link to them. Alternatively you can set ICICLE_INSTALL_DIR
env variable for a custom install directory.
Make sure to install icicle libs when installing a library/application that depends on icicle such that it is located at runtime.
Go: Build, Test, and Install (TODO)
To install CUDA backend and license click here