Apart from cloning, be sure you get all the sub-modules, by calling:
git submodule update --init --recursive
This project requires ledger firmware 1.5.5
The current repository keeps track of Ledger's SDK but it is possible to override it by changing the git sub-module.
CircleCI allows compiling BOLOS firmware both in Linux and MacOS. The CLI will download a docker container ready to run.
To install, follow the instructions here:
CircleCI CLI should have instructed you to install Docker. Just in case, you can find instructions here too:
Install the following packages:
sudo apt-get update && sudo apt-get -y install build-essential git sudo wget cmake libssl-dev libgmp-dev autoconf libtool python-pip
It is recommended that you install brew and xcode.
Additionally you will need to:
brew install libusb
Ledger firmware 1.5.5 requires ledgerblue >= 0.1.21.
In most cases, make deps should be able to install all dependencies:
There are different local builds:
Generic C++ code and run unit tests
This is useful when you want to make changes to libraries, run unit tests, etc. It will build all common libraries and unit tests.
cmake . && make
In Case Above Command didn't work, use the command given below. It will compile local code but it will not try to cross compile the apps. Typically this is more efficient too.
cmake -DDISABLE_DOCKER_BUILDS=ON . && make
export GTEST_ANTLIA=1 && ctest -VV
In order to keep builds reproducible, a Makefile is provided.
The Makefile will build the firmware in a docker container and leave the binary in the correct directory.
The following command will build the app firmware inside a container. All output will be available to the host.
make # Builds both Antlia and Tendermint apps
The following command will upload the application to the ledger. Warning: The application will be deleted before uploading.
make load_antlia # Loads Antlias app (for users)make load_tendermint # Loads Tendermint app (for validators)
This will build in a docker image identical to what CircleCI uses. This provides a clean, reproducible environment. It also can be helpful to debug CI issues.
To build in ubuntu 16.04 and run C++ unit tests
To build BOLOS firmware
circleci build --job build_ledger_usercircleci build --job build_ledger_val