A utility to split a SEP firmware into its various modules, made in Rust.
- Install
cargo
if you haven't already, instructions are here - Run
cargo install --path /path/to/sepsplit-rs/
- Run the executable with
sepsplit-rs
In order to get the program to compile, you may need to
- Install LLVM as shown here
- Either comment out or modify line 52 in
lzvn_decode.c
in the lzvn repo to#define _LZVN_DEBUG_DUMP(...)
if you are using the MSVC compiler.
sepsplit-rs /path/to/sep-firmware.bin [output folder]
The SEP firmware has to be decrypted and extracted.
- Use
./src/seplib.h
as the header for importing the function. - Compile a static library with
cargo rustc --lib --crate-type staticlib
. - Finally, run the main logic of the program with
split(const char* filein, const char* outdir, unsigned int verbose)
, replacing the parameters with arguments with the necessary safety requirements listed in the header.
cd
into the project- Run
./download_testfws.sh
to download test SEP Firmwares - Run the tests with
cargo test
- xerub for the original sepsplit and the fork of LZVN
- matteyeux for helping me test this program
- mrmacete for the 64-bit version