diff --git a/crypto/bip32.c b/crypto/bip32.c index cb67834764..b78d31159b 100644 --- a/crypto/bip32.c +++ b/crypto/bip32.c @@ -209,6 +209,8 @@ int hdnode_private_ckd_bip32(HDNode *inout, uint32_t i) { memcpy(data + 1, inout->private_key, 32); } else { // public derivation if (!inout->curve->params) { + // SLIP-10 doesn't support private key to private key non-hardened + // derivation for curve25519 and ed25519 return 0; } if (hdnode_fill_public_key(inout) != 0) { @@ -321,6 +323,13 @@ int hdnode_public_ckd_cp(const ecdsa_curve *curve, const curve_point *parent, int hdnode_public_ckd(HDNode *inout, uint32_t i) { curve_point parent = {0}, child = {0}; + if (!inout->curve->params) { + // SLIP-10 doesn't support public key to public key derivation for + // curve25519 and ed25519, Cardano BIP32-ed22519 public key to public key + // derivation is not implemented + return 0; + } + if (!ecdsa_read_pubkey(inout->curve->params, inout->public_key, &parent)) { return 0; }