Skip to content

FPGA verilog and firmware for TKey, the flexible and open USB security key ๐Ÿ”‘

Notifications You must be signed in to change notification settings

tillitis/tillitis-key1

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

ci

Tillitis TKey

TK1 PCB The TK1 PCB, also known as TKey.

Introduction

The Tillitis TKey is an open source, open hardware FPGA-based USB security token using DICE-like unconditional measured boot that can run generic applications while still guaranteeing the security of its cryptographic assets.

TKey Threat Model.

With the right application, the TKey can be used for:

  • authentication,
  • cryptographic signing,
  • encryption,
  • root of trust,
  • and more: it's a general computer!

If you want to know more about Tillitis and the TKey, visit:

All of the TKey software, firmware, FPGA Verilog code, schematics and PCB design files are open source, just like all trustworthy security software and hardware should be.

Licensing

See LICENSES for more information about the projects' licenses.

Repositories

This repository contains the FPGA design, the source of the firmware/bootloader, and the source of the USB controller firmware.

Specific documentation regarding implementation is kept close to the code/design in README files, typically in the same directory.

Note that development is ongoing. To avoid unexpected changes of derived key material, please use a tagged release. Read the Release Notes to keep up to date with changes and new releases.

The TKey PCB KiCad design files are kept in a separate repository:

https://github.com/tillitis/tk1-pcba

The TP1 (TKey programmer 1) PCB design files and the firmware sources are kept in:

https://github.com/tillitis/tp1

Note that the TP1 is only used for provisioning the FPGA bitstream into flash or the FPGA configuration memory. It's not necessary if you just want to develop apps for the TKey.

Measured boot

The key behind guaranteeing security even as a general computer is the unconditional measured boot. This means that we have a small, unchangeable, trusted firmware in ROM that creates a unique identity before starting the application. This identity is used as a seed for all later cryptographic keys.

We call this identity the Compound Device Identity (CDI). The CDI is a cryptographic mix of:

  1. the Unique Device Secret (UDS), a hardware secret, unique per device, something the user has,
  2. the hash digest of the TKey device application that has been loaded, the integrity of the application, and,
  3. an optional User Supplied Secret (USS), something the user knows.

CDI is computed using the BLAKE2s hash function:

CDI = BLAKE2s(UDS, BLAKE2s(application loaded in RAM), USS)

When firmware is about to start the device application it changes the TKey to a less permissive hardware mode, application mode. In application mode the UDS and the User Supplied Secret are no longer available, but the device application can use the CDI as a seed to deterministically generate any cryptographic keys it needs.

  • If the wrong application has been loaded, or the original application has been tampered with, the generated keys will be different.
  • If the USS is not the same, the generated keys will be different.
  • If the same USS and device application is used on a different TKey, the generated keys will be different.

The TKey unconditional measured boot is inspired by, but not exactly the same as part of TCG DICE.