mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-11-22 07:28:10 +00:00
legacy/signing.c: Revert formatting of the workflow of streamed signing.
This commit is contained in:
parent
e688fa8775
commit
15d8f9def6
@ -118,6 +118,7 @@ enum {
|
|||||||
#define PROGRESS_PRECISION 16
|
#define PROGRESS_PRECISION 16
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
clang-format off
|
||||||
|
|
||||||
Workflow of streamed signing
|
Workflow of streamed signing
|
||||||
The STAGE_ constants describe the signing_stage when request is sent.
|
The STAGE_ constants describe the signing_stage when request is sent.
|
||||||
@ -131,20 +132,29 @@ Phase1 - check inputs, previous transactions, and outputs
|
|||||||
=========================================================
|
=========================================================
|
||||||
|
|
||||||
foreach I (idx1):
|
foreach I (idx1):
|
||||||
Request I STAGE_REQUEST_1_INPUT Add I to segwit hash_prevouts, hash_sequence
|
Request I STAGE_REQUEST_1_INPUT
|
||||||
|
Add I to segwit hash_prevouts, hash_sequence
|
||||||
Add I to Decred decred_hash_prefix
|
Add I to Decred decred_hash_prefix
|
||||||
Add I to TransactionChecksum (prevout and type)
|
Add I to TransactionChecksum (prevout and type)
|
||||||
if (Decred)
|
if (Decred)
|
||||||
Return I
|
Return I
|
||||||
If not segwit, Calculate amount of I:
|
If not segwit, Calculate amount of I:
|
||||||
Request prevhash I, META STAGE_REQUEST_2_PREV_META foreach prevhash I
|
Request prevhash I, META STAGE_REQUEST_2_PREV_META
|
||||||
(idx2): Request prevhash I STAGE_REQUEST_2_PREV_INPUT foreach prevhash O (idx2):
|
foreach prevhash I (idx2):
|
||||||
Request prevhash O STAGE_REQUEST_2_PREV_OUTPUT Add amount of
|
Request prevhash I STAGE_REQUEST_2_PREV_INPUT
|
||||||
prevhash O (which is amount of I) Request prevhash extra data (if applicable)
|
foreach prevhash O (idx2):
|
||||||
STAGE_REQUEST_2_PREV_EXTRADATA Calculate hash of streamed tx, compare to
|
Request prevhash O STAGE_REQUEST_2_PREV_OUTPUT
|
||||||
prevhash I foreach O (idx1): Request O STAGE_REQUEST_3_OUTPUT Add O to Decred
|
Add amount of prevhash O (which is amount of I)
|
||||||
decred_hash_prefix Add O to TransactionChecksum if (Decred) Return O Display
|
Request prevhash extra data (if applicable) STAGE_REQUEST_2_PREV_EXTRADATA
|
||||||
output Ask for confirmation
|
Calculate hash of streamed tx, compare to prevhash I
|
||||||
|
foreach O (idx1):
|
||||||
|
Request O STAGE_REQUEST_3_OUTPUT
|
||||||
|
Add O to Decred decred_hash_prefix
|
||||||
|
Add O to TransactionChecksum
|
||||||
|
if (Decred)
|
||||||
|
Return O
|
||||||
|
Display output
|
||||||
|
Ask for confirmation
|
||||||
|
|
||||||
Check tx fee
|
Check tx fee
|
||||||
Ask for confirmation
|
Ask for confirmation
|
||||||
@ -157,17 +167,21 @@ if (Decred)
|
|||||||
|
|
||||||
foreach I (idx1): // input to sign
|
foreach I (idx1): // input to sign
|
||||||
if (idx1 is segwit)
|
if (idx1 is segwit)
|
||||||
Request I STAGE_REQUEST_SEGWIT_INPUT Return serialized input chunk
|
Request I STAGE_REQUEST_SEGWIT_INPUT
|
||||||
|
Return serialized input chunk
|
||||||
|
|
||||||
else
|
else
|
||||||
foreach I (idx2):
|
foreach I (idx2):
|
||||||
Request I STAGE_REQUEST_4_INPUT If idx1 == idx2 Fill scriptsig
|
Request I STAGE_REQUEST_4_INPUT
|
||||||
|
If idx1 == idx2
|
||||||
|
Fill scriptsig
|
||||||
Remember key for signing
|
Remember key for signing
|
||||||
Add I to StreamTransactionSign
|
Add I to StreamTransactionSign
|
||||||
Add I to TransactionChecksum
|
Add I to TransactionChecksum
|
||||||
foreach O (idx2):
|
foreach O (idx2):
|
||||||
Request O STAGE_REQUEST_4_OUTPUT Add O to StreamTransactionSign Add
|
Request O STAGE_REQUEST_4_OUTPUT
|
||||||
O to TransactionChecksum
|
Add O to StreamTransactionSign
|
||||||
|
Add O to TransactionChecksum
|
||||||
|
|
||||||
Compare TransactionChecksum with checksum computed in Phase 1
|
Compare TransactionChecksum with checksum computed in Phase 1
|
||||||
If different:
|
If different:
|
||||||
@ -176,24 +190,32 @@ O to TransactionChecksum
|
|||||||
Return signed chunk
|
Return signed chunk
|
||||||
|
|
||||||
foreach O (idx1):
|
foreach O (idx1):
|
||||||
Request O STAGE_REQUEST_5_OUTPUT Rewrite change address Return O
|
Request O STAGE_REQUEST_5_OUTPUT
|
||||||
|
Rewrite change address
|
||||||
|
Return O
|
||||||
|
|
||||||
|
|
||||||
Phase3: sign segwit inputs, check that nothing changed
|
Phase3: sign segwit inputs, check that nothing changed
|
||||||
===============================================
|
===============================================
|
||||||
|
|
||||||
foreach I (idx1): // input to sign
|
foreach I (idx1): // input to sign
|
||||||
Request I STAGE_REQUEST_SEGWIT_WITNESS Check amount Sign segwit prevhash,
|
Request I STAGE_REQUEST_SEGWIT_WITNESS
|
||||||
sequence, amount, outputs Return witness
|
Check amount
|
||||||
|
Sign segwit prevhash, sequence, amount, outputs
|
||||||
|
Return witness
|
||||||
|
|
||||||
Phase3: sign Decred inputs
|
Phase3: sign Decred inputs
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
foreach I (idx1): // input to sign STAGE_REQUEST_DECRED_WITNESS Request I Fill
|
foreach I (idx1): // input to sign STAGE_REQUEST_DECRED_WITNESS
|
||||||
scriptSig Compute hash_witness
|
Request I
|
||||||
|
Fill scriptSig
|
||||||
|
Compute hash_witness
|
||||||
|
|
||||||
Sign (hash_type || decred_hash_prefix || hash_witness)
|
Sign (hash_type || decred_hash_prefix || hash_witness)
|
||||||
Return witness
|
Return witness
|
||||||
|
|
||||||
|
clang-format on
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void send_req_1_input(void) {
|
void send_req_1_input(void) {
|
||||||
|
Loading…
Reference in New Issue
Block a user