mirror of
https://github.com/tillitis/tillitis-key1.git
synced 2025-01-17 02:17:14 -05:00
Add a lot of content about the application FPGA
Signed-off-by: Joachim Strömbergson <joachim@assured.se>
This commit is contained in:
parent
ffa6236243
commit
579a8fd053
@ -1,39 +1,148 @@
|
||||
# The TKey FPGA
|
||||
|
||||
## Introduction
|
||||
The TKey
|
||||
The TKey application FPGA (application_fpga design) contain
|
||||
the application platform CPU system onto which secure applications
|
||||
are loaded, measured and executed. The platform is a compact
|
||||
System on Chip (SoC) with the following cores.
|
||||
|
||||
![The Application FPGA block diagram](../images/application_fpga_block_diagram.png)
|
||||
|
||||
The application FPGA is currently implemented using a Lattice
|
||||
[iCE40 UltraPlus UP5K device](https://www.latticesemi.com/en/Products/FPGAandCPLD/iCE40UltraPlus).
|
||||
Only open tools are used in the toolchain.
|
||||
|
||||
|
||||
### Top level
|
||||
|
||||
The top level application_fpga design contain instances of all cores as
|
||||
well as the memory system. The memory system allows the CPU to access
|
||||
cores in different ways given the current exection mode. There are two
|
||||
execution modes - firmware and application. Basically, in application mode
|
||||
the access is more restrictive.
|
||||
|
||||
The API for all cores is described in XYZ.
|
||||
|
||||
### Cores
|
||||
|
||||
#### Clock and reset
|
||||
|
||||
|
||||
#### CPU
|
||||
PicoRV32.
|
||||
The CPU core is an instance of the [PicoRV32 core](https://github.com/YosysHQ/picorv32).
|
||||
The instance enables the following features
|
||||
|
||||
- Compressed ISA (C extension)
|
||||
- Fast multiplication. Two cycles for 32x32 multiplication
|
||||
- Barrel shifter
|
||||
|
||||
No other modification to the core has been done.
|
||||
No interrupts are used.
|
||||
|
||||
|
||||
#### Clock and reset
|
||||
|
||||
The device does not rely on external clock or reset. Instead the
|
||||
internal HFOSC oscillator combined with an internal PLL is used to generate
|
||||
the main clock. Currently the clock frequency driving the SoC is 18 MHz.
|
||||
|
||||
The device also generates its own reset.
|
||||
|
||||
|
||||
#### FW ROM
|
||||
|
||||
The ROM memory containing the firmware. After reset the CPU will
|
||||
read from the ROM to load, measure and start applications.
|
||||
|
||||
The RAM memort is only accessible by the firmware.
|
||||
|
||||
|
||||
#### FW RAM
|
||||
|
||||
A 512w32 small RAM only accessible by the firmware. The firmware
|
||||
use the RAM during loading and measurement of the application.
|
||||
|
||||
|
||||
#### UDS
|
||||
|
||||
Unique Device Secret memory.
|
||||
|
||||
A 256 bit memory implemented using separate registers. The
|
||||
registers can only be accessed once between power cycling.
|
||||
Only the firmware can access the UDS memory core.
|
||||
|
||||
|
||||
#### Application RAM
|
||||
|
||||
The 128 KByte main RAM. The RAM is only used by applications.
|
||||
The memory is cleared by firmware before an application is loaded.
|
||||
|
||||
The application RAM is available to use by firmware and applications.
|
||||
|
||||
|
||||
#### Timer
|
||||
|
||||
A general purpose 32 bit timer. The timer will count down from
|
||||
the initial value to one. In order to handle long time sequences
|
||||
(minutes, hours, days) there is also a 32 bit prescaler.
|
||||
|
||||
The timer is available to use by firmware and applications.
|
||||
|
||||
|
||||
#### UART
|
||||
|
||||
A standard UART interface for receiving bytes from and send bytes
|
||||
to the host via the interface MCU on the TKey.
|
||||
|
||||
The UART default speed is 62500 bps, but can be adjusted by the
|
||||
application. (Note that the host must set the same bitrate too.)
|
||||
|
||||
The UART contain a 512 but Rx-FIFO with status (data available).
|
||||
|
||||
The timer is available to use by firmware and applications.
|
||||
|
||||
|
||||
#### TRNG
|
||||
|
||||
The TRNG is a ring oscillator based internal entropy source.
|
||||
By default the TRNG use 32 free running digital oscillators. By
|
||||
default, the oscillators are sampled after 4096 cycles. The
|
||||
states are XOR combined to create a single bit. After another
|
||||
4096 cycles a second bit is created, and the two bits are
|
||||
XOR combined to a single entropy bit. The entropy bit is
|
||||
added to a 32 bit entropy word.
|
||||
|
||||
#### TK1
|
||||
After 32 bits has been collected, the data ready flag is set,
|
||||
indicating that an entropy word is ready for consumption. Note
|
||||
that entropy bit generation and collections is running continuously,
|
||||
bits will be added, and the discarded after 32 more bits have
|
||||
been added.
|
||||
|
||||
If a data word has been read from the TRNG, by default at least
|
||||
32 bits will collected before new data will be available.
|
||||
|
||||
The timer is available to use by firmware and applications.
|
||||
|
||||
|
||||
#### TKey
|
||||
|
||||
The TKey core contains several functions, and acts as
|
||||
main HW interface between firmware and applications. The core
|
||||
includes:
|
||||
|
||||
- Read access to the 64 bit FPGA design name, expressed as ASCII chars.
|
||||
- Read access to the 32 bit FPGA design version, expressed as an integer
|
||||
|
||||
- Control and status access for the RGB LED on TKey board
|
||||
- Control ans status access for the 4 GPIOs on the TKey board
|
||||
|
||||
- Application read access to information about the loaded
|
||||
application. The information is written by the firmware.
|
||||
- Start address
|
||||
- Size of address
|
||||
|
||||
- Application read access to the CDI generated and written
|
||||
by the firmware when the application is loaded.
|
||||
|
||||
- Application-Firmware execution mode control. Can be read
|
||||
by the application and written by firmware. When written
|
||||
to by the firmware, the hardware will switch to application
|
||||
mode and start executing the application.
|
||||
|
Loading…
Reference in New Issue
Block a user