mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-08 22:40:59 +00:00
check return value of cryptoHDNodePathToPubkey
This commit is contained in:
parent
309604d286
commit
4122b56e1c
@ -255,6 +255,7 @@ int cryptoMessageDecrypt(curve_point *nonce, uint8_t *payload, pb_size_t payload
|
|||||||
|
|
||||||
uint8_t *cryptoHDNodePathToPubkey(const HDNodePathType *hdnodepath)
|
uint8_t *cryptoHDNodePathToPubkey(const HDNodePathType *hdnodepath)
|
||||||
{
|
{
|
||||||
|
if (!hdnodepath->node.has_public_key || hdnodepath->node.public_key.size != 33) return 0;
|
||||||
static HDNode node;
|
static HDNode node;
|
||||||
if (hdnode_from_xpub(hdnodepath->node.depth, hdnodepath->node.fingerprint, hdnodepath->node.child_num, hdnodepath->node.chain_code.bytes, hdnodepath->node.public_key.bytes, &node) == 0) {
|
if (hdnode_from_xpub(hdnodepath->node.depth, hdnodepath->node.fingerprint, hdnodepath->node.child_num, hdnodepath->node.chain_code.bytes, hdnodepath->node.public_key.bytes, &node) == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
@ -272,7 +273,8 @@ int cryptoMultisigPubkeyIndex(const MultisigRedeemScriptType *multisig, const ui
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < multisig->pubkeys_count; i++) {
|
for (i = 0; i < multisig->pubkeys_count; i++) {
|
||||||
if (memcmp(cryptoHDNodePathToPubkey(&(multisig->pubkeys[i])), pubkey, 33) == 0) {
|
const uint8_t *node_pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
|
if (node_pubkey && memcmp(node_pubkey, pubkey, 33) == 0) {
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,9 +24,9 @@
|
|||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include "trezor.h"
|
#include "trezor.h"
|
||||||
|
|
||||||
#define MSG_IN_SIZE (9*1024)
|
#define MSG_IN_SIZE (12*1024)
|
||||||
|
|
||||||
#define MSG_OUT_SIZE (9*1024)
|
#define MSG_OUT_SIZE (12*1024)
|
||||||
|
|
||||||
#define msg_read(buf, len) msg_read_common('n', (buf), (len))
|
#define msg_read(buf, len) msg_read_common('n', (buf), (len))
|
||||||
#define msg_write(id, ptr) msg_write_common('n', (id), (ptr))
|
#define msg_write(id, ptr) msg_write_common('n', (id), (ptr))
|
||||||
|
@ -145,7 +145,9 @@ uint32_t compile_script_multisig(const MultisigRedeemScriptType *multisig, uint8
|
|||||||
out[r] = 0x50 + m; r++;
|
out[r] = 0x50 + m; r++;
|
||||||
for (i = 0; i < n; i++) {
|
for (i = 0; i < n; i++) {
|
||||||
out[r] = 33; r++; // OP_PUSH 33
|
out[r] = 33; r++; // OP_PUSH 33
|
||||||
memcpy(out + r, cryptoHDNodePathToPubkey(&(multisig->pubkeys[i])), 33); r += 33;
|
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
|
if (!pubkey) return 0;
|
||||||
|
memcpy(out + r, pubkey, 33); r += 33;
|
||||||
}
|
}
|
||||||
out[r] = 0x50 + n; r++;
|
out[r] = 0x50 + n; r++;
|
||||||
out[r] = 0xAE; r++; // OP_CHECKMULTISIG
|
out[r] = 0xAE; r++; // OP_CHECKMULTISIG
|
||||||
@ -171,7 +173,9 @@ uint32_t compile_script_multisig_hash(const MultisigRedeemScriptType *multisig,
|
|||||||
uint32_t i;
|
uint32_t i;
|
||||||
for (i = 0; i < n; i++) {
|
for (i = 0; i < n; i++) {
|
||||||
d = 33; sha256_Update(&ctx, &d, 1); // OP_PUSH 33
|
d = 33; sha256_Update(&ctx, &d, 1); // OP_PUSH 33
|
||||||
sha256_Update(&ctx, cryptoHDNodePathToPubkey(&(multisig->pubkeys[i])), 33);
|
const uint8_t *pubkey = cryptoHDNodePathToPubkey(&(multisig->pubkeys[i]));
|
||||||
|
if (!pubkey) return 0;
|
||||||
|
sha256_Update(&ctx, pubkey, 33);
|
||||||
}
|
}
|
||||||
d = 0x50 + n; sha256_Update(&ctx, &d, 1);
|
d = 0x50 + n; sha256_Update(&ctx, &d, 1);
|
||||||
d = 0xAE; sha256_Update(&ctx, &d, 1);
|
d = 0xAE; sha256_Update(&ctx, &d, 1);
|
||||||
|
Loading…
Reference in New Issue
Block a user