14#include "lib/crypt_ops/compat_openssl.h"
27 "FFFFFFFFFFFFFFFFADF85458A2BB4A9AAFDC5620273D3CF1"
28 "D8B9C583CE2D3695A9E13641146433FBCC939DCE249B3EF9"
29 "7D2FE363630C75D8F681B202AEC4617AD3DF1ED5D5FD6561"
30 "2433F51F5F066ED0856365553DED1AF3B557135E7F57C935"
31 "984F0C70E0E68B77E2A689DAF3EFE8721DF158A136ADE735"
32 "30ACCA4F483A797ABC0AB182B324FB61D108A94BB2C8E3FB"
33 "B96ADAB760D7F4681D4F42A3DE394DF4AE56EDE76372BB19"
34 "0B07A7C8EE0A6D709E02FCE1CDF7E2ECC03404CD28342F61"
35 "9172FE9CE98583FF8E4F1232EEF28183C3FE3B1B4C6FAD73"
36 "3BB5FCBC2EC22005C58EF1837D1683B2C6F34A26C1B2EFFA"
37 "886B423861285C97FFFFFFFFFFFFFFFF";
44 "FFFFFFFFFFFFFFFFC90FDAA22168C234C4C6628B80DC1CD129024E08"
45 "8A67CC74020BBEA63B139B22514A08798E3404DDEF9519B3CD3A431B"
46 "302B0A6DF25F14374FE1356D6D51C245E485B576625E7EC6F44C42E9"
47 "A637ED6B0BFF5CB6F406B7EDEE386BFB5A899FA5AE9F24117C4B1FE6"
48 "49286651ECE65381FFFFFFFFFFFFFFFF";
62crypto_dh_free_all(
void)
65 crypto_dh_free_all_openssl();
68 crypto_dh_free_all_nss();
84 const char *pubkey,
size_t pubkey_len,
85 char *secret_out,
size_t secret_bytes_out)
89 unsigned char *secret_tmp = NULL;
90 size_t secret_len=0, secret_tmp_len=0;
92 secret_tmp = tor_malloc(secret_tmp_len);
95 secret_tmp, secret_tmp_len);
101 (uint8_t*)secret_out, secret_bytes_out)<0)
103 secret_len = secret_bytes_out;
110 memwipe(secret_tmp, 0, secret_tmp_len);
ssize_t crypto_dh_compute_secret(int severity, crypto_dh_t *dh, const char *pubkey, size_t pubkey_len, char *secret_out, size_t secret_bytes_out)
const char OAKLEY_PRIME_2[]
const char TLS_DH_PRIME[]
const unsigned DH_GENERATOR
int crypto_dh_get_bytes(crypto_dh_t *dh)
ssize_t crypto_dh_handshake(int severity, crypto_dh_t *dh, const char *pubkey, size_t pubkey_len, unsigned char *secret_out, size_t secret_bytes_out)
void crypto_dh_init_openssl(void)
Headers for crypto_digest.c.
int crypto_expand_key_material_TAP(const uint8_t *key_in, size_t key_in_len, uint8_t *key_out, size_t key_out_len)
Headers for crypto_hkdf.h.
void memwipe(void *mem, uint8_t byte, size_t sz)
Common functions for cryptographic routines.
Macros to manage assertions, fatal and non-fatal.