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

Conrad Meyer cem at FreeBSD.org
Wed Jul 18 04:37:15 UTC 2018


Author: cem
Date: Wed Jul 18 04:37:14 2018
New Revision: 336443
URL: https://svnweb.freebsd.org/changeset/base/336443

Log:
  aesni(4): Add sha256 plain hash support

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

Modified: head/sys/crypto/aesni/aesni.c
==============================================================================
--- head/sys/crypto/aesni/aesni.c	Wed Jul 18 04:29:44 2018	(r336442)
+++ head/sys/crypto/aesni/aesni.c	Wed Jul 18 04:37:14 2018	(r336443)
@@ -196,6 +196,7 @@ aesni_attach(device_t dev)
 	if (sc->has_sha) {
 		crypto_register(sc->cid, CRYPTO_SHA1, 0, 0);
 		crypto_register(sc->cid, CRYPTO_SHA1_HMAC, 0, 0);
+		crypto_register(sc->cid, CRYPTO_SHA2_256, 0, 0);
 		crypto_register(sc->cid, CRYPTO_SHA2_256_HMAC, 0, 0);
 	}
 	return (0);
@@ -265,6 +266,7 @@ aesni_newsession(device_t dev, crypto_session_t cses, 
 			break;
 		case CRYPTO_SHA1:
 		case CRYPTO_SHA1_HMAC:
+		case CRYPTO_SHA2_256:
 		case CRYPTO_SHA2_256_HMAC:
 			if (!sc->has_sha)
 				goto unhandled;
@@ -350,6 +352,7 @@ aesni_process(device_t dev, struct cryptop *crp, int h
 		case CRYPTO_AES_256_NIST_GMAC:
 		case CRYPTO_SHA1:
 		case CRYPTO_SHA1_HMAC:
+		case CRYPTO_SHA2_256:
 		case CRYPTO_SHA2_256_HMAC:
 			if (authcrd != NULL) {
 				error = EINVAL;
@@ -477,6 +480,7 @@ aesni_cipher_setup(struct aesni_session *ses, struct c
 	switch (ses->auth_algo) {
 	case CRYPTO_SHA1:
 	case CRYPTO_SHA1_HMAC:
+	case CRYPTO_SHA2_256:
 	case CRYPTO_SHA2_256_HMAC:
 		error = aesni_authprepare(ses, authini->cri_klen,
 		    authini->cri_key);
@@ -858,6 +862,8 @@ aesni_cipher_mac(struct aesni_session *ses, struct cry
 
 	case CRYPTO_SHA2_256_HMAC:
 		hmac = true;
+		/* FALLTHROUGH */
+	case CRYPTO_SHA2_256:
 		hashlen = SHA2_256_HASH_LEN;
 		InitFn = SHA256_Init_fn;
 		UpdateFn = intel_sha256_update;


More information about the svn-src-all mailing list