1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-14 01:10:58 +00:00
Go to file
Pavol Rusnak 62e07befeb Merge pull request #1 from hiviah/docker_gpg_fix
Pin GPG key of ARM GCC repo by full fingerprint in Docker build
2014-06-25 14:33:38 +02:00
demo import v1.0.0 2014-04-29 14:38:32 +02:00
firmware better UI for layoutSignMessage, layoutVerifyMessage and layoutCipherKeyValue 2014-06-21 00:31:44 +02:00
gen import v1.0.0 2014-04-29 14:38:32 +02:00
trezor-common@bf7b99fd28 implement ClearSession 2014-06-17 16:03:07 +02:00
trezor-crypto@e588906f81 adapt to new aes api 2014-06-09 19:00:07 +02:00
.gitignore small changes to scripts for deterministic builds 2014-06-19 02:31:07 +02:00
.gitmodules import v1.0.0 2014-04-29 14:38:32 +02:00
buttons.c import v1.0.0 2014-04-29 14:38:32 +02:00
buttons.h adapt to new opencm3 include structure 2014-06-19 00:12:31 +02:00
COPYING import v1.0.0 2014-04-29 14:38:32 +02:00
Dockerfile Pin GPG key of ARM GCC repo by full fingerprint in Docker build 2014-06-25 14:25:30 +02:00
firmware-docker-build.sh small changes to scripts for deterministic builds 2014-06-19 02:31:07 +02:00
firmware-fingerprint.sh small changes to scripts for deterministic builds 2014-06-19 02:31:07 +02:00
layout.c import v1.0.0 2014-04-29 14:38:32 +02:00
layout.h import v1.0.0 2014-04-29 14:38:32 +02:00
Makefile import v1.0.0 2014-04-29 14:38:32 +02:00
Makefile.include small changes to scripts for deterministic builds 2014-06-19 02:31:07 +02:00
memory_app_0.0.0.ld import v1.0.0 2014-04-29 14:38:32 +02:00
memory_app_1.0.0.ld import v1.0.0 2014-04-29 14:38:32 +02:00
memory.c adapt to new opencm3 include structure 2014-06-19 00:12:31 +02:00
memory.h import v1.0.0 2014-04-29 14:38:32 +02:00
memory.ld import v1.0.0 2014-04-29 14:38:32 +02:00
oled.c adapt to new opencm3 include structure 2014-06-19 00:12:31 +02:00
oled.h import v1.0.0 2014-04-29 14:38:32 +02:00
README Fixed docker build howto 2014-06-22 19:29:28 +02:00
rng.c adapt to new opencm3 include structure 2014-06-19 00:12:31 +02:00
rng.h import v1.0.0 2014-04-29 14:38:32 +02:00
serialno.c import v1.0.0 2014-04-29 14:38:32 +02:00
serialno.h import v1.0.0 2014-04-29 14:38:32 +02:00
setup.c adapt to new opencm3 include structure 2014-06-19 00:12:31 +02:00
setup.h import v1.0.0 2014-04-29 14:38:32 +02:00
util.c import v1.0.0 2014-04-29 14:38:32 +02:00
util.h import v1.0.0 2014-04-29 14:38:32 +02:00

TREZOR firmware

http://bitcointrezor.com/

How to build Trezor firmware?
=============================
1. Install Docker (docker.com)
2. git clone https://github.com/trezor/trezor-mcu.git
3. cd trezor-mcu
4. sudo ./firmware-docker-build.sh (sudo may be needed on some distros because of Docker)

This generates trezor.bin in current directory and prints sha256 fingerprint on last line of build log.

How to get sha256 fingerprint of firmware signed and distributed by SatoshiLabs?
================================================================================
1. Pick proper version of firmware binary listed on https://mytrezor.com/data/firmware/releases.json
2. Download it: wget -O trezor.signed.bin.hex https://mytrezor.com/data/firmware/trezor-1.1.0.bin.hex
3. xxd -r -p trezor.signed.bin.hex trezor.signed.bin
4. ./firmware-fingerprint.sh trezor.signed.bin

Step 4 should produce the same sha256 fingerprint like your local build.

The reasoning behind "firmware-fingerprint.sh" is that signed firmware has special header holding signatures themselves,
which must be removed before calculating fingerprint.