From 0aacd3754acafa2e84e9cf092571b5c34ee70d6c Mon Sep 17 00:00:00 2001 From: Xavier Chapron Date: Fri, 26 Jan 2024 09:11:47 +0100 Subject: [PATCH] src: Use CX_ASSERT to fix warn-unused-result --- src/handlers/sign.c | 14 +++++++------- src/handlers/sign_personal_message.c | 26 ++++++++++++++++---------- src/helpers.c | 14 +++++++------- src/tokens.c | 16 ++++++++-------- 4 files changed, 38 insertions(+), 32 deletions(-) diff --git a/src/handlers/sign.c b/src/handlers/sign.c index 16fcdc0..733e93b 100644 --- a/src/handlers/sign.c +++ b/src/handlers/sign.c @@ -135,7 +135,7 @@ int handleSign(uint8_t p1, uint8_t p2, uint8_t *workBuffer, uint16_t dataLength) return io_send_sw(E_INCORRECT_P1_P2); } // hash data - cx_hash_no_throw((cx_hash_t *) &txContext.sha2, 0, workBuffer, dataLength, NULL, 32); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &txContext.sha2, 0, workBuffer, dataLength, NULL, 32)); #ifdef HAVE_SWAP if (G_called_from_swap) { @@ -180,12 +180,12 @@ int handleSign(uint8_t p1, uint8_t p2, uint8_t *workBuffer, uint16_t dataLength) } // Last data hash - cx_hash_no_throw((cx_hash_t *) &txContext.sha2, - CX_LAST, - workBuffer, - 0, - transactionContext.hash, - 32); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &txContext.sha2, + CX_LAST, + workBuffer, + 0, + transactionContext.hash, + 32)); if (txContent.permission_id > 0) { PRINTF("Set permission_id...\n"); diff --git a/src/handlers/sign_personal_message.c b/src/handlers/sign_personal_message.c index 64daa7f..ea9c514 100644 --- a/src/handlers/sign_personal_message.c +++ b/src/handlers/sign_personal_message.c @@ -48,17 +48,18 @@ int handleSignPersonalMessage(uint8_t p1, uint8_t p2, uint8_t *workBuffer, uint1 dataLength -= 4; // Initialize message header + length - cx_keccak_init_no_throw(&sha3, 256); - cx_hash_no_throw((cx_hash_t *) &sha3, - 0, - (const uint8_t *) SIGN_MAGIC, - sizeof(SIGN_MAGIC) - 1, - NULL, - 0); + CX_ASSERT(cx_keccak_init_no_throw(&sha3, 256)); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &sha3, + 0, + (const uint8_t *) SIGN_MAGIC, + sizeof(SIGN_MAGIC) - 1, + NULL, + 0)); char tmp[11]; snprintf((char *) tmp, 11, "%d", (uint32_t) txContent.dataBytes); - cx_hash_no_throw((cx_hash_t *) &sha3, 0, (const uint8_t *) tmp, strlen(tmp), NULL, 0); + CX_ASSERT( + cx_hash_no_throw((cx_hash_t *) &sha3, 0, (const uint8_t *) tmp, strlen(tmp), NULL, 0)); } else if (p1 != P1_MORE) { return io_send_sw(E_INCORRECT_P1_P2); @@ -71,10 +72,15 @@ int handleSignPersonalMessage(uint8_t p1, uint8_t p2, uint8_t *workBuffer, uint1 return io_send_sw(E_INCORRECT_LENGTH); } - cx_hash_no_throw((cx_hash_t *) &sha3, 0, workBuffer, dataLength, NULL, 0); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &sha3, 0, workBuffer, dataLength, NULL, 0)); txContent.dataBytes -= dataLength; if (txContent.dataBytes == 0) { - cx_hash_no_throw((cx_hash_t *) &sha3, CX_LAST, workBuffer, 0, transactionContext.hash, 32); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &sha3, + CX_LAST, + workBuffer, + 0, + transactionContext.hash, + 32)); #ifdef HAVE_BAGL #define HASH_LENGTH 4 format_hex(transactionContext.hash, HASH_LENGTH / 2, fullContract, sizeof(fullContract)); diff --git a/src/helpers.c b/src/helpers.c index 4c4e028..8499e48 100644 --- a/src/helpers.c +++ b/src/helpers.c @@ -28,13 +28,13 @@ void getAddressFromPublicKey(const uint8_t *publicKey, uint8_t address[static AD uint8_t hashAddress[HASH_SIZE]; cx_sha3_t sha3; - cx_keccak_init_no_throw(&sha3, 256); - cx_hash_no_throw((cx_hash_t *) &sha3, - CX_LAST, - publicKey + 1, - PUBLIC_KEY_SIZE - 1, - hashAddress, - HASH_SIZE); + CX_ASSERT(cx_keccak_init_no_throw(&sha3, 256)); + CX_ASSERT(cx_hash_no_throw((cx_hash_t *) &sha3, + CX_LAST, + publicKey + 1, + PUBLIC_KEY_SIZE - 1, + hashAddress, + HASH_SIZE)); memmove(address, hashAddress + 11, ADDRESS_SIZE); address[0] = ADD_PRE_FIX_BYTE_MAINNET; diff --git a/src/tokens.c b/src/tokens.c index fa0454a..6b912ff 100644 --- a/src/tokens.c +++ b/src/tokens.c @@ -1576,10 +1576,10 @@ int verifyTokenNameID(const char *tokenId, cx_hash_sha256(buffer, strlen(tokenId) + strlen(tokenName) + 1, hash, 32); - cx_ecfp_init_public_key_no_throw(CX_CURVE_256K1, - (uint8_t *) PIC(&token_public_key), - 65, - &publicKey); + CX_ASSERT(cx_ecfp_init_public_key_no_throw(CX_CURVE_256K1, + (uint8_t *) PIC(&token_public_key), + 65, + &publicKey)); int ret = cx_ecdsa_verify_no_throw(&publicKey, hash, 32, signature, signatureLength); @@ -1595,10 +1595,10 @@ int verifyExchangeID(const unsigned char *exchangeValidation, cx_hash_sha256(exchangeValidation, datLength, hash, 32); - cx_ecfp_init_public_key_no_throw(CX_CURVE_256K1, - (uint8_t *) PIC(&token_public_key), - 65, - &publicKey); + CX_ASSERT(cx_ecfp_init_public_key_no_throw(CX_CURVE_256K1, + (uint8_t *) PIC(&token_public_key), + 65, + &publicKey)); int ret = cx_ecdsa_verify_no_throw(&publicKey, hash, 32, signature, signatureLength);