Loading src/common/crypto.c +2 −3 Original line number Diff line number Diff line Loading @@ -997,7 +997,7 @@ int crypto_dh_compute_secret(crypto_dh_env_t *dh, goto error; secret_tmp = tor_malloc(crypto_dh_get_bytes(dh)+1); secret_len = DH_compute_key(secret_tmp, pubkey_bn, dh->dh); assert(secret_len == crypto_dh_get_bytes(dh)); /* sometimes secret_len might be less than 128, e.g., 127. that's ok. */ for (i = 0; i < secret_bytes_out; i += 20) { secret_tmp[secret_len] = (unsigned char) i/20; if (crypto_SHA_digest(secret_tmp, secret_len+1, hash)) Loading @@ -1012,8 +1012,7 @@ int crypto_dh_compute_secret(crypto_dh_env_t *dh, done: if (pubkey_bn) BN_free(pubkey_bn); if (secret_tmp) free(secret_tmp); tor_free(secret_tmp); return secret_len; } void crypto_dh_free(crypto_dh_env_t *dh) Loading src/common/crypto.h +1 −1 Original line number Diff line number Diff line Loading @@ -99,7 +99,7 @@ crypto_cipher_env_t *crypto_create_init_cipher(int cipher_type, char *key, char /* SHA-1 */ int crypto_SHA_digest(const unsigned char *m, int len, unsigned char *digest); crypto_digest_env_t *crypto_digest_new_env(int type); crypto_digest_env_t *crypto_new_digest_env(int type); void crypto_free_digest_env(crypto_digest_env_t *digest); void crypto_digest_add_bytes(crypto_digest_env_t *digest, const char *data, size_t len); Loading Loading
src/common/crypto.c +2 −3 Original line number Diff line number Diff line Loading @@ -997,7 +997,7 @@ int crypto_dh_compute_secret(crypto_dh_env_t *dh, goto error; secret_tmp = tor_malloc(crypto_dh_get_bytes(dh)+1); secret_len = DH_compute_key(secret_tmp, pubkey_bn, dh->dh); assert(secret_len == crypto_dh_get_bytes(dh)); /* sometimes secret_len might be less than 128, e.g., 127. that's ok. */ for (i = 0; i < secret_bytes_out; i += 20) { secret_tmp[secret_len] = (unsigned char) i/20; if (crypto_SHA_digest(secret_tmp, secret_len+1, hash)) Loading @@ -1012,8 +1012,7 @@ int crypto_dh_compute_secret(crypto_dh_env_t *dh, done: if (pubkey_bn) BN_free(pubkey_bn); if (secret_tmp) free(secret_tmp); tor_free(secret_tmp); return secret_len; } void crypto_dh_free(crypto_dh_env_t *dh) Loading
src/common/crypto.h +1 −1 Original line number Diff line number Diff line Loading @@ -99,7 +99,7 @@ crypto_cipher_env_t *crypto_create_init_cipher(int cipher_type, char *key, char /* SHA-1 */ int crypto_SHA_digest(const unsigned char *m, int len, unsigned char *digest); crypto_digest_env_t *crypto_digest_new_env(int type); crypto_digest_env_t *crypto_new_digest_env(int type); void crypto_free_digest_env(crypto_digest_env_t *digest); void crypto_digest_add_bytes(crypto_digest_env_t *digest, const char *data, size_t len); Loading