This guide follows the Secure Boot Specification for td-shim.
cargo xbuild -p td-shim --target x86_64-unknown-uefi --release --features=main,tdx,secure-boot
Refer to README, using ELF as example:
cargo xbuild -p td-payload --target devtools/rustc-targets/x86_64-unknown-none.json --release --features=main,tdx
- ECDSA NIST P384
Run below command to generate a DER encoded PKCS8 formate EC private key file (on Linux):
openssl genpkey -algorithm EC \
-pkeyopt ec_paramgen_curve:P-384 \
-pkeyopt ec_param_enc:named_curve \
-outform der -out ecdsa-p384-private.der
openssl pkcs8 -topk8 -nocrypt -inform der -in ecdsa-p384-private.der -outform der -out ecdsa-p384-private.pk8
Generate public key file with private key:
openssl ec -inform der -in ecdsa-p384-private.der -pubout -outform der -out ecdsa-p384-public.der
- RSA 3072
Run below command to generate a DER encoded PKCS8 formate RSA private key file (on Linux).
openssl genpkey -algorithm RSA \
-pkeyopt rsa_keygen_bits:3072 \
-pkeyopt rsa_keygen_pubexp:65537 | \
openssl pkcs8 -topk8 -nocrypt -outform der > rsa-3072-private.pk8
Generate public key file with private key:
openssl rsa -inform der -in rsa-3072-private.pk8 -pubout -outform der -out rsa-3072-public.der
Sign payload with rust-tdpayload-signing
Using ECDSA NIST P384 as example:
Set environment varibles CC and AR:
set CC=clang
set AR=llvm-ar
Run the signing tool:
cargo run -p td-shim-tools --bin td-shim-sign-payload -- -A ECDSA_NIST_P384_SHA384 data/sample-keys/ecdsa-p384-private.pk8 target/x86_64-unknown-none/release/td-payload 1 1
The signed payload file td-payload-signed is located in the same folder with input td-payload
.
Enroll public key into CFV with rust-tdshim-key-enroll
Build final.bin:
cargo run -p td-shim-tools --bin td-shim-ld -- target/x86_64-unknown-uefi/release/ResetVector.bin target/x86_64-unknown-uefi/release/td-shim.efi -p target/x86_64-unknown-none/release/td-payload-signed -o target/x86_64-unknown-uefi/release/final.bin
Enroll public key:
cargo run -p td-shim-tools --bin td-shim-enroll -- target/x86_64-unknown-uefi/release/final.bin -H SHA384 -k data/sample-keys/ecdsa-p384-public.der
The output file final.sb.bin with secure boot enabled is located in the same folder with input final.bin.