updated sequence number in AD and unit tests

This commit is contained in:
JacobBarthelmeh 2014-07-14 16:13:24 -06:00
parent 4250955003
commit 5b08cb35d7
2 changed files with 33 additions and 23 deletions

View File

@ -4921,6 +4921,13 @@ static INLINE int Encrypt(CYASSL* ssl, byte* out, const byte* input, word16 sz)
printf("%02x", additional[i]); printf("%02x", additional[i]);
} }
printf("\n\n"); printf("\n\n");
printf("input before encryption :\n");
for (i = 0; i < sz; i++) {
printf("%02x", input[i]);
if ((i + 1) % 16 == 0)
printf("\n");
}
printf("\n");
#endif #endif
/* get nonce using implicit and explicit IV */ /* get nonce using implicit and explicit IV */
@ -4961,9 +4968,7 @@ static INLINE int Encrypt(CYASSL* ssl, byte* out, const byte* input, word16 sz)
((sz - AEAD_EXP_IV_SZ - ssl->specs.aead_mac_size) >>24) & 0xff; ((sz - AEAD_EXP_IV_SZ - ssl->specs.aead_mac_size) >>24) & 0xff;
/* generate tag */ /* generate tag */
Poly1305SetKey(ssl->encrypt.poly1305, Poly1305SetKey(ssl->encrypt.poly1305, cipher, sizeof(cipher));
ssl->keys.server_write_MAC_secret,
sizeof(ssl->keys.server_write_MAC_secret));
Poly1305Update(ssl->encrypt.poly1305, p, Poly1305Update(ssl->encrypt.poly1305, p,
CHACHA20_BLOCK_SIZE + padding2 + 16); CHACHA20_BLOCK_SIZE + padding2 + 16);
Poly1305Final(ssl->encrypt.poly1305, tag); Poly1305Final(ssl->encrypt.poly1305, tag);
@ -4975,7 +4980,13 @@ static INLINE int Encrypt(CYASSL* ssl, byte* out, const byte* input, word16 sz)
XMEMSET(nonce, 0, AEAD_NONCE_SZ); XMEMSET(nonce, 0, AEAD_NONCE_SZ);
#ifdef CHACHA_AEAD_TEST #ifdef CHACHA_AEAD_TEST
printf("output after encrypt :\n"); printf("mac tag :\n");
for (i = 0; i < 16; i++) {
printf("%02x", tag[i]);
if ((i + 1) % 16 == 0)
printf("\n");
}
printf("\n\noutput after encrypt :\n");
for (i = 0; i < sz; i++) { for (i = 0; i < sz; i++) {
printf("%02x", out[i]); printf("%02x", out[i]);
if ((i + 1) % 16 == 0) if ((i + 1) % 16 == 0)
@ -5152,7 +5163,7 @@ static INLINE int Decrypt(CYASSL* ssl, byte* plain, const byte* input,
XMEMSET(p, 0, CHACHA20_BLOCK_SIZE + padding2 + 16); XMEMSET(p, 0, CHACHA20_BLOCK_SIZE + padding2 + 16);
/* sequence number field is 64-bits, we only use 32-bits */ /* sequence number field is 64-bits, we only use 32-bits */
c32toa(GetSEQIncrement(ssl, 0), additional + AEAD_SEQ_OFFSET); c32toa(GetSEQIncrement(ssl, 1), additional + AEAD_SEQ_OFFSET);
/* get AD info */ /* get AD info */
additional[AEAD_TYPE_OFFSET] = ssl->curRL.type; additional[AEAD_TYPE_OFFSET] = ssl->curRL.type;
@ -5205,9 +5216,7 @@ static INLINE int Decrypt(CYASSL* ssl, byte* plain, const byte* input,
((sz - AEAD_EXP_IV_SZ - ssl->specs.aead_mac_size) >>24) & 0xff; ((sz - AEAD_EXP_IV_SZ - ssl->specs.aead_mac_size) >>24) & 0xff;
/* create Poly1305 tag */ /* create Poly1305 tag */
Poly1305SetKey(ssl->decrypt.poly1305, Poly1305SetKey(ssl->decrypt.poly1305, cipher, sizeof(cipher));
ssl->keys.server_write_MAC_secret,
sizeof(ssl->keys.server_write_MAC_secret));
Poly1305Update(ssl->decrypt.poly1305, p, Poly1305Update(ssl->decrypt.poly1305, p,
CHACHA20_BLOCK_SIZE + padding2 + 16); CHACHA20_BLOCK_SIZE + padding2 + 16);
Poly1305Final(ssl->decrypt.poly1305, tag); Poly1305Final(ssl->decrypt.poly1305, tag);
@ -5220,6 +5229,7 @@ static INLINE int Decrypt(CYASSL* ssl, byte* plain, const byte* input,
} }
if (ret == 1) { if (ret == 1) {
CYASSL_MSG("Mac did not match");
SendAlert(ssl, alert_fatal, bad_record_mac); SendAlert(ssl, alert_fatal, bad_record_mac);
XMEMSET(nonce, 0, AEAD_NONCE_SZ); XMEMSET(nonce, 0, AEAD_NONCE_SZ);
return VERIFY_MAC_ERROR; return VERIFY_MAC_ERROR;

View File

@ -350,15 +350,15 @@
-A ./certs/server-ecc.pem -A ./certs/server-ecc.pem
# server TLSv1.1 ECDHE-EDCSA-CHACHA20-POLY1305 # server TLSv1.1 ECDHE-EDCSA-CHACHA20-POLY1305
#-v 2 -v 2
#-l ECDHE-ECDSA-CHACHA20-256-POLY1305-SHA256 -l ECDHE-ECDSA-CHACHA20-256-POLY1305-SHA256
#-c ./certs/server-ecc.pem -c ./certs/server-ecc.pem
#-k ./certs/ecc-key.pem -k ./certs/ecc-key.pem
# client TLSv1.1 ECDHE-ECDSA-CHACHA20-POLY1305 # client TLSv1.1 ECDHE-ECDSA-CHACHA20-POLY1305
#-v 2 -v 2
#-l ECDHE-ECDSA-CHACHA20-256-POLY1305-SHA256 -l ECDHE-ECDSA-CHACHA20-256-POLY1305-SHA256
#-A ./certs/server-ecc.pem -A ./certs/server-ecc.pem
# server TLSv1.1 ECDHE-ECDSA-DES3 # server TLSv1.1 ECDHE-ECDSA-DES3
-v 2 -v 2
@ -730,12 +730,12 @@
-l ECDHE-RSA-AES256-SHA384 -l ECDHE-RSA-AES256-SHA384
# server TLSv1.1 ECDHE-RSA-CHACHA20-POLY1305 # server TLSv1.1 ECDHE-RSA-CHACHA20-POLY1305
#-v 2 -v 2
#-l ECDHE-RSA-CHACHA20-256-POLY1305-SHA256 -l ECDHE-RSA-CHACHA20-256-POLY1305-SHA256
# server TLSv1.1 ECDHE-RSA-CHACHA20-POLY1305 # server TLSv1.1 ECDHE-RSA-CHACHA20-POLY1305
#-v 2 -v 2
#-l ECDHE-RSA-CHACHA20-256-POLY1305-SHA256 -l ECDHE-RSA-CHACHA20-256-POLY1305-SHA256
# server TLSv1.2 ECDHE-ECDSA-AES256-SHA384 # server TLSv1.2 ECDHE-ECDSA-AES256-SHA384
-v 3 -v 3
@ -1054,12 +1054,12 @@
-l DHE-RSA-AES128-SHA -l DHE-RSA-AES128-SHA
# server TLSv1 DHE-RSA-CHACHA20-POLY1305 # server TLSv1 DHE-RSA-CHACHA20-POLY1305
#-v 1 -v 1
#-l DHE-RSA-CHACHA20-256-POLY1305-SHA256 -l DHE-RSA-CHACHA20-256-POLY1305-SHA256
# server TLSv1 DHE-RSA-CHACHA20-POLY1305 # server TLSv1 DHE-RSA-CHACHA20-POLY1305
#-v 1 -v 1
#-l DHE-RSA-CHACHA20-256-POLY1305-SHA256 -l DHE-RSA-CHACHA20-256-POLY1305-SHA256
# server TLSv1 DHE AES256 # server TLSv1 DHE AES256
-v 1 -v 1