allow SetKeys() to be called with encrypt or decrypt, or both
This commit is contained in:
parent
596148840d
commit
ed1beafdfc
494
src/keys.c
494
src/keys.c
@ -1806,159 +1806,199 @@ static int SetKeys(Ciphers* enc, Ciphers* dec, Keys* keys, CipherSpecs* specs,
|
|||||||
#ifdef BUILD_ARC4
|
#ifdef BUILD_ARC4
|
||||||
word32 sz = specs->key_size;
|
word32 sz = specs->key_size;
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_rc4) {
|
if (specs->bulk_cipher_algorithm == cyassl_rc4) {
|
||||||
if (enc->arc4 == NULL)
|
if (enc && enc->arc4 == NULL)
|
||||||
enc->arc4 = (Arc4*)XMALLOC(sizeof(Arc4), heap, DYNAMIC_TYPE_CIPHER);
|
enc->arc4 = (Arc4*)XMALLOC(sizeof(Arc4), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->arc4 == NULL)
|
if (enc && enc->arc4 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->arc4 == NULL)
|
if (dec && dec->arc4 == NULL)
|
||||||
dec->arc4 = (Arc4*)XMALLOC(sizeof(Arc4), heap, DYNAMIC_TYPE_CIPHER);
|
dec->arc4 = (Arc4*)XMALLOC(sizeof(Arc4), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->arc4 == NULL)
|
if (dec && dec->arc4 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
#ifdef HAVE_CAVIUM
|
#ifdef HAVE_CAVIUM
|
||||||
if (devId != NO_CAVIUM_DEVICE) {
|
if (devId != NO_CAVIUM_DEVICE) {
|
||||||
if (Arc4InitCavium(enc->arc4, devId) != 0) {
|
if (enc) {
|
||||||
CYASSL_MSG("Arc4InitCavium failed in SetKeys");
|
if (Arc4InitCavium(enc->arc4, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("Arc4InitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (Arc4InitCavium(dec->arc4, devId) != 0) {
|
if (dec) {
|
||||||
CYASSL_MSG("Arc4InitCavium failed in SetKeys");
|
if (Arc4InitCavium(dec->arc4, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("Arc4InitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
Arc4SetKey(enc->arc4, keys->client_write_key, sz);
|
if (enc)
|
||||||
Arc4SetKey(dec->arc4, keys->server_write_key, sz);
|
Arc4SetKey(enc->arc4, keys->client_write_key, sz);
|
||||||
|
if (dec)
|
||||||
|
Arc4SetKey(dec->arc4, keys->server_write_key, sz);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Arc4SetKey(enc->arc4, keys->server_write_key, sz);
|
if (enc)
|
||||||
Arc4SetKey(dec->arc4, keys->client_write_key, sz);
|
Arc4SetKey(enc->arc4, keys->server_write_key, sz);
|
||||||
|
if (dec)
|
||||||
|
Arc4SetKey(dec->arc4, keys->client_write_key, sz);
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_POLY1305
|
#ifdef HAVE_POLY1305
|
||||||
/* set up memory space for poly1305 */
|
/* set up memory space for poly1305 */
|
||||||
if (enc->poly1305 == NULL)
|
if (enc && enc->poly1305 == NULL)
|
||||||
enc->poly1305 = (Poly1305*)malloc(sizeof(Poly1305));
|
enc->poly1305 = (Poly1305*)malloc(sizeof(Poly1305));
|
||||||
if (enc->poly1305 == NULL)
|
if (enc && enc->poly1305 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->poly1305 == NULL)
|
if (dec && dec->poly1305 == NULL)
|
||||||
dec->poly1305 =
|
dec->poly1305 =
|
||||||
(Poly1305*)XMALLOC(sizeof(Poly1305), heap, DYNAMIC_TYPE_CIPHER);
|
(Poly1305*)XMALLOC(sizeof(Poly1305), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->poly1305 == NULL)
|
if (dec && dec->poly1305 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_CHACHA
|
#ifdef HAVE_CHACHA
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_chacha) {
|
if (specs->bulk_cipher_algorithm == cyassl_chacha) {
|
||||||
int chachaRet;
|
int chachaRet;
|
||||||
if (enc->chacha == NULL)
|
if (enc && enc->chacha == NULL)
|
||||||
enc->chacha = (ChaCha*)malloc(sizeof(ChaCha));
|
enc->chacha = (ChaCha*)malloc(sizeof(ChaCha));
|
||||||
if (enc->chacha == NULL)
|
if (enc && enc->chacha == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->chacha == NULL)
|
if (dec && dec->chacha == NULL)
|
||||||
dec->chacha =
|
dec->chacha =
|
||||||
(ChaCha*)XMALLOC(sizeof(ChaCha), heap, DYNAMIC_TYPE_CIPHER);
|
(ChaCha*)XMALLOC(sizeof(ChaCha), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->chacha == NULL)
|
if (dec && dec->chacha == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
chachaRet = Chacha_SetKey(enc->chacha, keys->client_write_key,
|
if (enc) {
|
||||||
specs->key_size);
|
chachaRet = Chacha_SetKey(enc->chacha, keys->client_write_key,
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
specs->key_size);
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->client_write_IV,
|
||||||
if (chachaRet != 0) return chachaRet;
|
AEAD_IMP_IV_SZ);
|
||||||
chachaRet = Chacha_SetKey(dec->chacha, keys->server_write_key,
|
if (chachaRet != 0) return chachaRet;
|
||||||
specs->key_size);
|
}
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
if (dec) {
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
chachaRet = Chacha_SetKey(dec->chacha, keys->server_write_key,
|
||||||
if (chachaRet != 0) return chachaRet;
|
specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->server_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
if (chachaRet != 0) return chachaRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
chachaRet = Chacha_SetKey(enc->chacha, keys->server_write_key,
|
if (enc) {
|
||||||
specs->key_size);
|
chachaRet = Chacha_SetKey(enc->chacha, keys->server_write_key,
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
specs->key_size);
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->server_write_IV,
|
||||||
if (chachaRet != 0) return chachaRet;
|
AEAD_IMP_IV_SZ);
|
||||||
chachaRet = Chacha_SetKey(dec->chacha, keys->client_write_key,
|
if (chachaRet != 0) return chachaRet;
|
||||||
specs->key_size);
|
}
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
if (dec) {
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
chachaRet = Chacha_SetKey(dec->chacha, keys->client_write_key,
|
||||||
if (chachaRet != 0) return chachaRet;
|
specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->client_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
if (chachaRet != 0) return chachaRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_HC128
|
#ifdef HAVE_HC128
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_hc128) {
|
if (specs->bulk_cipher_algorithm == cyassl_hc128) {
|
||||||
int hcRet;
|
int hcRet;
|
||||||
if (enc->hc128 == NULL)
|
if (enc && enc->hc128 == NULL)
|
||||||
enc->hc128 =
|
enc->hc128 =
|
||||||
(HC128*)XMALLOC(sizeof(HC128), heap, DYNAMIC_TYPE_CIPHER);
|
(HC128*)XMALLOC(sizeof(HC128), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->hc128 == NULL)
|
if (enc && enc->hc128 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->hc128 == NULL)
|
if (dec && dec->hc128 == NULL)
|
||||||
dec->hc128 =
|
dec->hc128 =
|
||||||
(HC128*)XMALLOC(sizeof(HC128), heap, DYNAMIC_TYPE_CIPHER);
|
(HC128*)XMALLOC(sizeof(HC128), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->hc128 == NULL)
|
if (dec && dec->hc128 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
hcRet = Hc128_SetKey(enc->hc128, keys->client_write_key,
|
if (enc) {
|
||||||
keys->client_write_IV);
|
hcRet = Hc128_SetKey(enc->hc128, keys->client_write_key,
|
||||||
if (hcRet != 0) return hcRet;
|
keys->client_write_IV);
|
||||||
hcRet = Hc128_SetKey(dec->hc128, keys->server_write_key,
|
if (hcRet != 0) return hcRet;
|
||||||
keys->server_write_IV);
|
}
|
||||||
if (hcRet != 0) return hcRet;
|
if (dec) {
|
||||||
|
hcRet = Hc128_SetKey(dec->hc128, keys->server_write_key,
|
||||||
|
keys->server_write_IV);
|
||||||
|
if (hcRet != 0) return hcRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
hcRet = Hc128_SetKey(enc->hc128, keys->server_write_key,
|
if (enc) {
|
||||||
keys->server_write_IV);
|
hcRet = Hc128_SetKey(enc->hc128, keys->server_write_key,
|
||||||
if (hcRet != 0) return hcRet;
|
keys->server_write_IV);
|
||||||
hcRet = Hc128_SetKey(dec->hc128, keys->client_write_key,
|
if (hcRet != 0) return hcRet;
|
||||||
keys->client_write_IV);
|
}
|
||||||
if (hcRet != 0) return hcRet;
|
if (dec) {
|
||||||
|
hcRet = Hc128_SetKey(dec->hc128, keys->client_write_key,
|
||||||
|
keys->client_write_IV);
|
||||||
|
if (hcRet != 0) return hcRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef BUILD_RABBIT
|
#ifdef BUILD_RABBIT
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_rabbit) {
|
if (specs->bulk_cipher_algorithm == cyassl_rabbit) {
|
||||||
int rabRet;
|
int rabRet;
|
||||||
if (enc->rabbit == NULL)
|
if (enc && enc->rabbit == NULL)
|
||||||
enc->rabbit =
|
enc->rabbit =
|
||||||
(Rabbit*)XMALLOC(sizeof(Rabbit), heap, DYNAMIC_TYPE_CIPHER);
|
(Rabbit*)XMALLOC(sizeof(Rabbit), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->rabbit == NULL)
|
if (enc && enc->rabbit == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->rabbit == NULL)
|
if (dec && dec->rabbit == NULL)
|
||||||
dec->rabbit =
|
dec->rabbit =
|
||||||
(Rabbit*)XMALLOC(sizeof(Rabbit), heap, DYNAMIC_TYPE_CIPHER);
|
(Rabbit*)XMALLOC(sizeof(Rabbit), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->rabbit == NULL)
|
if (dec && dec->rabbit == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
rabRet = RabbitSetKey(enc->rabbit, keys->client_write_key,
|
if (enc) {
|
||||||
keys->client_write_IV);
|
rabRet = RabbitSetKey(enc->rabbit, keys->client_write_key,
|
||||||
if (rabRet != 0) return rabRet;
|
keys->client_write_IV);
|
||||||
rabRet = RabbitSetKey(dec->rabbit, keys->server_write_key,
|
if (rabRet != 0) return rabRet;
|
||||||
keys->server_write_IV);
|
}
|
||||||
if (rabRet != 0) return rabRet;
|
if (dec) {
|
||||||
|
rabRet = RabbitSetKey(dec->rabbit, keys->server_write_key,
|
||||||
|
keys->server_write_IV);
|
||||||
|
if (rabRet != 0) return rabRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
rabRet = RabbitSetKey(enc->rabbit, keys->server_write_key,
|
if (enc) {
|
||||||
keys->server_write_IV);
|
rabRet = RabbitSetKey(enc->rabbit, keys->server_write_key,
|
||||||
if (rabRet != 0) return rabRet;
|
keys->server_write_IV);
|
||||||
rabRet = RabbitSetKey(dec->rabbit, keys->client_write_key,
|
if (rabRet != 0) return rabRet;
|
||||||
keys->client_write_IV);
|
}
|
||||||
if (rabRet != 0) return rabRet;
|
if (dec) {
|
||||||
|
rabRet = RabbitSetKey(dec->rabbit, keys->client_write_key,
|
||||||
|
keys->client_write_IV);
|
||||||
|
if (rabRet != 0) return rabRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1966,48 +2006,58 @@ static int SetKeys(Ciphers* enc, Ciphers* dec, Keys* keys, CipherSpecs* specs,
|
|||||||
if (specs->bulk_cipher_algorithm == cyassl_triple_des) {
|
if (specs->bulk_cipher_algorithm == cyassl_triple_des) {
|
||||||
int desRet = 0;
|
int desRet = 0;
|
||||||
|
|
||||||
if (enc->des3 == NULL)
|
if (enc && enc->des3 == NULL)
|
||||||
enc->des3 = (Des3*)XMALLOC(sizeof(Des3), heap, DYNAMIC_TYPE_CIPHER);
|
enc->des3 = (Des3*)XMALLOC(sizeof(Des3), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->des3 == NULL)
|
if (enc && enc->des3 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->des3 == NULL)
|
if (dec && dec->des3 == NULL)
|
||||||
dec->des3 = (Des3*)XMALLOC(sizeof(Des3), heap, DYNAMIC_TYPE_CIPHER);
|
dec->des3 = (Des3*)XMALLOC(sizeof(Des3), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->des3 == NULL)
|
if (dec && dec->des3 == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
#ifdef HAVE_CAVIUM
|
#ifdef HAVE_CAVIUM
|
||||||
if (devId != NO_CAVIUM_DEVICE) {
|
if (devId != NO_CAVIUM_DEVICE) {
|
||||||
if (Des3_InitCavium(enc->des3, devId) != 0) {
|
if (enc) {
|
||||||
CYASSL_MSG("Des3_InitCavium failed in SetKeys");
|
if (Des3_InitCavium(enc->des3, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("Des3_InitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (Des3_InitCavium(dec->des3, devId) != 0) {
|
if (dec) {
|
||||||
CYASSL_MSG("Des3_InitCavium failed in SetKeys");
|
if (Des3_InitCavium(dec->des3, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("Des3_InitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
desRet = Des3_SetKey(enc->des3, keys->client_write_key,
|
if (enc) {
|
||||||
keys->client_write_IV, DES_ENCRYPTION);
|
desRet = Des3_SetKey(enc->des3, keys->client_write_key,
|
||||||
if (desRet != 0)
|
keys->client_write_IV, DES_ENCRYPTION);
|
||||||
return desRet;
|
if (desRet != 0) return desRet;
|
||||||
desRet = Des3_SetKey(dec->des3, keys->server_write_key,
|
}
|
||||||
keys->server_write_IV, DES_DECRYPTION);
|
if (dec) {
|
||||||
if (desRet != 0)
|
desRet = Des3_SetKey(dec->des3, keys->server_write_key,
|
||||||
return desRet;
|
keys->server_write_IV, DES_DECRYPTION);
|
||||||
|
if (desRet != 0) return desRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
desRet = Des3_SetKey(enc->des3, keys->server_write_key,
|
if (enc) {
|
||||||
keys->server_write_IV, DES_ENCRYPTION);
|
desRet = Des3_SetKey(enc->des3, keys->server_write_key,
|
||||||
if (desRet != 0)
|
keys->server_write_IV, DES_ENCRYPTION);
|
||||||
return desRet;
|
if (desRet != 0) return desRet;
|
||||||
desRet = Des3_SetKey(dec->des3, keys->client_write_key,
|
}
|
||||||
keys->client_write_IV, DES_DECRYPTION);
|
if (dec) {
|
||||||
if (desRet != 0)
|
desRet = Des3_SetKey(dec->des3, keys->client_write_key,
|
||||||
return desRet;
|
keys->client_write_IV, DES_DECRYPTION);
|
||||||
|
if (desRet != 0) return desRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2015,116 +2065,146 @@ static int SetKeys(Ciphers* enc, Ciphers* dec, Keys* keys, CipherSpecs* specs,
|
|||||||
if (specs->bulk_cipher_algorithm == cyassl_aes) {
|
if (specs->bulk_cipher_algorithm == cyassl_aes) {
|
||||||
int aesRet = 0;
|
int aesRet = 0;
|
||||||
|
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
#ifdef HAVE_CAVIUM
|
#ifdef HAVE_CAVIUM
|
||||||
if (devId != NO_CAVIUM_DEVICE) {
|
if (devId != NO_CAVIUM_DEVICE) {
|
||||||
if (AesInitCavium(enc->aes, devId) != 0) {
|
if (enc) {
|
||||||
CYASSL_MSG("AesInitCavium failed in SetKeys");
|
if (AesInitCavium(enc->aes, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("AesInitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (AesInitCavium(dec->aes, devId) != 0) {
|
if (dec) {
|
||||||
CYASSL_MSG("AesInitCavium failed in SetKeys");
|
if (AesInitCavium(dec->aes, devId) != 0) {
|
||||||
return CAVIUM_INIT_E;
|
CYASSL_MSG("AesInitCavium failed in SetKeys");
|
||||||
|
return CAVIUM_INIT_E;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
aesRet = AesSetKey(enc->aes, keys->client_write_key,
|
if (enc) {
|
||||||
specs->key_size, keys->client_write_IV,
|
aesRet = AesSetKey(enc->aes, keys->client_write_key,
|
||||||
AES_ENCRYPTION);
|
specs->key_size, keys->client_write_IV,
|
||||||
if (aesRet != 0)
|
AES_ENCRYPTION);
|
||||||
return aesRet;
|
if (aesRet != 0) return aesRet;
|
||||||
aesRet = AesSetKey(dec->aes, keys->server_write_key,
|
}
|
||||||
specs->key_size, keys->server_write_IV,
|
if (dec) {
|
||||||
AES_DECRYPTION);
|
aesRet = AesSetKey(dec->aes, keys->server_write_key,
|
||||||
if (aesRet != 0)
|
specs->key_size, keys->server_write_IV,
|
||||||
return aesRet;
|
AES_DECRYPTION);
|
||||||
|
if (aesRet != 0) return aesRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
aesRet = AesSetKey(enc->aes, keys->server_write_key,
|
if (enc) {
|
||||||
specs->key_size, keys->server_write_IV,
|
aesRet = AesSetKey(enc->aes, keys->server_write_key,
|
||||||
AES_ENCRYPTION);
|
specs->key_size, keys->server_write_IV,
|
||||||
if (aesRet != 0)
|
AES_ENCRYPTION);
|
||||||
return aesRet;
|
if (aesRet != 0) return aesRet;
|
||||||
aesRet = AesSetKey(dec->aes, keys->client_write_key,
|
}
|
||||||
specs->key_size, keys->client_write_IV,
|
if (dec) {
|
||||||
AES_DECRYPTION);
|
aesRet = AesSetKey(dec->aes, keys->client_write_key,
|
||||||
if (aesRet != 0)
|
specs->key_size, keys->client_write_IV,
|
||||||
return aesRet;
|
AES_DECRYPTION);
|
||||||
|
if (aesRet != 0) return aesRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef BUILD_AESGCM
|
#ifdef BUILD_AESGCM
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_aes_gcm) {
|
if (specs->bulk_cipher_algorithm == cyassl_aes_gcm) {
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
|
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
AesGcmSetKey(enc->aes, keys->client_write_key, specs->key_size);
|
if (enc) {
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
AesGcmSetKey(enc->aes, keys->client_write_key, specs->key_size);
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->client_write_IV,
|
||||||
AesGcmSetKey(dec->aes, keys->server_write_key, specs->key_size);
|
AEAD_IMP_IV_SZ);
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
}
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
if (dec) {
|
||||||
|
AesGcmSetKey(dec->aes, keys->server_write_key, specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->server_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
AesGcmSetKey(enc->aes, keys->server_write_key, specs->key_size);
|
if (enc) {
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
AesGcmSetKey(enc->aes, keys->server_write_key, specs->key_size);
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->server_write_IV,
|
||||||
AesGcmSetKey(dec->aes, keys->client_write_key, specs->key_size);
|
AEAD_IMP_IV_SZ);
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
}
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
if (dec) {
|
||||||
|
AesGcmSetKey(dec->aes, keys->client_write_key, specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->client_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_AESCCM
|
#ifdef HAVE_AESCCM
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_aes_ccm) {
|
if (specs->bulk_cipher_algorithm == cyassl_aes_ccm) {
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
enc->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->aes == NULL)
|
if (enc && enc->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
dec->aes = (Aes*)XMALLOC(sizeof(Aes), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->aes == NULL)
|
if (dec && dec->aes == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
|
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
AesCcmSetKey(enc->aes, keys->client_write_key, specs->key_size);
|
if (enc) {
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
AesCcmSetKey(enc->aes, keys->client_write_key, specs->key_size);
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->client_write_IV,
|
||||||
AesCcmSetKey(dec->aes, keys->server_write_key, specs->key_size);
|
AEAD_IMP_IV_SZ);
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
}
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
if (dec) {
|
||||||
|
AesCcmSetKey(dec->aes, keys->server_write_key, specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->server_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
AesCcmSetKey(enc->aes, keys->server_write_key, specs->key_size);
|
if (enc) {
|
||||||
XMEMCPY(keys->aead_enc_imp_IV,
|
AesCcmSetKey(enc->aes, keys->server_write_key, specs->key_size);
|
||||||
keys->server_write_IV, AEAD_IMP_IV_SZ);
|
XMEMCPY(keys->aead_enc_imp_IV, keys->server_write_IV,
|
||||||
AesCcmSetKey(dec->aes, keys->client_write_key, specs->key_size);
|
AEAD_IMP_IV_SZ);
|
||||||
XMEMCPY(keys->aead_dec_imp_IV,
|
}
|
||||||
keys->client_write_IV, AEAD_IMP_IV_SZ);
|
if (dec) {
|
||||||
|
AesCcmSetKey(dec->aes, keys->client_write_key, specs->key_size);
|
||||||
|
XMEMCPY(keys->aead_dec_imp_IV, keys->client_write_IV,
|
||||||
|
AEAD_IMP_IV_SZ);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2132,49 +2212,55 @@ static int SetKeys(Ciphers* enc, Ciphers* dec, Keys* keys, CipherSpecs* specs,
|
|||||||
if (specs->bulk_cipher_algorithm == cyassl_camellia) {
|
if (specs->bulk_cipher_algorithm == cyassl_camellia) {
|
||||||
int camRet;
|
int camRet;
|
||||||
|
|
||||||
if (enc->cam == NULL)
|
if (enc && enc->cam == NULL)
|
||||||
enc->cam =
|
enc->cam =
|
||||||
(Camellia*)XMALLOC(sizeof(Camellia), heap, DYNAMIC_TYPE_CIPHER);
|
(Camellia*)XMALLOC(sizeof(Camellia), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (enc->cam == NULL)
|
if (enc && enc->cam == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
|
|
||||||
if (dec->cam == NULL)
|
if (dec && dec->cam == NULL)
|
||||||
dec->cam =
|
dec->cam =
|
||||||
(Camellia*)XMALLOC(sizeof(Camellia), heap, DYNAMIC_TYPE_CIPHER);
|
(Camellia*)XMALLOC(sizeof(Camellia), heap, DYNAMIC_TYPE_CIPHER);
|
||||||
if (dec->cam == NULL)
|
if (dec && dec->cam == NULL)
|
||||||
return MEMORY_E;
|
return MEMORY_E;
|
||||||
|
|
||||||
if (side == CYASSL_CLIENT_END) {
|
if (side == CYASSL_CLIENT_END) {
|
||||||
camRet = CamelliaSetKey(enc->cam, keys->client_write_key,
|
if (enc) {
|
||||||
specs->key_size, keys->client_write_IV);
|
camRet = CamelliaSetKey(enc->cam, keys->client_write_key,
|
||||||
if (camRet != 0)
|
specs->key_size, keys->client_write_IV);
|
||||||
return camRet;
|
if (camRet != 0) return camRet;
|
||||||
|
}
|
||||||
camRet = CamelliaSetKey(dec->cam, keys->server_write_key,
|
if (dec) {
|
||||||
specs->key_size, keys->server_write_IV);
|
camRet = CamelliaSetKey(dec->cam, keys->server_write_key,
|
||||||
if (camRet != 0)
|
specs->key_size, keys->server_write_IV);
|
||||||
return camRet;
|
if (camRet != 0) return camRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
camRet = CamelliaSetKey(enc->cam, keys->server_write_key,
|
if (enc) {
|
||||||
specs->key_size, keys->server_write_IV);
|
camRet = CamelliaSetKey(enc->cam, keys->server_write_key,
|
||||||
if (camRet != 0)
|
specs->key_size, keys->server_write_IV);
|
||||||
return camRet;
|
if (camRet != 0) return camRet;
|
||||||
|
}
|
||||||
camRet = CamelliaSetKey(dec->cam, keys->client_write_key,
|
if (dec) {
|
||||||
specs->key_size, keys->client_write_IV);
|
camRet = CamelliaSetKey(dec->cam, keys->client_write_key,
|
||||||
if (camRet != 0)
|
specs->key_size, keys->client_write_IV);
|
||||||
return camRet;
|
if (camRet != 0) return camRet;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_NULL_CIPHER
|
#ifdef HAVE_NULL_CIPHER
|
||||||
if (specs->bulk_cipher_algorithm == cyassl_cipher_null) {
|
if (specs->bulk_cipher_algorithm == cyassl_cipher_null) {
|
||||||
enc->setup = 1;
|
if (enc)
|
||||||
dec->setup = 1;
|
enc->setup = 1;
|
||||||
|
if (dec)
|
||||||
|
dec->setup = 1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user