Jan Pochyla
46f748205d
modtrezormsg: WIP python USB API
2017-04-21 16:25:00 +02:00
Jan Pochyla
03aac60681
trezorhal: disable interfaces on deinit
2017-04-21 16:23:06 +02:00
Pavol Rusnak
d131dc7405
fix last commit
2017-04-17 18:56:08 +02:00
Pavol Rusnak
795875523b
unix: implement __fatal_error, simplify modtrezorutils
2017-04-17 18:07:34 +02:00
Pavol Rusnak
117edd233f
build: don't use STM32_HAL_H directly to detect port, introduce TREZOR_STM32 and TREZOR_UNIX macros
2017-04-17 17:57:42 +02:00
Pavol Rusnak
8a9e31382e
bootloader: add fake processing of FirmwareUpload messages
2017-04-16 20:58:58 +02:00
Pavol Rusnak
b91d8da421
bootloader: more protobuf cleanup
2017-04-16 17:37:39 +02:00
Pavol Rusnak
fffe8abd02
bootloader: rework message creation
2017-04-16 14:16:40 +02:00
Pavol Rusnak
00f566c434
bootloader: start working on USB processing
2017-04-12 18:31:23 +02:00
Pavol Rusnak
80d8ab7825
bootloader/firmware: update usb strings
2017-04-12 15:20:09 +02:00
Jan Pochyla
4c183268a8
trezorhal: align uint8_t buffers
2017-04-11 18:22:30 +02:00
Jan Pochyla
87909637bf
stmhal: vcp+hid style & comments, vcp tx ring buffer
2017-04-11 18:06:20 +02:00
Pavol Rusnak
69d7f39b23
modtrezorutils: call __fatal_error on stm
2017-04-10 19:43:07 +02:00
Pavol Rusnak
0c060b6d4a
rename loader to bootloader
2017-04-10 19:24:21 +02:00
Pavol Rusnak
0633506166
rename bootloader to boardloader
2017-04-10 19:11:44 +02:00
Pavol Rusnak
b412ef4b24
trezorhal: usbd - fix typo
2017-04-10 18:39:10 +02:00
Jan Pochyla
28d6b38f6f
trezorhal: implement vcp read and ctrl-c soft reset, fix write
2017-04-10 18:32:13 +02:00
Jan Pochyla
137d27d69e
trezorhal: cleanup hid, usb
2017-04-10 18:30:02 +02:00
Pavol Rusnak
f12c630914
trezorhal: don't use legacy symbols from STMhal
2017-04-10 18:15:48 +02:00
Pavol Rusnak
8a1ec2aad6
trezorhal: upgrade usbd files from stmcube 1.15
2017-04-10 17:52:18 +02:00
Jan Pochyla
df57f47aa9
trezorhal: minor usb cleanup
2017-04-07 17:40:22 +02:00
Jan Pochyla
cc38f537d3
trezorhal: whitespace
2017-04-07 13:41:12 +02:00
Pavol Rusnak
1851bffe26
loader: move usb/flash init to mainloop, add simple demo
2017-04-07 02:36:26 +02:00
Jan Pochyla
792faea908
loader: cleanup usb before jump
2017-04-06 19:06:05 +02:00
Jan Pochyla
0e33357ee7
trezorhal: add usb_deinit
2017-04-06 19:06:05 +02:00
Pavol Rusnak
b592a95fb1
loader: better report descriptor format
2017-04-06 19:06:05 +02:00
Jan Pochyla
0636c12729
loader: fix b2f9725
2017-04-06 19:06:05 +02:00
Jan Pochyla
823a33b930
trezorhal: export usb_hid_read_select
2017-04-06 19:06:05 +02:00
Jan Pochyla
9fcf5afaa9
usb_init_all: better report descriptor format
2017-04-06 19:06:05 +02:00
Jan Pochyla
a54293b808
trezorhal: add usb_hid_read_select
2017-04-06 19:06:05 +02:00
Pavol Rusnak
1f837c4572
trezorhal: remove dependency on py/
2017-04-06 19:06:05 +02:00
Pavol Rusnak
d8d62af275
trezorhal: bcdUSB should be 0x0200
2017-04-06 19:06:05 +02:00
Pavol Rusnak
435ac7081a
loader: add usb
2017-04-06 19:06:05 +02:00
Jan Pochyla
38b99b306a
trezorhal: add cdc vcp tx
...
TODO: rx support
TODO: buffering
TODO: cleanup
2017-04-06 19:06:05 +02:00
Jan Pochyla
e87d0d3905
trezorhal: refactor error checks
2017-04-06 19:06:05 +02:00
Jan Pochyla
cb497eec0b
trezorhal: error checks, fix potential bug in usb_hid_class_data_out
2017-04-06 19:06:05 +02:00
Pavol Rusnak
9fcd21922f
trezorhal: use UNCONST macro in usb stack
2017-04-06 19:06:05 +02:00
Jan Pochyla
a78221fd22
trezorhal: fix IN endpoint detection
2017-04-06 19:06:05 +02:00
Jan Pochyla
33e5ad1ac9
trezorhal: fix setup of next OUT transfer
2017-04-06 19:06:05 +02:00
Jan Pochyla
3a4cbacbff
trezorhal: fix missing rx_buffer
2017-04-06 19:06:05 +02:00
Jan Pochyla
c258bfdd90
trezorhal: fix buffer truncation in usb_hid_read
2017-04-06 19:06:05 +02:00
Pavol Rusnak
8eb5cbbe13
trezorhal: add stubs for vcp interface
2017-04-06 19:06:05 +02:00
Pavol Rusnak
2c03f97ca9
trezorhal: extract usb hid stuff into usb_hid-defs.h and usb_hid-impl.h
2017-04-06 19:06:05 +02:00
Pavol Rusnak
6b07961cf6
trezorhal: set iface.type
2017-04-06 19:06:05 +02:00
Jan Pochyla
56b1d69796
trezorhal/usb: now compiles
2017-04-06 19:06:05 +02:00
Jan Pochyla
466285a21c
trezorhal: WIP usb rewrite
2017-04-06 19:06:05 +02:00
Jan Pochyla
2abc29f70d
unix: mp_uint_t -> size_t
2017-04-06 18:37:36 +02:00
Jan Pochyla
9f985dba46
extmod: use size_t for mp_obj_get_array and mp_obj_tuple_get
2017-04-06 18:36:30 +02:00
Pavol Rusnak
cb8e957379
bootloader/loader: refactor PRINT(LN) macros to common.h
2017-04-06 17:25:14 +02:00
Pavol Rusnak
4f9f351a16
bootloader/loader: print version to log
2017-04-06 17:21:03 +02:00
Pavol Rusnak
35e404bd38
tools: add fake signing to binctl, add make sign target
2017-04-05 19:33:50 +02:00
Pavol Rusnak
fdef0575b1
loader: show firmware version in loader, remove image_options.h
2017-04-05 17:41:10 +02:00
Pavol Rusnak
a4a939058b
bootloader/loader: reorganize checking code
2017-04-05 16:27:55 +02:00
Pavol Rusnak
fad4b80af8
trezorhal: don't parse (image|vendor) headers twice, don't use legacy stm32 names
2017-04-05 15:10:33 +02:00
Pavol Rusnak
3532b266ce
modtrezorconfig: readd norcow as a submodule
2017-04-05 02:23:48 +02:00
Pavol Rusnak
0a7997f798
modtrezorcrypto: add cosi cosigning scheme to ed25519 class
2017-04-03 22:28:54 +02:00
Pavol Rusnak
eef147d810
modtrezorcrypto: add crypto.rfc6979 class
2017-04-03 21:29:52 +02:00
Pavol Rusnak
87b7d0649b
boot: use cosi to compute aggregated key and use it
2017-04-02 02:55:51 +02:00
Pavol Rusnak
1eff07f84d
build: don't convert from png in build_vendorheader, remove vendorheader.bin from vcs
2017-04-01 23:16:25 +02:00
Pavol Rusnak
5c227a4a47
loader: compute pubkey rather than use precomputed one, prepare for vendor keys
2017-04-01 22:30:10 +02:00
Pavol Rusnak
7cb7a90d27
build: include vendorheader.bin in source tree
2017-04-01 20:21:02 +02:00
Pavol Rusnak
1f07f310b3
loader: show vendor image and vendor string from vendor header
2017-04-01 20:19:35 +02:00
Pavol Rusnak
b72bc08172
loader: vendor image is now shown in display
2017-04-01 20:19:35 +02:00
Pavol Rusnak
bbf55bcf2a
loader: handle vendor header
2017-04-01 19:24:41 +02:00
Pavol Rusnak
6187a8a0c1
build: refactor build_vendorheader
2017-04-01 18:28:10 +02:00
Jochen Hoenicke
e0fd890661
Implemented vendor header.
...
Header is generated with
./tools/build_vendorheader 'key1,key2,key3' 2 1.1 SatoshiLabs assets/satoshilabs.png micropython/firmware/vendorheader.bin
where
- keyN is a 64 character hex string encoding the public key
- 2 encodes 2/3 key scheme
- 1.1 is the version number (major, minor)
- SatoshiLabs is the vendor name
- satoshilabs.png is the vendor image
Updated the firmware compilation that it adds vendor header and updated loader
that it handles vendor header to be present.
2017-04-01 17:01:59 +02:00
Pavol Rusnak
300daa4513
bootloader: lock flash/turn off sdcard when header invalid
2017-04-01 13:53:53 +02:00
Pavol Rusnak
74db11cbfc
bootloader/loader: rename crypto.c/h to image.c/h, refactor
2017-04-01 13:41:07 +02:00
Pavol Rusnak
a440f3d322
trezorhal: update linker scripts
2017-04-01 12:48:15 +02:00
Pavol Rusnak
435e96e1b3
build: refactor binctl and firmware/loader image stuff
2017-04-01 02:53:52 +02:00
Jochen Hoenicke
e37619899e
Put loader/firmware header into image ( #5 )
2017-04-01 00:22:24 +02:00
Pavol Rusnak
722e71eb31
modtrezorconfig: use uint16_t for data length
2017-03-30 21:42:50 +02:00
Pavol Rusnak
32cf4f36d2
modtrezorconfig: norcow works for stm
2017-03-30 20:55:18 +02:00
Pavol Rusnak
5e69cbe69f
trezorhal: chain loading works
2017-03-30 16:50:39 +02:00
Pavol Rusnak
d3ec688d6f
trezorhal: don't set SCB->VTOR in SystemInit
2017-03-30 16:47:02 +02:00
Pavol Rusnak
efb722cc97
trezorhal: split memory files, adapt bootloader and loader
2017-03-29 22:00:17 +02:00
Pavol Rusnak
8d3020bc62
trezorhal: implement jump_to function
2017-03-29 20:50:45 +02:00
Pavol Rusnak
c8bff40ffb
trezorhal: use more readable syntax in memory script
2017-03-29 15:54:21 +02:00
Pavol Rusnak
2725792528
bootloader: erase all sectors except first two
2017-03-29 02:43:41 +02:00
Pavol Rusnak
41af56222a
modtrezorcrypto: update trezor-crypto
2017-03-29 00:22:52 +02:00
Pavol Rusnak
7dfc863fe7
modtrezorui: use const for bitmap font
2017-03-28 21:09:21 +02:00
Pavol Rusnak
4d4a351ba6
modtrezorcrypto: update to new trezor-crypto
2017-03-28 20:28:51 +02:00
Pavol Rusnak
b30f3b0946
build: use -Os for debug builds and use them by default
2017-03-28 15:21:09 +02:00
Pavol Rusnak
f6747b9556
modtrezorui: update qrcode to draw 1px border
2017-03-28 14:25:16 +02:00
Pavol Rusnak
6861e68f21
update to current micropython master
2017-03-26 23:11:57 +02:00
Pavol Rusnak
a9d16aa7fa
firmware: extract periph_init into common.c
2017-03-23 16:22:58 +01:00
Pavol Rusnak
e313234fe3
bootloader/loader: use blake2s instead of sha256 for digests
2017-03-23 15:54:34 +01:00
Pavol Rusnak
1e80e82bac
bootloader: change stage2 to loader
2017-03-21 16:06:54 +01:00
Pavol Rusnak
9e5d61752c
trezorhal: use display_print instead of mp_hal_stdout in our version of stm32_it.c
2017-03-21 16:06:54 +01:00
Pavol Rusnak
416676120b
extract common stuff into trezorhal/common.[ch]
2017-03-21 02:09:17 +01:00
Pavol Rusnak
e872f54896
modtrezorui: split display_print into display_print and display_print_out
2017-03-20 21:51:08 +01:00
Pavol Rusnak
420516c5de
modtrezorcrypto: use BLOCK_LENGTH and DIGEST_LENGTH across all hash functions
2017-03-20 21:07:20 +01:00
Pavol Rusnak
cbaca604f3
bootloader+loader: rework build, make clear what is bootloader and what is loader in docu
2017-03-20 16:00:10 +01:00
Pavol Rusnak
b141e6b1e3
loader: add skeleton
2017-03-20 15:41:21 +01:00
Pavol Rusnak
603d980d22
bootloader: enable build again
2017-03-18 12:06:28 +01:00
Pavol Rusnak
7edc688180
modtrezorui: extract fsmc constants
2017-03-17 17:43:22 +01:00
Pavol Rusnak
4b301cd288
modtrezorui: rename variables
2017-03-17 15:27:11 +01:00
Pavol Rusnak
135294b5e8
modtrezorui: more cleanup
2017-03-17 14:14:47 +01:00
Pavol Rusnak
a753bb05e2
unix: fix NOUI build
2017-03-16 19:40:20 +01:00
Pavol Rusnak
4a7540f5b9
modtrezormsg: untagle touch
2017-03-16 19:14:30 +01:00