#efi #uefi #pe #authenticode #secure-boot

nightly efi_signer

A crates for signing and parsing EFI image

11 releases

0.2.8 Dec 18, 2024
0.2.7 Nov 13, 2023
0.2.4 Jun 29, 2023
0.2.2 May 21, 2023
0.1.1 May 4, 2023

#470 in Cryptography

Download history 16/week @ 2024-10-20 13/week @ 2024-10-27 27/week @ 2024-11-03 15/week @ 2024-11-10 21/week @ 2024-11-17 21/week @ 2024-11-24 132/week @ 2024-12-01 283/week @ 2024-12-08 209/week @ 2024-12-15 59/week @ 2024-12-22 66/week @ 2024-12-29 90/week @ 2025-01-05 72/week @ 2025-01-12 24/week @ 2025-01-19 28/week @ 2025-01-26 42/week @ 2025-02-02

175 downloads per month

MulanPSL-2.0

1MB
860 lines

Contains (DOS exe, 1MB) tests/shimx64.efi.dualsigned, (DOS exe, 1MB) tests/shimx64.efi, (DOS exe, 1MB) tests/shimx64.efi.signed

EFI_SIGNER

Coverage Status cargo license

A pure rust library to sign/verify the EFI image.

HOWs

see examples

how to sign a EFI image

  1. generate certificates

    bash -ex scripts/make_codesign_cert.sh
    
  2. sign a EFI image

    ./main sign --key key.pem --cert certificate.p7b shimx64.efi shimx64.efi.signed
    
  3. sign a EFI image with detached signature

    ./main sign --key key.pem --cert certificate.p7b -d shimx64.efi efi.signed
    

    the efi.signed file will onlyl contain the signature itself which can be used by set_authenticode

how to parse the EFI image

./main --verbose parse shimx64.efi

Dependencies

~19–36MB
~576K SLoC