svn commit: r361774 - head/sys/crypto/aesni

John Baldwin jhb at FreeBSD.org
Wed Jun 3 22:15:11 UTC 2020


Author: jhb
Date: Wed Jun  3 22:15:11 2020
New Revision: 361774
URL: https://svnweb.freebsd.org/changeset/base/361774

Log:
  Explicitly zero on-stack IVs, tags, and HMAC keys.
  
  Reviewed by:	delphij
  Sponsored by:	Netflix
  Differential Revision:	https://reviews.freebsd.org/D25057

Modified:
  head/sys/crypto/aesni/aesni.c

Modified: head/sys/crypto/aesni/aesni.c
==============================================================================
--- head/sys/crypto/aesni/aesni.c	Wed Jun  3 22:11:05 2020	(r361773)
+++ head/sys/crypto/aesni/aesni.c	Wed Jun  3 22:15:11 2020	(r361774)
@@ -815,6 +815,8 @@ out:
 		explicit_bzero(outbuf, crp->crp_payload_length);
 		free(outbuf, M_AESNI);
 	}
+	explicit_bzero(iv, sizeof(iv));
+	explicit_bzero(tag, sizeof(tag));
 	return (error);
 }
 
@@ -826,9 +828,7 @@ aesni_cipher_mac(struct aesni_session *ses, struct cry
 		struct SHA256Context sha2 __aligned(16);
 		struct sha1_ctxt sha1 __aligned(16);
 	} sctx;
-	uint8_t hmac_key[SHA1_BLOCK_LEN] __aligned(16);
 	uint32_t res[SHA2_256_HASH_LEN / sizeof(uint32_t)];
-	uint32_t res2[SHA2_256_HASH_LEN / sizeof(uint32_t)];
 	const uint8_t *key;
 	int i, keylen;
 
@@ -839,6 +839,8 @@ aesni_cipher_mac(struct aesni_session *ses, struct cry
 	keylen = csp->csp_auth_klen;
 
 	if (ses->hmac) {
+		uint8_t hmac_key[SHA1_BLOCK_LEN] __aligned(16);
+
 		/* Inner hash: (K ^ IPAD) || data */
 		ses->hash_init(&sctx);
 		for (i = 0; i < keylen; i++)
@@ -869,6 +871,7 @@ aesni_cipher_mac(struct aesni_session *ses, struct cry
 		ses->hash_update(&sctx, hmac_key, sizeof(hmac_key));
 		ses->hash_update(&sctx, res, ses->hash_len);
 		ses->hash_finalize(res, &sctx);
+		explicit_bzero(hmac_key, sizeof(hmac_key));
 	} else {
 		ses->hash_init(&sctx);
 
@@ -889,10 +892,14 @@ aesni_cipher_mac(struct aesni_session *ses, struct cry
 	}
 
 	if (crp->crp_op & CRYPTO_OP_VERIFY_DIGEST) {
+		uint32_t res2[SHA2_256_HASH_LEN / sizeof(uint32_t)];
+
 		crypto_copydata(crp, crp->crp_digest_start, ses->mlen, res2);
 		if (timingsafe_bcmp(res, res2, ses->mlen) != 0)
 			return (EBADMSG);
+		explicit_bzero(res2, sizeof(res2));
 	} else
 		crypto_copyback(crp, crp->crp_digest_start, ses->mlen, res);
+	explicit_bzero(res, sizeof(res));
 	return (0);
 }


More information about the svn-src-all mailing list