99efb78ed8
- We're OK with USS not being loaded, and use an all-zero USS if so. - We require USS to be loaded before app_size (if at all). |
||
---|---|---|
contrib | ||
doc | ||
hw | ||
LICENSES | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
README.md |
Tillitis Key 1
Introduction
Tillitis Key 1 is a new kind of USB security token. All of its software, FPGA logic, schematics, and PCB layout are open source, as all security software and hardware should be. This in itself makes it different, as other security tokens utilize closed source hardware for its security-critical operations.
What makes the Tillitis Key 1 security token unique is that it doesn’t verify applications, it measures them (hashes a digest over the binary), before running them on its open hardware security processor.
Each security token contains a Unique Device Secret (UDS), which together with an application measurement, and an optional user-provided seed, is used to derive key material unique to each application. This allows users to build and load their own apps, while ensuring that each app loaded will have its own cryptographic identity. The design is similar to TCG DICE. The Tillitis Key 1 platform allows for applications up to 64 KB.
The first implementation is the Tillitis Key 1:
Documentation
- System Description
- Threat Model
- Framing Protocol
- Boards
- Firmware
- Toolchain setup
- Quickstart to program the Tillitis Key 1
- Release Notes
About this repository
This repository contains hardware, software and utilities written as part of the Tillitis Key 1 project. It is structured as monolithic repository, or "monorepo", where all components live in one repository.
The repository follows the OpenTitan layout.
Licensing
See LICENSES for more information about the projects' licenses.