Builds a Ledger device embedded app and outputs a JSON/TOML manifest file that can be used by ledgerctl to install an application directly on a device.
In order to build for Nano X, Nano S Plus, Stax and Flex custom target files are used. They can be found at the root of the ledger_secure_sdk_sys and can be installed automatically with the command cargo ledger setup
.
This program requires:
arm-none-eabi-objcopy
ledgerctl
Install this repo with:
cargo install --git https://github.com/LedgerHQ/cargo-ledger
or download it manually and install with:
cargo install cargo-ledger
Note that cargo
's dependency resolver may behave differently when installing, and you may end up with errors.
In order to fix those and force usage of the versions specified in the tagged Cargo.lock
, append --locked
to the above commands.
General usage is displayed when invoking cargo ledger
.
This will install custom target files from the SDK directly into your environment.
cargo ledger setup
cargo ledger build nanox
cargo ledger build nanosplus
cargo ledger build stax
cargo ledger build flex
Loading on device can optionally be performed by appending --load
or -l
to the command.
By default, this program will attempt to build the current program with in release
mode (full command: cargo build --release --target=nanosplus --message-format=json
)
Arguments can be passed to modify this behaviour after inserting a --
like so:
cargo ledger build nanosplus --load -- --features one -Z unstable-options --out-dir ./output/