mirror of
https://github.com/linuxboot/heads.git
synced 2025-01-18 18:57:04 +00:00
31cf85b707
The Librem Key is a custom device USB-based security token Nitrokey is producing for Purism and among other things it has custom firmware created for use with Heads. In particular, when a board is configured with CONFIG_LIBREMKEY, this custom firmware allows Heads to use the sealed TOTP secret to also send an HOTP authentication to the Librem Key. If the HOTP code is successful, the Librem Key will blink a green LED, if unsuccessful it will blink red, thereby informing the user that Heads has been tampered with without requiring them to use a phone to validate the TOTP secret. Heads will still use and show the TOTP secret, in case the user wants to validate both codes (in case the Librem Key was lost or is no longer trusted). It will also show the result of the HOTP verification (but not the code itself), even though the user should trust only what the Librem Key displays, so the user can confirm that both the device and Heads are in sync. If HOTP is enabled, Heads will maintain a new TPM counter separate from the Heads TPM counter that will increment each time HOTP codes are checked. This change also modifies the routines that update TOTP so that if the Librem Key executables are present it will also update HOTP codes and synchronize them with a Librem Key.
20 lines
653 B
Plaintext
20 lines
653 B
Plaintext
modules-$(CONFIG_LIBREMKEY) += libremkey-hotp-verification
|
|
|
|
libremkey-hotp-verification_depends := libusb $(musl_dep)
|
|
|
|
libremkey-hotp-verification_version := git
|
|
libremkey-hotp-verification_dir := libremkey-hotp-verification
|
|
libremkey-hotp-verification_repo := --recursive https://github.com/Nitrokey/nitrokey-hotp-verification
|
|
|
|
libremkey-hotp-verification_target := \
|
|
$(MAKE_JOBS) \
|
|
$(CROSS_TOOLS) \
|
|
|
|
libremkey-hotp-verification_output := \
|
|
libremkey_hotp_verification \
|
|
libremkey_hotp_initialize
|
|
|
|
libremkey-hotp-verification_configure := \
|
|
INSTALL="$(INSTALL)" \
|
|
cmake -DCMAKE_TOOLCHAIN_FILE=./Toolchain-heads.cmake -DCMAKE_AR="$(CROSS)ar" .
|