2024-05-31 09:21:11 +00:00
2016-05-11 12:39:28 +00:00
.PHONY : vendor
2023-11-03 13:13:55 +00:00
# get the number of CPU cores in a "portable" manner
# (accounting for darwin and big.LITTLE archs)
JOBS = $( shell sysctl -n hw.perflevel0.physicalcpu 2>/dev/null || \
sysctl -n hw.physicalcpu 2>/dev/null || \
sysctl -n hw.ncpu 2>/dev/null || \
nproc 2>/dev/null || \
echo 4)
2017-04-19 19:39:44 +00:00
MAKE = make -j $( JOBS)
2017-08-07 10:04:11 +00:00
SCONS = scons -Q -j $( JOBS)
2017-04-19 19:39:44 +00:00
2017-11-06 15:44:34 +00:00
BUILD_DIR = build
BOARDLOADER_BUILD_DIR = $( BUILD_DIR) /boardloader
BOOTLOADER_BUILD_DIR = $( BUILD_DIR) /bootloader
2023-03-23 14:42:21 +00:00
BOOTLOADER_CI_BUILD_DIR = $( BUILD_DIR) /bootloader_ci
BOOTLOADER_EMU_BUILD_DIR = $( BUILD_DIR) /bootloader_emu
2017-11-06 15:44:34 +00:00
PRODTEST_BUILD_DIR = $( BUILD_DIR) /prodtest
2017-11-06 14:46:27 +00:00
REFLASH_BUILD_DIR = $( BUILD_DIR) /reflash
2024-08-13 05:47:59 +00:00
KERNEL_BUILD_DIR = $( BUILD_DIR) /kernel
2017-11-06 15:44:34 +00:00
FIRMWARE_BUILD_DIR = $( BUILD_DIR) /firmware
UNIX_BUILD_DIR = $( BUILD_DIR) /unix
2021-03-23 12:14:33 +00:00
RUST_BUILD_DIR = $( BUILD_DIR) /rust
2016-10-12 16:29:01 +00:00
2017-08-08 12:23:34 +00:00
UNAME_S := $( shell uname -s)
2018-06-05 21:30:43 +00:00
UNIX_PORT_OPTS ?=
2018-01-05 00:07:05 +00:00
CROSS_PORT_OPTS ?=
2017-08-08 12:23:34 +00:00
2017-10-12 10:17:04 +00:00
PRODUCTION ?= 0
2019-08-21 15:46:30 +00:00
PYOPT ?= 1
2019-08-22 18:15:16 +00:00
BITCOIN_ONLY ?= 0
2022-11-23 15:02:05 +00:00
BOOTLOADER_QA ?= 0
2023-08-10 09:30:13 +00:00
BOOTLOADER_DEVEL ?= 0
2020-08-28 12:50:38 +00:00
TREZOR_MODEL ?= T
2020-10-26 19:30:55 +00:00
TREZOR_MEMPERF ?= 0
2022-01-07 12:07:45 +00:00
ADDRESS_SANITIZER ?= 0
2023-01-30 14:36:22 +00:00
CMAKELISTS ?= 0
2023-08-11 15:57:32 +00:00
PYTEST_TIMEOUT ?= 500
TEST_LANG ?= "en"
2024-08-23 11:34:25 +00:00
NEW_RENDERING ?= 1
2024-04-02 14:51:01 +00:00
THP ?= 0
2017-10-12 10:17:04 +00:00
2022-04-13 14:00:00 +00:00
# OpenOCD interface default. Alternative: ftdi/olimex-arm-usb-tiny-h
OPENOCD_INTERFACE ?= stlink
# OpenOCD transport default. Alternative: jtag
OPENOCD_TRANSPORT ?= hla_swd
2017-09-26 13:10:56 +00:00
2024-09-23 11:44:57 +00:00
i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,T ) )
2024-02-22 21:24:56 +00:00
MCU = STM32F4
OPENOCD_TARGET = target/stm32f4x.cfg
2024-04-12 20:39:30 +00:00
MODEL_FEATURE = model_tt
2024-02-22 21:24:56 +00:00
e l s e i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,R ) )
MCU = STM32F4
2023-06-28 08:51:30 +00:00
OPENOCD_TARGET = target/stm32f4x.cfg
2024-04-12 20:39:30 +00:00
MODEL_FEATURE = model_tr
2023-08-24 09:33:50 +00:00
e l s e i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,T 3T 1) )
2024-02-22 21:24:56 +00:00
MCU = STM32U5
2023-08-24 09:33:50 +00:00
OPENOCD_TARGET = target/stm32u5x.cfg
2024-05-31 09:21:11 +00:00
MODEL_FEATURE = model_mercury
2024-04-14 08:04:44 +00:00
e l s e i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,T 3B 1) )
MCU = STM32U5
OPENOCD_TARGET = target/stm32u5x.cfg
MODEL_FEATURE = model_tr
2024-02-22 21:24:56 +00:00
e l s e i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,DISC 1) )
MCU = STM32F4
2024-06-21 10:48:31 +00:00
OPENOCD_TARGET = target/stm32f4x.cfg
2023-06-28 08:51:37 +00:00
e l s e i f e q ( $( TREZOR_MODEL ) , $( filter $ ( TREZOR_MODEL ) ,DISC 2) )
2024-02-22 21:24:56 +00:00
MCU = STM32U5
2023-06-28 08:51:37 +00:00
OPENOCD_TARGET = target/stm32u5x.cfg
2023-06-28 08:51:30 +00:00
e l s e
$(error Unknown TREZOR_MODEL : $( TREZOR_MODEL ) )
e n d i f
2024-09-23 14:25:18 +00:00
FLASH_START = $( shell layout_parser ${ TREZOR_MODEL } FLASH_START)
2024-07-31 15:40:17 +00:00
BOARDLOADER_START = $( shell layout_parser ${ TREZOR_MODEL } BOARDLOADER_START)
BOOTLOADER_START = $( shell layout_parser ${ TREZOR_MODEL } BOOTLOADER_START)
2024-08-13 05:47:59 +00:00
KERNEL_START = $( shell layout_parser ${ TREZOR_MODEL } KERNEL_START)
2024-07-31 15:40:17 +00:00
FIRMWARE_START = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_START)
FIRMWARE_P2_START = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P2_START)
2024-09-23 14:25:18 +00:00
STORAGE_1_START = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_1_START)
STORAGE_2_START = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_2_START)
2024-07-31 15:40:17 +00:00
STORAGE_SIZE = $( shell layout_parser ${ TREZOR_MODEL } NORCOW_SECTOR_SIZE)
2024-09-23 14:25:18 +00:00
BOARDLOADER_MAXSIZE = $( shell layout_parser ${ TREZOR_MODEL } BOARDLOADER_MAXSIZE)
BOOTLOADER_MAXSIZE = $( shell layout_parser ${ TREZOR_MODEL } BOOTLOADER_MAXSIZE)
FIRMWARE_MAXSIZE = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_MAXSIZE)
FIRMWARE_P1_MAXSIZE = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P1_MAXSIZE)
FIRMWARE_P2_MAXSIZE = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P2_MAXSIZE)
2024-07-31 15:40:17 +00:00
BOARDLOADER_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } BOARDLOADER_SECTOR_START)
BOARDLOADER_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } BOARDLOADER_SECTOR_END)
BOOTLOADER_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } BOOTLOADER_SECTOR_START)
BOOTLOADER_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } BOOTLOADER_SECTOR_END)
FIRMWARE_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_SECTOR_START)
FIRMWARE_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_SECTOR_END)
2024-09-23 14:25:18 +00:00
FIRMWARE_P1_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P1_SECTOR_START)
FIRMWARE_P1_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P1_SECTOR_END)
2024-07-31 15:40:17 +00:00
FIRMWARE_P2_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P2_SECTOR_START)
FIRMWARE_P2_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } FIRMWARE_P2_SECTOR_END)
STORAGE_1_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_1_SECTOR_START)
STORAGE_1_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_1_SECTOR_END)
STORAGE_2_SECTOR_START = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_2_SECTOR_START)
STORAGE_2_SECTOR_END = $( shell layout_parser ${ TREZOR_MODEL } STORAGE_2_SECTOR_END)
2024-02-22 21:24:56 +00:00
2024-09-23 14:25:18 +00:00
STORAGE_1_OFFSET := $( shell expr $( STORAGE_1_START) - $( FLASH_START) )
STORAGE_2_OFFSET := $( shell expr $( STORAGE_2_START) - $( FLASH_START) )
2023-06-28 08:51:30 +00:00
OPENOCD = openocd -f interface/$( OPENOCD_INTERFACE) .cfg -c " transport select $( OPENOCD_TRANSPORT) " -f $( OPENOCD_TARGET)
2017-10-11 19:15:22 +00:00
2021-05-21 09:35:43 +00:00
CFLAGS += -DSCM_REVISION= '\"$(shell git rev-parse HEAD | sed ' s:\( ..\) :\\ x\1 :g')\"'
2017-10-12 14:02:40 +00:00
2020-01-16 16:17:41 +00:00
TESTPATH = $( CURDIR) /../tests
2020-01-16 12:57:14 +00:00
EMU = $( CURDIR) /emu.py
2020-01-16 16:17:41 +00:00
EMU_LOG_FILE ?= $( TESTPATH) /trezor.log
EMU_TEST_ARGS = --disable-animation --headless --output= $( EMU_LOG_FILE) --temporary-profile
2020-01-16 12:57:14 +00:00
EMU_TEST = $( EMU) $( EMU_TEST_ARGS) -c
JUNIT_XML ?= $( TESTPATH) /junit.xml
PYTEST = pytest --junitxml= $( JUNIT_XML)
TREZOR_FIDO2_UDP_PORT = 21326
2022-10-12 11:13:52 +00:00
RUST_TARGET = $( shell rustc -vV | sed -n 's/host: //p' )
2020-01-16 12:57:14 +00:00
2023-03-03 14:10:33 +00:00
MULTICORE ?= "auto"
2017-03-25 13:46:38 +00:00
## help commands:
2016-03-30 14:36:39 +00:00
help : ## show this help
2019-04-18 14:27:27 +00:00
@awk -f ../tools/help.awk $( MAKEFILE_LIST)
2017-03-25 13:46:38 +00:00
## dependencies commands:
2016-03-30 14:36:39 +00:00
2016-05-11 12:39:28 +00:00
vendor : ## update git submodules
2017-10-11 14:17:17 +00:00
git submodule update --init --recursive --force
2016-04-01 18:04:59 +00:00
2017-03-25 13:46:38 +00:00
## emulator commands:
2017-03-20 16:45:40 +00:00
run : ## run unix port
2020-07-27 14:59:51 +00:00
cd src ; ../$( UNIX_BUILD_DIR) /trezor-emu-core
2017-03-20 16:45:40 +00:00
emu : ## run emulator
2020-01-16 12:57:14 +00:00
$( EMU)
2017-03-20 16:45:40 +00:00
2017-03-25 13:46:38 +00:00
## test commands:
2017-03-20 16:45:40 +00:00
test : ## run unit tests
2018-03-09 13:56:18 +00:00
cd tests ; ./run_tests.sh $( TESTOPTS)
2017-03-20 16:45:40 +00:00
2021-09-08 12:16:40 +00:00
test_rust : ## run rs unit tests
2024-08-08 15:18:32 +00:00
export BUILD_DIR = $( abspath $( UNIX_BUILD_DIR) ) ; \
2023-05-04 12:32:02 +00:00
cd embed/rust ; cargo test $( TESTOPTS) --target= $( RUST_TARGET) \
2024-04-12 20:39:30 +00:00
--no-default-features --features $( MODEL_FEATURE) ,test \
2023-05-04 12:32:02 +00:00
-- --test-threads= 1 --nocapture
2021-09-08 12:16:40 +00:00
2017-10-30 17:52:10 +00:00
test_emu : ## run selected device tests from python-trezor
2023-08-11 15:57:32 +00:00
$( EMU_TEST) $( PYTEST) $( TESTPATH) /device_tests $( TESTOPTS) --lang= $( TEST_LANG)
2017-03-20 16:45:40 +00:00
2022-08-18 15:21:27 +00:00
test_emu_multicore : ## run device tests using multiple cores
2023-05-04 12:32:02 +00:00
$( PYTEST) -n $( MULTICORE) $( TESTPATH) /device_tests $( TESTOPTS) --timeout $( PYTEST_TIMEOUT) \
2023-08-11 15:57:32 +00:00
--control-emulators --model= core --random-order-seed= $( shell echo $$ RANDOM) \
--lang= $( TEST_LANG)
2022-08-18 15:21:27 +00:00
xmr: master merging commit
templates: build
style: correct math in comment
[260130c1] xmr: show address fix
[abd27e6c] xmr: reorganize module structure
[cd9e5a5d] xmr: simplify layout code
[a5b56f17] xmr: monero.crypto test fix
[60bc30ec] xmr: minor fixes
[f82bd9c0] xmr: use trezor.utils.ensure
[adf119ac] xmr: get rid of xmr.common module
[3531a42f] pipenv: temporary fix attempt for travis
- until pipenv bug is resolved
[d172f86f] xmr: protob messages refactored
[e83085ea] trezor-common version bump & messages regenerated
xmr: mlsag_hasher simplified
[feb5f1c6] xmr: simplify key_image_sync workflow
[d4cb0084] xmr: tiny note in README and typo
[62411cde] xmr: readme updates
[ff15b46e] xmr: rename and order mlsag functions
[3fb57dab] xmr: mlsag notes
[c27ae90b] xmr: output index check added in step6
[973c457b] xmr: grouping is mandatory
[684c7e19] xmr: range sig grouping check added
[012ca766] xmr: small refactor in borromean range proof
[1ba72b65] xmr: move range signatures to seperate file; rename mlsag2 to mlsag
[a89f3ab0] xmr: fix wrong annotation in modtrezorcrypto
[8303b42f] xmr: state's use_simple_rct and use_bulletproof modified to enums
[276712a9] xmr: re-export most of functions in apps.monero.xmr.crypto
[74165457] xmr: out_pk_masks changed to out_pk_commitments
[1e186727] xmr: state comments
[3c69a2e1] xmr: TrezorTxPrefixHashNotMatchingError note removed
only concerns multisig
[5af0feae] xmr: master merging commit
xmr: step 10 review
[d8e99375] xmr: step 09 review
[a510150d] travis: workaround form 6a0ea22b6eb3bdc9bce62d7c88fb8841ef8fdb0c
[03d27115] mocks: regenerate
[bd24bb35] mocks: add support for entering the global scope
[f75c1902] mocks: regenerate
[bce85968] modtrezorcrypto: define mock package
[7c077521] mocks: support package definition
[b3f1017b] xmr: step 05 and 06 masks and range proofs review
Masks are now always generated in step 5 and stored in state.
Range proofs were reviewed only in a high-level manner and will be
reviewed later.
[67f391cd] xmr: step 08 review
[673bf01f] xmr: steps 04, 05, 06 (almost) and 07 review
_range_proof in step 06 is still to be reviewed
[24c52517] xmr: simplify serialization, remove Archive
[896cdebf] xmr: redundant exception removed
[cb3813aa] xmr: serializer simplified
[471213b4] xmr: serializer flake8 fix
[9d4df17f] xmr: aescbc not needed
[52dd8b3b] xmr: serializer - erefs kicked out
[9e3be78f] xmr: sign cleanup, comments
- state cleanup, comments added, unused code removed
[164a7d6a] xmr: sign step 09 - fix in_memory artifact, dead branch
[8fa4066d] xmr: sign step 03 - permutation length check added
[55a593aa] xmr: multisig removed from protocol and functions
[6470678d] xmr: black styling
[02664401] xmr: step 03 review
[daf7b7d6] xmr: step 02 review
xmr: adding agent tests to travis
[c752866f] xmr: unused imports removed
[85115fd9] xmr: serializer test fixed
- removed unsupported messages after serialization simplification
[60874751] xmr: sign step 06 - comment on bulletproof hashing
- hash_bp(bp) != hash(serialize(bp)) because hash does not contain array lengths
[4abb5473] xmr: sign protocol - multisig logic removed
[813cb3a0] xmr: lite protocol removed
- backup left in xmr-total-full-with-lite branch
[e5f5b5bd] xmr: serialization slimming
- base types reduced, not needed for now
- some int serialization methods not used now
[fb515aaf] xmr: serialization - archive simplified
- simple parameter passing, no kwargs
- unused methods removed
- reader/writer passing removed for archive methods
[ec4c4adb] xmr: KeccakXmrArchive simplified, no archive used
- getting rid of container_size. We dont use containers with fixed size so this special case can be abandoned.
- KeccakXmrArchive is lighweight without need to touch main serialization
[90065bd4] xmr: serialization - serialize_archive removed
- custom serialization routine is not required at this moment
[b98c2f89] xmr: extra serialization refactored, manual serialization
- extra is serialized manually to reduce serialization overhead
- extra contains simple structures now:
- payment ID = already serialized manually
- tx pub key = easy to serialize manually
- tx additional pub keys = serialized manually with little effort, more efficient memory usage
[8ce28a54] xmr: state 6 - provided tx keys removed
- needed only in the multisig scenario which is pruned now
[8d827f46] xmr: PreMlsagHasher pseudo out hashing fix
[49e552da] xmr: redundant import removed
[4199943d] xmr: KeccakXmrArchive simplified
[69bbf5fa] xmr: PreMlsagHasher - KeyV import removed, comment added
[9a194fa2] xmr: step7 - manual hashing of Extra
[d8a09283] xmr: PreMlsagHasher state load/save removed
- not needed, state not serialized anymore
[d5f43fa4] xmr: serialize reimport removed
- complex types are not surviving protocol boundary anymore, no need to fix hierarchy problems due to unimporting
[3b045612] xmr: serialize - TupleType removed
[b9a56981] xmr: serialization schemes simplified
[a59dbb8d] xmr: HashWrapper removed
[d0d1f05b] xmr: step 01 cleanup and comments
[8f7a7782] xmr: isort, black, flake8 fixes
[14265eb2] xmr: getting rid of CtKey from the state
- only lightweight objects are kept in the state. CtKey is import heavy object. Each set_out call locally imports a new own version of the Ctkey which causes a memory leak.
[c0cfc203] xmr: set_out minor function call fix
[c11c4686] xmr: sign_tx unimport optimization to reduce fragmentation
[df0a1dfc] xmr: range_sig allocation reordering, large chunks first
[63cddd5f] xmr: remove misc.StdObj
[8c8e3f33] xmr: proper memory usage in workflow
[9be1e0ac] xmr: typos and renames
[87f718b5] xmr: back to flat workflow
[64751339] xmr: refactor builder to seperate steps
- lot of work to be done, but the general idea will probably stay
- the messages workflow works, but the signed tx was not accepted by
daemon, so there is a bug somewhere
- additional cleanup/refactoring is defintely needed
[14b0a851] xmr: iface modified to layout
[27d568e1] xmr: extmod refactoring
- *_into removed, replaced by generic methods
- point_add, point_sub added
- code cleanup (+1 squashed commit)
Squashed commits:
[fbe39496] monero support added
Squashed commits:
xmr: hmac/enc keys removed from builder
[41028dff] xmr: unused function removed
[358573e3] xmr: PR comments fixes
[4abf9dc9] xmr: test fixes after refactoring
[192785ad] template rebuilt
[57a1f25e] xmr: wrapper protocol messages removed
[6f40ce17] xmr: trezor-common version bump & sync
[03e71de2] xmr: check input permutation
[6fc8b0ec] xmr: code cleanup, refactoring
[85ecc151] xmr: crypto code cleanup
[20b4113c] xmr: chunked bulletproof vectors
- workaround for the heap fragmentation problems
[66786f9d] tools: enable to reset class level indentation for mocks gen
[dc6f84a9] xmr: extmod-monero comments added, for mocks
[b1d4ab11] xmr: code cleanup
[447a8625] xmr: tsx confirmation raises exception on cancellation
[00dd8f6c] xmr: protocol optimizations removed, flow unified
- in_memory optimization stored tx.vin parts in the memory which enabled to skip roundtrips with permutations and hash_vini. Optimizations was removed so the protocol flow is unified among inputs, independent of the tx specs
- many_inputs: optimization stored spending keys for UTXO in memory, now it is offloaded in the encrypted form.
[ea69c7ad] vendor: trezor-common version bump & pb sync
[5d81c2a8] xmr: manual BP serialization
- more memory effective as the memory is critical in the range proof section
[d64bda7c] xmr: range_proof C-impl deprecated
- using now partitioned implementation in Python, which is also quite fast and easier to maintain due to allocations and buffers.
[18604e0f] xmr: borromean range sig generated by partitions
- overcomes heap fragmentation problem
[65a5116b] xmr: comments removed
[ca2bd0cc] xmr: auto-generated intelliJ param comments removed
[a75ef32e] xmr: code cleanup, heap fragmentations fixes
Squashed commits:
[d2ac2eb6] xmr: addr cleanup
[7e4c1a9c] xmr: code cleanup, heap fragmentations fixes
[93af8afb] xmr: refactoring, typing, comments
[28df8662] xmr: comment fix
[8b4f4d9c] xmr: serializer test fix (+34 squashed commits)
Squashed commits:
[823ee192] xmr: crypto comment cleanup
[6debfb6b] xmr: ring_ct cleanup
[759f52bf] xmr: tsx signer code style, hintins
[0b175bc9] xmr: tsx builder external state removed
[fee4a5ad] xmr: builder state fix
[92736fa7] xmr: sign_tx unimport
[a570ecb9] xmr: misc code cleanup
[4a496bb7] xmr: hash wrapper not needed in writer
[fefdb834] xmr: signer serialization improved
[8fa6eec9] xmr: signer mem clean
[66c53fe5] xmr: isort
[6996bd90] xmr: black
[59915a85] xmr: tsx input serialization refactored
[326af131] xmr: msg dump with prefix
[6e39801d] xmr: manual serialization of tx prefix
[9e5e047a] xmr: manual serialization improvements
[d07cee60] xmr: manual serialization of txout elements
[8d56c80e] xmr: TxOut custom serialization optimized II
[c19ba122] xmr: TxOut custom serialization optimized
[ce0d9b0b] xmr: TxOut manual serialization
[44e38342] xmr: sing_tx unimport
[61ac61be] xmr: lite log trace rename
[176b4275] xmr: de-async overhaul
[89ae3bad] xmr: diag style
[5ccb2fbb] xmr: wrappers cleanup
[aa86fb19] xmr: py3 only inheritance
[8031b1b0] xmr: builder, log_trace -> mem_trace for clarity
[25bf70d7] xmr: debugging logging only in debug mode
[c7c8d3c8] xmr: iface cleanup
[b0373396] xmr: lite debug only
[b1f6ce04] xmr: diag only in debug
[de7d718b] xmr: tsx counter removed
[76729beb] xmr: tsx_sign removed
[c6e6ffa8] Merge commit 'ba500bf4ec1ef9cd953bdf5a47888c5226db8d0b' into xmr
[ee97ef9f] xmr: minor code cleanup
xmr: black
xmr: minor code cleanup
[bae3ecac] xmr: bp comments
[5e812e6f] xmr: sign - mem_trace, pydoc
[7216a8c6] xmr: pydoc removed
[e87365f4] xmr: layout cleanup
[8d21d82e] xmr: redundant constructors removed
[9aa82bed] xmr: redundant comments removed
[9b926d6c] xmr: preludes removed
[bc9e77f1] xmr: readme update
[cf62047a] xmr: aggregated bulletproofs + rsig offloading
xmr: change idx fix
xmr: iface refactoring, integrated address (+5 squashed commits)
xmr: layout pagination refactoring
xmr: addr - integrated address
pb: sync
vendor: trezor-common version bump
xmr: style fixes
xmr: handle sweep tsx correctly
- handle dummy change address correctly
xmr: integrated address generation
build: fix after trezor-crypto version bump
xmr: new protocol dispatch handlers
xmr: slip0010
[43cf4c3c] xmr: comment fix
xmr: extmod pointer aritm fix
xmr: _into api unified, result is the first parameter
xmr: bp cleanup
xmr: scalar nullity test fix
xmr: msg registration improved
- lite protocol optional
- diag protocol optional
xmr: unused imports (+33 squashed commits)
[b4d045ae] xmr: bp - noqa flake8 false positive
[2c79d4be] xmr: isort
[8b9d2835] xmr: code cleanup
[eb7496e9] xmr: iface - shorter timeouts for faster tests
[59520b63] xmr: ringct comment
[6b16088e] xmr: signer - comment fixes
[a08958e2] xmr: simple and bulletproof condition fix
[4e0289a9] vendor: trezor-common version bump
[de472e5a] xmr: black
[234d2249] xmr: lightening, fixes, KeccakXmrArchive
- builder keys
- unload mods before memory intensive operation
[abdec665] xmr: sign_tx logging
[989d8687] xmr: serialize lightening
[7d61f056] xmr: tsx sign refactoring, lightening
- wake_up state restore
- minimize import weight
[3a0daa8b] xmr: serialize thinning
[65ad1d2e] xmr: serialize thinning
[501221d5] xmr: bp - thinning
[3d980377] xmr: bp - generalization with proof_v8
[10d11d60] xmr: extended rsig - offloading protocol
[a8f5caa2] xmr: crypto - rsig params fix
[f5e130b8] xmr: crypto - inv8
[dbc3f9d8] xmr: rsig pb sync
[5748a13e] xmr: bp - data for bp4 fix (+18 squashed commits)
Squashed commits:
[5bcd54e3] xmr: bp - black
[e93e97dd] xmr: bp refactoring, large memory optimizations
- memoryview in __getitem__ requires new memory allocation so the refactored version uses to(), read() methods that can operate directly on buffers without need to create memory views.
[c30745ae] xmr: bp - black
[f5c40699] xmr: bp - tests extended
[8dae75de] xmr: bp - get_exponent optim
[3e59ff80] xmr: bp - precomputations for 4 statements
[d1d2e29c] xmr: bp - gc.collect
[1bb6b5ba] xmr: bp - optimizations, streamlining
[2a2b0cb7] xmr: bp - verification in log(MN) memory for 1 proof
- not allocating MN vectors
- sequential multiexec added for memory efficient verification
- bulletproofs: maintain -z4, -z5, and -y0 to avoid subtractions [8276d25]
- bulletproofs: merge multiexps as per sarang's new python code [acd64d2b]
[75aa7dee] xmr: bp - memory optimization
[a10d05a9] xmr: bp - deterministic mask generation init
[5060d6a7] xmr: bp optimizations
[dd69eb1b] xmr: bp - black
[19f0f64b] xmr: bp - optimizations, power key vector
[2ba63f8c] xmr: bp - minor cleanup, optimizations, scalarmultH
[31c9ca2d] xmr: bp - mem clean
[3fc2c793] xmr: bp - memory save
[5b16c9cc] bp: black
[f1040c97] xmr: crypto - memory leak fix
[ff863510] xmr: iface - flake
[6ebf69c2] xmr: lite - flake8, black
[eee55d62] xmr: bp - memory diag
[2767009b] xmr: bulletproofs upgrade, mainnet version, cleaning
[be6ebbd5] xmr: lite protocol
[d603e96d] xmr: pb sync
[5da15da9] vendor: trezor-common fix
[0373b97e] xmr: iface - output confirmation split, subaddr fix
[2cf32176] xmr: monero - subaddress fixed for index (0, 0)
[3bb8f08b] xmr: enc.aescbc added - for lite protocol (+1 squashed commit)
Squashed commits:
[011dbaab] TMP: trezor-common on master, crypto on ph4
- trezor-crypto on ph4r04 fork as it has all required stuff
- Lite protocol not merged in master, thus does not work in the PR
[795b34e1] xmr: get_address fix
[2d39c90c] xmr: bp - import fix (squashed commit)
Squashed commits:
[2d5c6cee] extmod: monero - reduce32 and ge25519_norm removed (squashed commit)
- not needed in trezor-core (+4 squashed commits)
Squashed commits:
[90e6b5c5] xmr: bp optimization
[4fda0d22] xmr: redundant ge_ functions removed
[68903767] xmr: crypto - sc_reduce32 not needed
[c8a6c807] xmr: test for inversion added (+12 squashed commits)
Squashed commits:
[378928db] xmr: adapting to new trezor-crypto
[8f4ff8c1] protob sync
[82dff70a] vendor: trezor-common version bump
[fabc67b3] extmod: monero - inversion mod curve order optimized a bit
[4f29fe4c] xmr: import fix
[f6f8e300] xmr: bp - code cleanup
[d54b4f3b] xmr: bp - memory cleaning
[1065abc3] xmr: tsx_signer - bulletproofs fixes
[9f8a700f] xmr: bp key vector iterator fix
[49c25977] xmr.serialize: bulletproof fix
[1ee77378] xmr: monero - format
[cf0a7104] xmr: bp last mask fix (+20 squashed commits)
Squashed commits:
[fa1c3623] xmr: black
[3f3e31f3] xmr: bulletproofs added to signer
[d23d9284] xmr: protocol.tsx_sign_builder - logger collects
[a28eb55f] xmr: bp - memory optimizations
[d2fcb23a] xmr: tests for bulletproofs added
[82eef146] xmr: bp - gc (+14 squashed commits)
Squashed commits:
[4cf70d97] xmr: bp - gc
[42877b05] xmr: bp - minor memory optimization
[2c612e45] xmr: bp - use sc_inv_into
[d7e9dab4] xmr: bp - KeyVEval fix
[1523f400] xmr: bp - blacked
[b264a65b] xmr: bp - KeyVEval - caching current element, avoid allocations
[83ba7a65] xmr: bp - memory view optimized
[b517906c] xmr: bp - gc() during inversion
[92d37c88] xmr: bp - gc.collect() after expensive inversion
[e7fad558] xmr: bp - hashing memory optimization
[4c278152] xmr: bp - deterministic masks optimization, prove_s1 optim
[cbf74a70] xmr: bp - detect which modular inversion is usable
[8ea1ec43] xmr: better memory tracing for bulletproofs
[2f4dd552] xmr: bulletproofs added
[1928e2d3] xmr: crypto - sc_inv_into added (+2 squashed commits)
Squashed commits:
[f895fa6e] xmr: crypto - hash to existing buffer
[b76c6b09] xmr: crypto - in-place crypto functions added
- required for Bulletproof to minimize the heap fragmentation
[cab4366e] extmod: monero - modular inversion mod curve order added (+2 squashed commits)
Squashed commits:
[52a6e487] extmod: monero - hash into buffer added
[695a3827] extmod: monero module - muladd256_modm added
- required for Bulletproof
[3f4498d7] xmr: crypto tests added
- basic unit tests for crypto, tests monero module and underlying trezor-crypto + basic address manipulation
[820d012d] pb sync
[49eeddd1] vendor: trezor-common version bump
[30382440] xmr: crypto - point norm not needed
[89701c41] tests: xmr - serializer tests added
[bfee46db] tests: support async unit tests, assertListEqual added
[55c14487] xmr: serialize - serialization logic cleaned, refactored
[4b771638] xmr: simplification, do not ask to confirm change tx output
- change address checked to match main address in the builder
[f334d8ad] xmr: protocol: simplification - require change address to equal the main address
[1a3416eb] xmr: unpack256_modm_noreduce added
- 32B array to integer mod curve order, without modular reduction after conversion
- required for bulletproofs
[1c94b5d4] xmr: readme added
[3cc9f9fa] extmod/monero: mul256_modm added, required for BP
[5cf77a4c] xmr: monero support added [for review]
depends on PRs:
https://github.com/trezor/trezor-crypto/pull/162
https://github.com/trezor/trezor-core/pull/286
2018-08-06 12:07:14 +00:00
test_emu_monero : ## run selected monero device tests from monero-agent
2020-02-11 10:16:28 +00:00
cd tests ; $( EMU_TEST) ./run_tests_device_emu_monero.sh $( TESTOPTS)
xmr: master merging commit
templates: build
style: correct math in comment
[260130c1] xmr: show address fix
[abd27e6c] xmr: reorganize module structure
[cd9e5a5d] xmr: simplify layout code
[a5b56f17] xmr: monero.crypto test fix
[60bc30ec] xmr: minor fixes
[f82bd9c0] xmr: use trezor.utils.ensure
[adf119ac] xmr: get rid of xmr.common module
[3531a42f] pipenv: temporary fix attempt for travis
- until pipenv bug is resolved
[d172f86f] xmr: protob messages refactored
[e83085ea] trezor-common version bump & messages regenerated
xmr: mlsag_hasher simplified
[feb5f1c6] xmr: simplify key_image_sync workflow
[d4cb0084] xmr: tiny note in README and typo
[62411cde] xmr: readme updates
[ff15b46e] xmr: rename and order mlsag functions
[3fb57dab] xmr: mlsag notes
[c27ae90b] xmr: output index check added in step6
[973c457b] xmr: grouping is mandatory
[684c7e19] xmr: range sig grouping check added
[012ca766] xmr: small refactor in borromean range proof
[1ba72b65] xmr: move range signatures to seperate file; rename mlsag2 to mlsag
[a89f3ab0] xmr: fix wrong annotation in modtrezorcrypto
[8303b42f] xmr: state's use_simple_rct and use_bulletproof modified to enums
[276712a9] xmr: re-export most of functions in apps.monero.xmr.crypto
[74165457] xmr: out_pk_masks changed to out_pk_commitments
[1e186727] xmr: state comments
[3c69a2e1] xmr: TrezorTxPrefixHashNotMatchingError note removed
only concerns multisig
[5af0feae] xmr: master merging commit
xmr: step 10 review
[d8e99375] xmr: step 09 review
[a510150d] travis: workaround form 6a0ea22b6eb3bdc9bce62d7c88fb8841ef8fdb0c
[03d27115] mocks: regenerate
[bd24bb35] mocks: add support for entering the global scope
[f75c1902] mocks: regenerate
[bce85968] modtrezorcrypto: define mock package
[7c077521] mocks: support package definition
[b3f1017b] xmr: step 05 and 06 masks and range proofs review
Masks are now always generated in step 5 and stored in state.
Range proofs were reviewed only in a high-level manner and will be
reviewed later.
[67f391cd] xmr: step 08 review
[673bf01f] xmr: steps 04, 05, 06 (almost) and 07 review
_range_proof in step 06 is still to be reviewed
[24c52517] xmr: simplify serialization, remove Archive
[896cdebf] xmr: redundant exception removed
[cb3813aa] xmr: serializer simplified
[471213b4] xmr: serializer flake8 fix
[9d4df17f] xmr: aescbc not needed
[52dd8b3b] xmr: serializer - erefs kicked out
[9e3be78f] xmr: sign cleanup, comments
- state cleanup, comments added, unused code removed
[164a7d6a] xmr: sign step 09 - fix in_memory artifact, dead branch
[8fa4066d] xmr: sign step 03 - permutation length check added
[55a593aa] xmr: multisig removed from protocol and functions
[6470678d] xmr: black styling
[02664401] xmr: step 03 review
[daf7b7d6] xmr: step 02 review
xmr: adding agent tests to travis
[c752866f] xmr: unused imports removed
[85115fd9] xmr: serializer test fixed
- removed unsupported messages after serialization simplification
[60874751] xmr: sign step 06 - comment on bulletproof hashing
- hash_bp(bp) != hash(serialize(bp)) because hash does not contain array lengths
[4abb5473] xmr: sign protocol - multisig logic removed
[813cb3a0] xmr: lite protocol removed
- backup left in xmr-total-full-with-lite branch
[e5f5b5bd] xmr: serialization slimming
- base types reduced, not needed for now
- some int serialization methods not used now
[fb515aaf] xmr: serialization - archive simplified
- simple parameter passing, no kwargs
- unused methods removed
- reader/writer passing removed for archive methods
[ec4c4adb] xmr: KeccakXmrArchive simplified, no archive used
- getting rid of container_size. We dont use containers with fixed size so this special case can be abandoned.
- KeccakXmrArchive is lighweight without need to touch main serialization
[90065bd4] xmr: serialization - serialize_archive removed
- custom serialization routine is not required at this moment
[b98c2f89] xmr: extra serialization refactored, manual serialization
- extra is serialized manually to reduce serialization overhead
- extra contains simple structures now:
- payment ID = already serialized manually
- tx pub key = easy to serialize manually
- tx additional pub keys = serialized manually with little effort, more efficient memory usage
[8ce28a54] xmr: state 6 - provided tx keys removed
- needed only in the multisig scenario which is pruned now
[8d827f46] xmr: PreMlsagHasher pseudo out hashing fix
[49e552da] xmr: redundant import removed
[4199943d] xmr: KeccakXmrArchive simplified
[69bbf5fa] xmr: PreMlsagHasher - KeyV import removed, comment added
[9a194fa2] xmr: step7 - manual hashing of Extra
[d8a09283] xmr: PreMlsagHasher state load/save removed
- not needed, state not serialized anymore
[d5f43fa4] xmr: serialize reimport removed
- complex types are not surviving protocol boundary anymore, no need to fix hierarchy problems due to unimporting
[3b045612] xmr: serialize - TupleType removed
[b9a56981] xmr: serialization schemes simplified
[a59dbb8d] xmr: HashWrapper removed
[d0d1f05b] xmr: step 01 cleanup and comments
[8f7a7782] xmr: isort, black, flake8 fixes
[14265eb2] xmr: getting rid of CtKey from the state
- only lightweight objects are kept in the state. CtKey is import heavy object. Each set_out call locally imports a new own version of the Ctkey which causes a memory leak.
[c0cfc203] xmr: set_out minor function call fix
[c11c4686] xmr: sign_tx unimport optimization to reduce fragmentation
[df0a1dfc] xmr: range_sig allocation reordering, large chunks first
[63cddd5f] xmr: remove misc.StdObj
[8c8e3f33] xmr: proper memory usage in workflow
[9be1e0ac] xmr: typos and renames
[87f718b5] xmr: back to flat workflow
[64751339] xmr: refactor builder to seperate steps
- lot of work to be done, but the general idea will probably stay
- the messages workflow works, but the signed tx was not accepted by
daemon, so there is a bug somewhere
- additional cleanup/refactoring is defintely needed
[14b0a851] xmr: iface modified to layout
[27d568e1] xmr: extmod refactoring
- *_into removed, replaced by generic methods
- point_add, point_sub added
- code cleanup (+1 squashed commit)
Squashed commits:
[fbe39496] monero support added
Squashed commits:
xmr: hmac/enc keys removed from builder
[41028dff] xmr: unused function removed
[358573e3] xmr: PR comments fixes
[4abf9dc9] xmr: test fixes after refactoring
[192785ad] template rebuilt
[57a1f25e] xmr: wrapper protocol messages removed
[6f40ce17] xmr: trezor-common version bump & sync
[03e71de2] xmr: check input permutation
[6fc8b0ec] xmr: code cleanup, refactoring
[85ecc151] xmr: crypto code cleanup
[20b4113c] xmr: chunked bulletproof vectors
- workaround for the heap fragmentation problems
[66786f9d] tools: enable to reset class level indentation for mocks gen
[dc6f84a9] xmr: extmod-monero comments added, for mocks
[b1d4ab11] xmr: code cleanup
[447a8625] xmr: tsx confirmation raises exception on cancellation
[00dd8f6c] xmr: protocol optimizations removed, flow unified
- in_memory optimization stored tx.vin parts in the memory which enabled to skip roundtrips with permutations and hash_vini. Optimizations was removed so the protocol flow is unified among inputs, independent of the tx specs
- many_inputs: optimization stored spending keys for UTXO in memory, now it is offloaded in the encrypted form.
[ea69c7ad] vendor: trezor-common version bump & pb sync
[5d81c2a8] xmr: manual BP serialization
- more memory effective as the memory is critical in the range proof section
[d64bda7c] xmr: range_proof C-impl deprecated
- using now partitioned implementation in Python, which is also quite fast and easier to maintain due to allocations and buffers.
[18604e0f] xmr: borromean range sig generated by partitions
- overcomes heap fragmentation problem
[65a5116b] xmr: comments removed
[ca2bd0cc] xmr: auto-generated intelliJ param comments removed
[a75ef32e] xmr: code cleanup, heap fragmentations fixes
Squashed commits:
[d2ac2eb6] xmr: addr cleanup
[7e4c1a9c] xmr: code cleanup, heap fragmentations fixes
[93af8afb] xmr: refactoring, typing, comments
[28df8662] xmr: comment fix
[8b4f4d9c] xmr: serializer test fix (+34 squashed commits)
Squashed commits:
[823ee192] xmr: crypto comment cleanup
[6debfb6b] xmr: ring_ct cleanup
[759f52bf] xmr: tsx signer code style, hintins
[0b175bc9] xmr: tsx builder external state removed
[fee4a5ad] xmr: builder state fix
[92736fa7] xmr: sign_tx unimport
[a570ecb9] xmr: misc code cleanup
[4a496bb7] xmr: hash wrapper not needed in writer
[fefdb834] xmr: signer serialization improved
[8fa6eec9] xmr: signer mem clean
[66c53fe5] xmr: isort
[6996bd90] xmr: black
[59915a85] xmr: tsx input serialization refactored
[326af131] xmr: msg dump with prefix
[6e39801d] xmr: manual serialization of tx prefix
[9e5e047a] xmr: manual serialization improvements
[d07cee60] xmr: manual serialization of txout elements
[8d56c80e] xmr: TxOut custom serialization optimized II
[c19ba122] xmr: TxOut custom serialization optimized
[ce0d9b0b] xmr: TxOut manual serialization
[44e38342] xmr: sing_tx unimport
[61ac61be] xmr: lite log trace rename
[176b4275] xmr: de-async overhaul
[89ae3bad] xmr: diag style
[5ccb2fbb] xmr: wrappers cleanup
[aa86fb19] xmr: py3 only inheritance
[8031b1b0] xmr: builder, log_trace -> mem_trace for clarity
[25bf70d7] xmr: debugging logging only in debug mode
[c7c8d3c8] xmr: iface cleanup
[b0373396] xmr: lite debug only
[b1f6ce04] xmr: diag only in debug
[de7d718b] xmr: tsx counter removed
[76729beb] xmr: tsx_sign removed
[c6e6ffa8] Merge commit 'ba500bf4ec1ef9cd953bdf5a47888c5226db8d0b' into xmr
[ee97ef9f] xmr: minor code cleanup
xmr: black
xmr: minor code cleanup
[bae3ecac] xmr: bp comments
[5e812e6f] xmr: sign - mem_trace, pydoc
[7216a8c6] xmr: pydoc removed
[e87365f4] xmr: layout cleanup
[8d21d82e] xmr: redundant constructors removed
[9aa82bed] xmr: redundant comments removed
[9b926d6c] xmr: preludes removed
[bc9e77f1] xmr: readme update
[cf62047a] xmr: aggregated bulletproofs + rsig offloading
xmr: change idx fix
xmr: iface refactoring, integrated address (+5 squashed commits)
xmr: layout pagination refactoring
xmr: addr - integrated address
pb: sync
vendor: trezor-common version bump
xmr: style fixes
xmr: handle sweep tsx correctly
- handle dummy change address correctly
xmr: integrated address generation
build: fix after trezor-crypto version bump
xmr: new protocol dispatch handlers
xmr: slip0010
[43cf4c3c] xmr: comment fix
xmr: extmod pointer aritm fix
xmr: _into api unified, result is the first parameter
xmr: bp cleanup
xmr: scalar nullity test fix
xmr: msg registration improved
- lite protocol optional
- diag protocol optional
xmr: unused imports (+33 squashed commits)
[b4d045ae] xmr: bp - noqa flake8 false positive
[2c79d4be] xmr: isort
[8b9d2835] xmr: code cleanup
[eb7496e9] xmr: iface - shorter timeouts for faster tests
[59520b63] xmr: ringct comment
[6b16088e] xmr: signer - comment fixes
[a08958e2] xmr: simple and bulletproof condition fix
[4e0289a9] vendor: trezor-common version bump
[de472e5a] xmr: black
[234d2249] xmr: lightening, fixes, KeccakXmrArchive
- builder keys
- unload mods before memory intensive operation
[abdec665] xmr: sign_tx logging
[989d8687] xmr: serialize lightening
[7d61f056] xmr: tsx sign refactoring, lightening
- wake_up state restore
- minimize import weight
[3a0daa8b] xmr: serialize thinning
[65ad1d2e] xmr: serialize thinning
[501221d5] xmr: bp - thinning
[3d980377] xmr: bp - generalization with proof_v8
[10d11d60] xmr: extended rsig - offloading protocol
[a8f5caa2] xmr: crypto - rsig params fix
[f5e130b8] xmr: crypto - inv8
[dbc3f9d8] xmr: rsig pb sync
[5748a13e] xmr: bp - data for bp4 fix (+18 squashed commits)
Squashed commits:
[5bcd54e3] xmr: bp - black
[e93e97dd] xmr: bp refactoring, large memory optimizations
- memoryview in __getitem__ requires new memory allocation so the refactored version uses to(), read() methods that can operate directly on buffers without need to create memory views.
[c30745ae] xmr: bp - black
[f5c40699] xmr: bp - tests extended
[8dae75de] xmr: bp - get_exponent optim
[3e59ff80] xmr: bp - precomputations for 4 statements
[d1d2e29c] xmr: bp - gc.collect
[1bb6b5ba] xmr: bp - optimizations, streamlining
[2a2b0cb7] xmr: bp - verification in log(MN) memory for 1 proof
- not allocating MN vectors
- sequential multiexec added for memory efficient verification
- bulletproofs: maintain -z4, -z5, and -y0 to avoid subtractions [8276d25]
- bulletproofs: merge multiexps as per sarang's new python code [acd64d2b]
[75aa7dee] xmr: bp - memory optimization
[a10d05a9] xmr: bp - deterministic mask generation init
[5060d6a7] xmr: bp optimizations
[dd69eb1b] xmr: bp - black
[19f0f64b] xmr: bp - optimizations, power key vector
[2ba63f8c] xmr: bp - minor cleanup, optimizations, scalarmultH
[31c9ca2d] xmr: bp - mem clean
[3fc2c793] xmr: bp - memory save
[5b16c9cc] bp: black
[f1040c97] xmr: crypto - memory leak fix
[ff863510] xmr: iface - flake
[6ebf69c2] xmr: lite - flake8, black
[eee55d62] xmr: bp - memory diag
[2767009b] xmr: bulletproofs upgrade, mainnet version, cleaning
[be6ebbd5] xmr: lite protocol
[d603e96d] xmr: pb sync
[5da15da9] vendor: trezor-common fix
[0373b97e] xmr: iface - output confirmation split, subaddr fix
[2cf32176] xmr: monero - subaddress fixed for index (0, 0)
[3bb8f08b] xmr: enc.aescbc added - for lite protocol (+1 squashed commit)
Squashed commits:
[011dbaab] TMP: trezor-common on master, crypto on ph4
- trezor-crypto on ph4r04 fork as it has all required stuff
- Lite protocol not merged in master, thus does not work in the PR
[795b34e1] xmr: get_address fix
[2d39c90c] xmr: bp - import fix (squashed commit)
Squashed commits:
[2d5c6cee] extmod: monero - reduce32 and ge25519_norm removed (squashed commit)
- not needed in trezor-core (+4 squashed commits)
Squashed commits:
[90e6b5c5] xmr: bp optimization
[4fda0d22] xmr: redundant ge_ functions removed
[68903767] xmr: crypto - sc_reduce32 not needed
[c8a6c807] xmr: test for inversion added (+12 squashed commits)
Squashed commits:
[378928db] xmr: adapting to new trezor-crypto
[8f4ff8c1] protob sync
[82dff70a] vendor: trezor-common version bump
[fabc67b3] extmod: monero - inversion mod curve order optimized a bit
[4f29fe4c] xmr: import fix
[f6f8e300] xmr: bp - code cleanup
[d54b4f3b] xmr: bp - memory cleaning
[1065abc3] xmr: tsx_signer - bulletproofs fixes
[9f8a700f] xmr: bp key vector iterator fix
[49c25977] xmr.serialize: bulletproof fix
[1ee77378] xmr: monero - format
[cf0a7104] xmr: bp last mask fix (+20 squashed commits)
Squashed commits:
[fa1c3623] xmr: black
[3f3e31f3] xmr: bulletproofs added to signer
[d23d9284] xmr: protocol.tsx_sign_builder - logger collects
[a28eb55f] xmr: bp - memory optimizations
[d2fcb23a] xmr: tests for bulletproofs added
[82eef146] xmr: bp - gc (+14 squashed commits)
Squashed commits:
[4cf70d97] xmr: bp - gc
[42877b05] xmr: bp - minor memory optimization
[2c612e45] xmr: bp - use sc_inv_into
[d7e9dab4] xmr: bp - KeyVEval fix
[1523f400] xmr: bp - blacked
[b264a65b] xmr: bp - KeyVEval - caching current element, avoid allocations
[83ba7a65] xmr: bp - memory view optimized
[b517906c] xmr: bp - gc() during inversion
[92d37c88] xmr: bp - gc.collect() after expensive inversion
[e7fad558] xmr: bp - hashing memory optimization
[4c278152] xmr: bp - deterministic masks optimization, prove_s1 optim
[cbf74a70] xmr: bp - detect which modular inversion is usable
[8ea1ec43] xmr: better memory tracing for bulletproofs
[2f4dd552] xmr: bulletproofs added
[1928e2d3] xmr: crypto - sc_inv_into added (+2 squashed commits)
Squashed commits:
[f895fa6e] xmr: crypto - hash to existing buffer
[b76c6b09] xmr: crypto - in-place crypto functions added
- required for Bulletproof to minimize the heap fragmentation
[cab4366e] extmod: monero - modular inversion mod curve order added (+2 squashed commits)
Squashed commits:
[52a6e487] extmod: monero - hash into buffer added
[695a3827] extmod: monero module - muladd256_modm added
- required for Bulletproof
[3f4498d7] xmr: crypto tests added
- basic unit tests for crypto, tests monero module and underlying trezor-crypto + basic address manipulation
[820d012d] pb sync
[49eeddd1] vendor: trezor-common version bump
[30382440] xmr: crypto - point norm not needed
[89701c41] tests: xmr - serializer tests added
[bfee46db] tests: support async unit tests, assertListEqual added
[55c14487] xmr: serialize - serialization logic cleaned, refactored
[4b771638] xmr: simplification, do not ask to confirm change tx output
- change address checked to match main address in the builder
[f334d8ad] xmr: protocol: simplification - require change address to equal the main address
[1a3416eb] xmr: unpack256_modm_noreduce added
- 32B array to integer mod curve order, without modular reduction after conversion
- required for bulletproofs
[1c94b5d4] xmr: readme added
[3cc9f9fa] extmod/monero: mul256_modm added, required for BP
[5cf77a4c] xmr: monero support added [for review]
depends on PRs:
https://github.com/trezor/trezor-crypto/pull/162
https://github.com/trezor/trezor-core/pull/286
2018-08-06 12:07:14 +00:00
2019-09-14 12:47:30 +00:00
test_emu_u2f : ## run selected u2f device tests from u2f-tests-hid
2020-01-16 12:57:14 +00:00
$( EMU_TEST) --slip0014 $( TESTPATH) /fido_tests/u2f-tests-hid/HIDTest $( TREZOR_FIDO2_UDP_PORT) $( TESTOPTS)
$( EMU_TEST) --slip0014 $( TESTPATH) /fido_tests/u2f-tests-hid/U2FTest $( TREZOR_FIDO2_UDP_PORT) $( TESTOPTS)
2019-09-14 12:47:30 +00:00
2019-10-18 13:35:45 +00:00
test_emu_fido2 : ## run fido2 device tests
2020-01-16 12:57:14 +00:00
cd $( TESTPATH) /fido_tests/fido2 ; \
2020-05-12 09:36:37 +00:00
$( EMU_TEST) --slip0014 $( PYTEST) --maxfail= 5 --sim tests/standard/ --vendor trezor $( TESTOPTS)
2019-10-18 13:35:45 +00:00
2019-10-25 12:03:44 +00:00
test_emu_click : ## run click tests
2023-08-11 15:57:32 +00:00
$( EMU_TEST) $( PYTEST) $( TESTPATH) /click_tests $( TESTOPTS) --lang= $( TEST_LANG)
2019-10-25 12:03:44 +00:00
2023-01-30 13:41:09 +00:00
test_emu_click_ui : ## run click tests with UI testing
2023-06-27 12:36:11 +00:00
$( EMU_TEST) $( PYTEST) $( TESTPATH) /click_tests $( TESTOPTS) \
2023-08-11 15:57:32 +00:00
--ui= test --ui-check-missing --do-master-diff --lang= $( TEST_LANG)
2023-01-30 13:41:09 +00:00
2023-03-30 10:44:05 +00:00
test_emu_persistence : ## run persistence tests
2023-08-11 15:57:32 +00:00
$( PYTEST) $( TESTPATH) /persistence_tests $( TESTOPTS) --lang= $( TEST_LANG)
2023-03-30 10:44:05 +00:00
test_emu_persistence_ui : ## run persistence tests with UI testing
2023-06-27 12:36:11 +00:00
$( PYTEST) $( TESTPATH) /persistence_tests $( TESTOPTS) \
2023-08-11 15:57:32 +00:00
--ui= test --ui-check-missing --do-master-diff --lang= $( TEST_LANG)
2023-03-30 10:44:05 +00:00
2019-12-19 21:59:55 +00:00
test_emu_ui : ## run ui integration tests
2023-01-03 14:08:53 +00:00
$( EMU_TEST) $( PYTEST) $( TESTPATH) /device_tests $( TESTOPTS) \
2023-08-11 15:57:32 +00:00
--ui= test --ui-check-missing --record-text-layout --do-master-diff \
--lang= $( TEST_LANG)
2019-12-09 16:01:04 +00:00
2022-08-18 15:21:27 +00:00
test_emu_ui_multicore : ## run ui integration tests using multiple cores
2023-05-04 12:32:02 +00:00
$( PYTEST) -n $( MULTICORE) $( TESTPATH) /device_tests $( TESTOPTS) --timeout $( PYTEST_TIMEOUT) \
2023-06-27 12:36:11 +00:00
--ui= test --ui-check-missing --record-text-layout --do-master-diff \
2023-08-11 15:57:32 +00:00
--control-emulators --model= core --random-order-seed= $( shell echo $$ RANDOM) \
--lang= $( TEST_LANG)
2022-08-18 15:21:27 +00:00
2019-12-29 10:42:15 +00:00
test_emu_ui_record : ## record and hash screens for ui integration tests
2023-01-03 14:08:53 +00:00
$( EMU_TEST) $( PYTEST) $( TESTPATH) /device_tests $( TESTOPTS) \
2023-08-11 15:57:32 +00:00
--ui= record --ui-check-missing --do-master-diff --lang= $( TEST_LANG)
2019-12-09 16:01:04 +00:00
2023-01-02 16:57:07 +00:00
test_emu_ui_record_multicore : ## quickly record all screens
make test_emu_ui_multicore || echo "All errors are recorded in fixtures.json"
2023-09-14 10:23:55 +00:00
../tests/update_fixtures.py local -r
2022-08-18 15:21:27 +00:00
2017-12-16 01:11:26 +00:00
pylint : ## run pylint on application sources and tests
2018-07-03 14:11:47 +00:00
pylint -E $( shell find src tests -name *.py)
2017-06-07 17:06:26 +00:00
2022-01-05 10:41:48 +00:00
mypy : ## deprecated; use "make typecheck"
@echo "mypy is deprecated; use 'make typecheck'"
make typecheck
2022-03-01 12:55:58 +00:00
typecheck : pyright
pyright :
2022-03-17 10:53:37 +00:00
python ../tools/pyright_tool.py
2019-06-09 09:23:41 +00:00
2021-09-22 16:15:40 +00:00
clippy :
2024-08-08 15:18:32 +00:00
export BUILD_DIR = $( abspath $( UNIX_BUILD_DIR) ) ; \
2024-04-12 20:39:30 +00:00
cd embed/rust ; cargo clippy $( TESTOPTS) --all-features --target= $( RUST_TARGET)
2021-09-22 16:15:40 +00:00
2019-01-15 17:04:50 +00:00
## code generation:
2018-08-22 11:48:32 +00:00
2024-03-15 10:56:00 +00:00
templates : translations ## render Mako templates (for lists of coins, tokens, etc.)
2018-08-22 11:48:32 +00:00
./tools/build_templates
2024-03-15 10:56:00 +00:00
templates_check : translations_check ## check that Mako-rendered files match their templates
2018-08-22 11:48:32 +00:00
./tools/build_templates --check
2023-10-18 10:02:09 +00:00
2024-03-15 10:56:00 +00:00
translations : ## update translations
python ./translations/order.py
python ./translations/cli.py gen
translations_check : ## check that translations are up to date
# spits out error if the stored merkle root is not up to date
python ./translations/cli.py merkle-root > /dev/null
2017-03-25 13:46:38 +00:00
## build commands:
2018-02-02 19:06:25 +00:00
build : build_boardloader build_bootloader build_firmware build_prodtest build_unix ## build all
2017-02-20 10:36:07 +00:00
2018-08-01 16:52:58 +00:00
build_embed : build_boardloader build_bootloader build_firmware # build boardloader, bootloader, firmware
2017-04-10 17:11:44 +00:00
build_boardloader : ## build boardloader
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
2024-04-16 13:52:17 +00:00
CMAKELISTS = " $( CMAKELISTS) " NEW_RENDERING = " $( NEW_RENDERING) " $( BOARDLOADER_BUILD_DIR) /boardloader.bin
2017-03-18 11:02:39 +00:00
2017-04-10 17:24:21 +00:00
build_bootloader : ## build bootloader
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
2024-04-16 13:52:17 +00:00
CMAKELISTS = " $( CMAKELISTS) " BOOTLOADER_QA = " $( BOOTLOADER_QA) " BOOTLOADER_DEVEL = " $( BOOTLOADER_DEVEL) " \
NEW_RENDERING = " $( NEW_RENDERING) " $( BOOTLOADER_BUILD_DIR) /bootloader.bin
2017-03-20 14:41:21 +00:00
2020-08-21 12:39:56 +00:00
build_bootloader_ci : ## build CI device testing bootloader
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
CMAKELISTS = " $( CMAKELISTS) " $( BOOTLOADER_CI_BUILD_DIR) /bootloader.bin
2020-08-21 12:39:56 +00:00
2023-03-23 14:42:21 +00:00
build_bootloader_emu : ## build the unix bootloader emulator
2024-04-16 13:52:17 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
CMAKELISTS = " $( CMAKELISTS) " NEW_RENDERING = " $( NEW_RENDERING) " $( BOOTLOADER_EMU_BUILD_DIR) /bootloader.elf
build_bootloader_emu_debug : ## build the unix bootloader emulator
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
CMAKELISTS = " $( CMAKELISTS) " NEW_RENDERING = " $( NEW_RENDERING) " TREZOR_EMULATOR_DEBUGGABLE = 1 \
$( BOOTLOADER_EMU_BUILD_DIR) /bootloader.elf
2023-03-23 14:42:21 +00:00
2017-10-24 16:16:36 +00:00
build_prodtest : ## build production test firmware
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
2023-08-10 09:30:13 +00:00
CMAKELISTS = " $( CMAKELISTS) " BOOTLOADER_DEVEL = " $( BOOTLOADER_DEVEL) " $( PRODTEST_BUILD_DIR) /prodtest.bin
2017-10-24 16:16:36 +00:00
2017-11-06 14:46:27 +00:00
build_reflash : ## build reflash firmware + reflash image
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " TREZOR_MODEL = " $( TREZOR_MODEL) " \
2024-04-16 13:52:17 +00:00
CMAKELISTS = " $( CMAKELISTS) " NEW_RENDERING = " $( NEW_RENDERING) " $( REFLASH_BUILD_DIR) /reflash.bin
2017-11-06 14:46:27 +00:00
dd if = build/boardloader/boardloader.bin of = $( REFLASH_BUILD_DIR) /sdimage.bin bs = 1 seek = 0
dd if = build/bootloader/bootloader.bin of = $( REFLASH_BUILD_DIR) /sdimage.bin bs = 1 seek = 49152
2024-08-13 05:47:59 +00:00
build_kernel : ## build kernel image
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " \
2024-09-04 09:17:11 +00:00
TREZOR_MODEL = " $( TREZOR_MODEL) " CMAKELISTS = " $( CMAKELISTS) " \
2024-08-13 05:47:59 +00:00
BOOTLOADER_QA = " $( BOOTLOADER_QA) " BOOTLOADER_DEVEL = " $( BOOTLOADER_DEVEL) " \
$( KERNEL_BUILD_DIR) /kernel.bin
2024-09-16 12:12:51 +00:00
build_firmware : templates build_cross build_kernel ## build firmware with frozen modules
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " PRODUCTION = " $( PRODUCTION) " \
TREZOR_MODEL = " $( TREZOR_MODEL) " CMAKELISTS = " $( CMAKELISTS) " \
PYOPT = " $( PYOPT) " BITCOIN_ONLY = " $( BITCOIN_ONLY) " \
2023-11-13 15:52:37 +00:00
BOOTLOADER_QA = " $( BOOTLOADER_QA) " BOOTLOADER_DEVEL = " $( BOOTLOADER_DEVEL) " \
2024-04-16 13:52:17 +00:00
DISABLE_OPTIGA = " $( DISABLE_OPTIGA) " THP = " $( THP) " NEW_RENDERING = " $( NEW_RENDERING) " \
2023-11-13 15:52:37 +00:00
$( FIRMWARE_BUILD_DIR) /firmware.bin
2017-03-29 20:00:17 +00:00
2020-11-13 10:17:48 +00:00
build_unix : templates ## build unix port
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " $( UNIX_BUILD_DIR) /trezor-emu-core $( UNIX_PORT_OPTS) \
2024-04-02 14:51:01 +00:00
TREZOR_MODEL = " $( TREZOR_MODEL) " CMAKELISTS = " $( CMAKELISTS) " THP = " $( THP) " \
2024-04-16 13:52:17 +00:00
PYOPT = "0" BITCOIN_ONLY = " $( BITCOIN_ONLY) " TREZOR_EMULATOR_ASAN = " $( ADDRESS_SANITIZER) " \
NEW_RENDERING = " $( NEW_RENDERING) "
2016-04-29 14:02:18 +00:00
2020-11-13 10:17:48 +00:00
build_unix_frozen : templates build_cross ## build unix port with frozen modules
2023-05-04 12:32:02 +00:00
$( SCONS) CFLAGS = " $( CFLAGS) " $( UNIX_BUILD_DIR) /trezor-emu-core $( UNIX_PORT_OPTS) \
TREZOR_MODEL = " $( TREZOR_MODEL) " CMAKELISTS = " $( CMAKELISTS) " \
PYOPT = " $( PYOPT) " BITCOIN_ONLY = " $( BITCOIN_ONLY) " TREZOR_EMULATOR_ASAN = " $( ADDRESS_SANITIZER) " \
2024-04-16 13:52:17 +00:00
TREZOR_MEMPERF = " $( TREZOR_MEMPERF) " TREZOR_EMULATOR_FROZEN = 1 NEW_RENDERING = " $( NEW_RENDERING) "
2019-05-04 20:10:01 +00:00
2020-11-13 10:17:48 +00:00
build_unix_debug : templates ## build unix port
2023-05-04 12:32:02 +00:00
$( SCONS) --max-drift= 1 CFLAGS = " $( CFLAGS) " $( UNIX_BUILD_DIR) /trezor-emu-core $( UNIX_PORT_OPTS) \
TREZOR_MODEL = " $( TREZOR_MODEL) " CMAKELISTS = " $( CMAKELISTS) " \
2024-04-16 13:52:17 +00:00
BITCOIN_ONLY = " $( BITCOIN_ONLY) " TREZOR_EMULATOR_ASAN = 1 TREZOR_EMULATOR_DEBUGGABLE = 1 \
NEW_RENDERING = " $( NEW_RENDERING) "
2019-05-27 12:17:43 +00:00
2017-03-30 14:47:02 +00:00
build_cross : ## build mpy-cross port
2017-02-24 12:19:00 +00:00
$( MAKE) -C vendor/micropython/mpy-cross $( CROSS_PORT_OPTS)
2016-05-17 15:17:23 +00:00
2017-03-25 13:46:38 +00:00
## clean commands:
2023-04-13 14:38:00 +00:00
clean : clean_boardloader clean_bootloader clean_bootloader_emu clean_bootloader_ci clean_prodtest clean_reflash clean_firmware clean_unix clean_cross ## clean all
2019-11-21 14:01:10 +00:00
rm -f ".sconsign.dblite"
2017-01-23 09:21:48 +00:00
2017-04-10 17:11:44 +00:00
clean_boardloader : ## clean boardloader build
2017-11-06 15:44:34 +00:00
rm -rf $( BOARDLOADER_BUILD_DIR)
2017-03-20 16:45:40 +00:00
2017-04-10 17:24:21 +00:00
clean_bootloader : ## clean bootloader build
2017-11-06 15:44:34 +00:00
rm -rf $( BOOTLOADER_BUILD_DIR)
2017-03-20 16:45:40 +00:00
2021-03-22 21:06:08 +00:00
clean_bootloader_ci : ## clean bootloader_ci build
rm -rf $( BOOTLOADER_CI_BUILD_DIR)
2023-04-13 14:38:00 +00:00
clean_bootloader_emu : ## clean bootloader_emu build
rm -rf $( BOOTLOADER_EMU_BUILD_DIR)
2017-10-24 16:16:36 +00:00
clean_prodtest : ## clean prodtest build
2017-11-06 15:44:34 +00:00
rm -rf $( PRODTEST_BUILD_DIR)
2017-10-24 16:16:36 +00:00
2017-11-06 14:46:27 +00:00
clean_reflash : ## clean reflash build
rm -rf $( REFLASH_BUILD_DIR)
2024-08-13 05:47:59 +00:00
clean_kernel : ## clean kernel build
rm -rf $( KERNEL_BUILD_DIR)
2017-03-29 20:00:17 +00:00
clean_firmware : ## clean firmware build
2021-03-23 12:14:33 +00:00
rm -rf $( FIRMWARE_BUILD_DIR) $( RUST_BUILD_DIR)
2017-03-29 20:00:17 +00:00
2016-04-11 15:55:10 +00:00
clean_unix : ## clean unix build
2021-03-23 12:14:33 +00:00
rm -rf $( UNIX_BUILD_DIR) $( RUST_BUILD_DIR)
2016-04-11 15:55:10 +00:00
2016-09-19 15:08:41 +00:00
clean_cross : ## clean mpy-cross build
2017-02-24 12:19:00 +00:00
$( MAKE) -C vendor/micropython/mpy-cross clean $( CROSS_PORT_OPTS)
2016-11-24 13:27:30 +00:00
2017-03-25 13:46:38 +00:00
## flash commands:
2017-09-26 13:10:56 +00:00
flash : flash_boardloader flash_bootloader flash_firmware ## flash everything using OpenOCD
flash_boardloader : $( BOARDLOADER_BUILD_DIR ) /boardloader .bin ## flash boardloader using OpenOCD
2017-10-11 19:15:22 +00:00
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( BOARDLOADER_START) ; exit "
2016-09-28 16:15:06 +00:00
2017-09-26 13:10:56 +00:00
flash_bootloader : $( BOOTLOADER_BUILD_DIR ) /bootloader .bin ## flash bootloader using OpenOCD
2017-10-11 19:15:22 +00:00
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( BOOTLOADER_START) ; exit "
2017-03-19 14:29:48 +00:00
2020-08-21 12:39:56 +00:00
flash_bootloader_ci : $( BOOTLOADER_CI_BUILD_DIR ) /bootloader .bin ## flash CI bootloader using OpenOCD
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( BOOTLOADER_START) ; exit "
2017-10-26 22:41:22 +00:00
flash_prodtest : $( PRODTEST_BUILD_DIR ) /prodtest .bin ## flash prodtest using OpenOCD
2024-02-22 21:24:56 +00:00
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( FIRMWARE_START) ; exit "
2017-10-26 22:41:22 +00:00
2017-09-26 13:10:56 +00:00
flash_firmware : $( FIRMWARE_BUILD_DIR ) /firmware .bin ## flash firmware using OpenOCD
2024-02-22 21:24:56 +00:00
i f e q ( $( MCU ) , $( filter $ ( MCU ) ,STM 32F 4) )
2023-06-28 08:51:30 +00:00
$( OPENOCD) -c " init; reset halt; flash write_image erase $<.p1 $( FIRMWARE_START) ; flash write_image erase $<.p2 $( FIRMWARE_P2_START) ; exit "
2017-03-29 20:00:17 +00:00
2023-06-28 08:51:30 +00:00
e l s e
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( FIRMWARE_START) ; exit "
e n d i f
2020-05-21 08:05:12 +00:00
2017-10-27 04:01:22 +00:00
flash_combine : $( PRODTEST_BUILD_DIR ) /combined .bin ## flash combined using OpenOCD
2024-04-25 08:08:13 +00:00
$( OPENOCD) -c " init; reset halt; flash write_image erase $< $( BOARDLOADER_START) ; exit "
2017-09-25 13:49:42 +00:00
2017-09-26 13:10:56 +00:00
flash_erase : ## erase all sectors in flash bank 0
$( OPENOCD) -c "init; reset halt; flash info 0; flash erase_sector 0 0 last; flash erase_check 0; exit"
2017-05-30 15:48:19 +00:00
2024-01-04 11:08:00 +00:00
flash_erase_bootloader : ## erase bootloader
$( OPENOCD) -c " init; reset halt; flash info 0; flash erase_sector 0 $( BOOTLOADER_SECTOR_START) $( BOOTLOADER_SECTOR_END) ; exit "
flash_erase_firmware : ## erase bootloader
2024-02-22 21:24:56 +00:00
i f e q ( $( MCU ) , $( filter $ ( MCU ) ,STM 32F 4) )
2024-09-23 14:25:18 +00:00
$( OPENOCD) -c " init; reset halt; flash info 0; flash erase_sector 0 $( FIRMWARE_P1_SECTOR_START) $( FIRMWARE_P1_SECTOR_END) ; flash erase_sector 0 $( FIRMWARE_P2_SECTOR_START) $( FIRMWARE_P2_SECTOR_END) ; exit "
2024-01-04 11:08:00 +00:00
e l s e
$( OPENOCD) -c " init; reset halt; flash info 0; flash erase_sector 0 $( FIRMWARE_SECTOR_START) $( FIRMWARE_SECTOR_END) ; exit "
e n d i f
2019-01-25 14:59:21 +00:00
flash_read_storage : ## read storage sectors from flash
2024-01-04 11:08:00 +00:00
$( OPENOCD) -c " init; reset halt; flash read_bank 0 storage1.data $( STORAGE_1_OFFSET) $( STORAGE_SIZE) ; flash read_bank 0 storage2.data $( STORAGE_2_OFFSET) $( STORAGE_SIZE) ; exit "
2019-01-25 14:59:21 +00:00
flash_erase_storage : ## erase storage sectors from flash
2024-01-04 11:08:00 +00:00
$( OPENOCD) -c " init; reset halt; flash erase_sector 0 $( STORAGE_1_SECTOR_START) $( STORAGE_1_SECTOR_END) ; flash erase_sector 0 $( STORAGE_2_SECTOR_START) $( STORAGE_2_SECTOR_END) ; exit "
2019-01-25 14:59:21 +00:00
2020-03-23 09:40:06 +00:00
flash_bootloader_jlink : $( BOOTLOADER_BUILD_DIR ) /bootloader .bin ## flash bootloader using JLink
2022-04-04 11:02:09 +00:00
JLinkExe -nogui 1 -commanderscript embed/bootloader/bootloader_flash.jlink
2020-03-23 09:40:06 +00:00
2020-08-21 12:39:56 +00:00
flash_bootloader_ci_jlink : $( BOOTLOADER_CI_BUILD_DIR ) /bootloader .bin ## flash CI bootloader using JLink
2022-04-04 11:02:09 +00:00
JLinkExe -nogui 1 -commanderscript embed/bootloader_ci/bootloader_flash.jlink
2020-08-21 12:39:56 +00:00
2020-03-23 09:40:06 +00:00
flash_firmware_jlink : $( FIRMWARE_BUILD_DIR ) /firmware .bin ## flash firmware using JLink. file names must end in .bin for JLink
cp -f $<.p1 $<.p1.bin
cp -f $<.p2 $<.p2.bin
2024-01-15 13:29:42 +00:00
## pad 2nd part so that FW integrity works after flash
## read&compare in flashing will avoid erasing unmodified sectors
truncate -s $( FIRMWARE_P2_MAXSIZE) $<.p2.bin
2022-04-04 11:02:09 +00:00
JLinkExe -nogui 1 -commanderscript embed/firmware/firmware_flash.jlink
2020-03-23 09:40:06 +00:00
2017-03-25 13:46:38 +00:00
## openocd debug commands:
2016-03-30 14:36:39 +00:00
openocd : ## start openocd which connects to the device
2017-09-26 13:10:56 +00:00
$( OPENOCD)
2016-03-30 14:36:39 +00:00
2017-11-10 19:02:35 +00:00
openocd_reset : ## cause a system reset using OpenOCD
$( OPENOCD) -c "init; reset; exit"
2017-09-28 22:04:11 +00:00
GDB = arm-none-eabi-gdb --nx -ex 'set remotetimeout unlimited' -ex 'set confirm off' -ex 'target remote 127.0.0.1:3333' -ex 'monitor reset halt'
gdb_boardloader : $( BOARDLOADER_BUILD_DIR ) /boardloader .elf ## start remote gdb session to openocd with boardloader symbols
$( GDB) $<
gdb_bootloader : $( BOOTLOADER_BUILD_DIR ) /bootloader .elf ## start remote gdb session to openocd with bootloader symbols
$( GDB) $<
2017-10-29 14:45:23 +00:00
gdb_prodtest : $( PRODTEST_BUILD_DIR ) /prodtest .elf ## start remote gdb session to openocd with prodtest symbols
$( GDB) $<
2017-09-28 22:04:11 +00:00
gdb_firmware : $( FIRMWARE_BUILD_DIR ) /firmware .elf ## start remote gdb session to openocd with firmware symbols
$( GDB) $<
2017-04-10 14:40:41 +00:00
## misc commands:
binctl : ## print info about binary files
2020-01-03 15:53:55 +00:00
./tools/headertool.py $( BOOTLOADER_BUILD_DIR) /bootloader.bin
./tools/headertool.py $( FIRMWARE_BUILD_DIR) /firmware.bin
2017-04-10 14:40:41 +00:00
bloaty : ## run bloaty size profiler
2017-04-28 13:39:22 +00:00
bloaty -d symbols -n 0 -s file $( FIRMWARE_BUILD_DIR) /firmware.elf | less
bloaty -d compileunits -n 0 -s file $( FIRMWARE_BUILD_DIR) /firmware.elf | less
sizecheck : ## check sizes of binary files
2017-10-30 13:07:52 +00:00
test $( BOARDLOADER_MAXSIZE) -ge $( shell wc -c < $( BOARDLOADER_BUILD_DIR) /boardloader.bin)
test $( BOOTLOADER_MAXSIZE) -ge $( shell wc -c < $( BOOTLOADER_BUILD_DIR) /bootloader.bin)
2018-06-20 12:55:30 +00:00
test $( FIRMWARE_P1_MAXSIZE) -ge $( shell wc -c < $( FIRMWARE_BUILD_DIR) /firmware.bin.p1)
test $( FIRMWARE_P2_MAXSIZE) -ge $( shell wc -c < $( FIRMWARE_BUILD_DIR) /firmware.bin.p2)
2017-10-30 13:07:52 +00:00
test $( FIRMWARE_MAXSIZE) -ge $( shell wc -c < $( FIRMWARE_BUILD_DIR) /firmware.bin)
2017-05-30 15:48:19 +00:00
2017-10-27 04:01:22 +00:00
combine : ## combine boardloader + bootloader + prodtest into one combined image
2024-07-31 15:40:17 +00:00
combine_firmware \
$( TREZOR_MODEL) \
2023-06-28 08:51:30 +00:00
$( PRODTEST_BUILD_DIR) /combined.bin \
2024-02-22 21:24:56 +00:00
-b BOARDLOADER $( BOARDLOADER_BUILD_DIR) /boardloader.bin \
-b BOOTLOADER $( BOOTLOADER_BUILD_DIR) /bootloader.bin \
-b FIRMWARE $( PRODTEST_BUILD_DIR) /prodtest.bin
i f e q ( $( MCU ) , $( filter $ ( MCU ) ,STM 32F 4) )
combine_fw : ## combine boardloader + bootloader + firmware into one combined image
2024-07-31 15:40:17 +00:00
combine_firmware \
$( TREZOR_MODEL) \
2024-02-22 21:24:56 +00:00
$( PRODTEST_BUILD_DIR) /combined.bin \
-b BOARDLOADER $( BOARDLOADER_BUILD_DIR) /boardloader.bin \
-b BOOTLOADER $( BOOTLOADER_BUILD_DIR) /bootloader.bin \
-b FIRMWARE $( FIRMWARE_BUILD_DIR) /firmware.bin.p1 \
-b FIRMWARE_P2 $( FIRMWARE_BUILD_DIR) /firmware.bin.p2
e l s e i f e q ( $( MCU ) , $( filter $ ( MCU ) ,STM 32U 5) )
combine_fw : ## combine boardloader + bootloader + firmware into one combined image
2024-07-31 15:40:17 +00:00
combine_firmware \
$( TREZOR_MODEL) \
2024-02-22 21:24:56 +00:00
$( PRODTEST_BUILD_DIR) /combined.bin \
-b BOARDLOADER $( BOARDLOADER_BUILD_DIR) /boardloader.bin \
-b BOOTLOADER $( BOOTLOADER_BUILD_DIR) /bootloader.bin \
-b FIRMWARE $( FIRMWARE_BUILD_DIR) /firmware.bin
e n d i f
2017-10-16 16:03:04 +00:00
upload : ## upload firmware using trezorctl
2023-09-18 19:39:25 +00:00
trezorctl firmware_update -s -f $( FIRMWARE_BUILD_DIR) /firmware.bin
2017-10-26 22:41:22 +00:00
upload_prodtest : ## upload prodtest using trezorctl
2023-09-18 19:39:25 +00:00
trezorctl firmware_update -s -f $( PRODTEST_BUILD_DIR) /prodtest.bin
2019-05-27 12:17:43 +00:00
2022-12-15 15:55:48 +00:00
coverage : ## generate coverage report
2020-08-13 16:37:43 +00:00
./tools/coverage-report
2022-12-15 15:55:48 +00:00
unused : ## find unused micropython code
vulture src src/_vulture_ignore.txt --exclude "messages.py,*/enums/*"
2023-05-04 12:32:02 +00:00
2024-03-15 10:56:00 +00:00
.PHONY : templates translations templates_check translations_check