提交 e29abda5 编写于 作者: H Harsh Jain 提交者: Herbert Xu

crypto: chcr - Increase priority of AEAD algos.

templates(gcm,ccm etc) inherit priority value of driver to
calculate its priority. In some cases template priority becomes
 more than driver priority for same algo.
Without this patch we will not be able to use driver authenc algos. It will
be good if it pushed in stable kernel.
Signed-off-by: NHarsh Jain <harsh@chelsio.com>
Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
上级 cd15f102
...@@ -2673,6 +2673,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2673,6 +2673,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_name = "gcm(aes)", .cra_name = "gcm(aes)",
.cra_driver_name = "gcm-aes-chcr", .cra_driver_name = "gcm-aes-chcr",
.cra_blocksize = 1, .cra_blocksize = 1,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_gcm_ctx), sizeof(struct chcr_gcm_ctx),
...@@ -2691,6 +2692,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2691,6 +2692,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_name = "rfc4106(gcm(aes))", .cra_name = "rfc4106(gcm(aes))",
.cra_driver_name = "rfc4106-gcm-aes-chcr", .cra_driver_name = "rfc4106-gcm-aes-chcr",
.cra_blocksize = 1, .cra_blocksize = 1,
.cra_priority = CHCR_AEAD_PRIORITY + 1,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_gcm_ctx), sizeof(struct chcr_gcm_ctx),
...@@ -2710,6 +2712,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2710,6 +2712,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_name = "ccm(aes)", .cra_name = "ccm(aes)",
.cra_driver_name = "ccm-aes-chcr", .cra_driver_name = "ccm-aes-chcr",
.cra_blocksize = 1, .cra_blocksize = 1,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx), sizeof(struct chcr_aead_ctx),
...@@ -2728,6 +2731,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2728,6 +2731,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_name = "rfc4309(ccm(aes))", .cra_name = "rfc4309(ccm(aes))",
.cra_driver_name = "rfc4309-ccm-aes-chcr", .cra_driver_name = "rfc4309-ccm-aes-chcr",
.cra_blocksize = 1, .cra_blocksize = 1,
.cra_priority = CHCR_AEAD_PRIORITY + 1,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx), sizeof(struct chcr_aead_ctx),
...@@ -2747,6 +2751,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2747,6 +2751,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-hmac-sha1-cbc-aes-chcr", "authenc-hmac-sha1-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2768,6 +2773,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2768,6 +2773,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-hmac-sha256-cbc-aes-chcr", "authenc-hmac-sha256-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2788,6 +2794,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2788,6 +2794,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-hmac-sha224-cbc-aes-chcr", "authenc-hmac-sha224-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2807,6 +2814,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2807,6 +2814,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-hmac-sha384-cbc-aes-chcr", "authenc-hmac-sha384-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2827,6 +2835,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2827,6 +2835,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-hmac-sha512-cbc-aes-chcr", "authenc-hmac-sha512-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2847,6 +2856,7 @@ static struct chcr_alg_template driver_algs[] = { ...@@ -2847,6 +2856,7 @@ static struct chcr_alg_template driver_algs[] = {
.cra_driver_name = .cra_driver_name =
"authenc-digest_null-cbc-aes-chcr", "authenc-digest_null-cbc-aes-chcr",
.cra_blocksize = AES_BLOCK_SIZE, .cra_blocksize = AES_BLOCK_SIZE,
.cra_priority = CHCR_AEAD_PRIORITY,
.cra_ctxsize = sizeof(struct chcr_context) + .cra_ctxsize = sizeof(struct chcr_context) +
sizeof(struct chcr_aead_ctx) + sizeof(struct chcr_aead_ctx) +
sizeof(struct chcr_authenc_ctx), sizeof(struct chcr_authenc_ctx),
...@@ -2915,8 +2925,6 @@ static int chcr_register_alg(void) ...@@ -2915,8 +2925,6 @@ static int chcr_register_alg(void)
name = driver_algs[i].alg.crypto.cra_driver_name; name = driver_algs[i].alg.crypto.cra_driver_name;
break; break;
case CRYPTO_ALG_TYPE_AEAD: case CRYPTO_ALG_TYPE_AEAD:
driver_algs[i].alg.aead.base.cra_priority =
CHCR_CRA_PRIORITY;
driver_algs[i].alg.aead.base.cra_flags = driver_algs[i].alg.aead.base.cra_flags =
CRYPTO_ALG_TYPE_AEAD | CRYPTO_ALG_ASYNC; CRYPTO_ALG_TYPE_AEAD | CRYPTO_ALG_ASYNC;
driver_algs[i].alg.aead.encrypt = chcr_aead_encrypt; driver_algs[i].alg.aead.encrypt = chcr_aead_encrypt;
......
...@@ -48,8 +48,8 @@ ...@@ -48,8 +48,8 @@
* giving the processed data * giving the processed data
*/ */
#define CHCR_CRA_PRIORITY 3000 #define CHCR_CRA_PRIORITY 500
#define CHCR_AEAD_PRIORITY 6000
#define CHCR_AES_MAX_KEY_LEN (2 * (AES_MAX_KEY_SIZE)) /* consider xts */ #define CHCR_AES_MAX_KEY_LEN (2 * (AES_MAX_KEY_SIZE)) /* consider xts */
#define CHCR_MAX_CRYPTO_IV_LEN 16 /* AES IV len */ #define CHCR_MAX_CRYPTO_IV_LEN 16 /* AES IV len */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册