A rust version SPDM implementation.
It is derived from https://github.com/DMTF/libspdm.
All documents are put at doc folder.
git clone https://github.com/jyao1/rust-spdm.git
git submodule update --init --recursive
- Install RUST
Please use nightly-2022-08-08.
- Install NASM
Please make sure nasm can be found in PATH.
- Install LLVM
Please make sure clang can be found in PATH.
-
Install Perl
- This is for crate ring
- This is for windows
Please make sure perl can be found in PATH.
For OS build, unset env (CC and AR):
set CC=
set AR=
For no_std
builds, set the following environment variables:
set AR_x86_64_unknown_uefi=llvm-ar
set CC_x86_64_unknown_uefi=clang
Replace set
with export
if you use Linux or the like.
cargo clippy
cargo fmt
cargo build
pushd spdmlib
cargo build -Z build-std=core,alloc,compiler_builtins --target x86_64-unknown-uefi --release --no-default-features --features="spdm-ring"
Open one command windows and run:
cargo run -p spdm-responder-emu
Open another command windows and run:
cargo run -p spdm-requester-emu
Cross test with spdm_emu is supported,
Open one command windows in workspace and run:
git clone https://github.com/DMTF/spdm-emu.git
cd spdm-emu
git submodule update --init --recursive
mkdir build
cd build
cmake -G"NMake Makefiles" -DARCH=<x64|ia32> -DTOOLCHAIN=<toolchain> -DTARGET=<Debug|Release> -DCRYPTO=<mbedtls|openssl> ..
nmake copy_sample_key
nmake
cd bin
spdm_responder_emu.exe
In root folder of rust spdm repo, open a command window and run:
cargo run -p spdm-requester-emu
cargo test
This package is only the sample code to show the concept. It does not have a full validation such as robustness functional test and fuzzing test. It does not meet the production quality yet. Any codes including the API definition, the libary and the drivers are subject to change.