chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
/*
|
|
|
|
* This file is part of the Chelsio T6 Crypto driver for Linux.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2003-2016 Chelsio Communications, Inc. All rights reserved.
|
|
|
|
*
|
|
|
|
* This software is available to you under a choice of one of two
|
|
|
|
* licenses. You may choose to be licensed under the terms of the GNU
|
|
|
|
* General Public License (GPL) Version 2, available from the file
|
|
|
|
* COPYING in the main directory of this source tree, or the
|
|
|
|
* OpenIB.org BSD license below:
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or
|
|
|
|
* without modification, are permitted provided that the following
|
|
|
|
* conditions are met:
|
|
|
|
*
|
|
|
|
* - Redistributions of source code must retain the above
|
|
|
|
* copyright notice, this list of conditions and the following
|
|
|
|
* disclaimer.
|
|
|
|
*
|
|
|
|
* - Redistributions in binary form must reproduce the above
|
|
|
|
* copyright notice, this list of conditions and the following
|
|
|
|
* disclaimer in the documentation and/or other materials
|
|
|
|
* provided with the distribution.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __CHCR_CRYPTO_H__
|
|
|
|
#define __CHCR_CRYPTO_H__
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
#define GHASH_BLOCK_SIZE 16
|
|
|
|
#define GHASH_DIGEST_SIZE 16
|
|
|
|
|
|
|
|
#define CCM_B0_SIZE 16
|
|
|
|
#define CCM_AAD_FIELD_SIZE 2
|
2017-04-10 12:54:01 +00:00
|
|
|
#define T6_MAX_AAD_SIZE 511
|
2016-11-29 13:30:43 +00:00
|
|
|
|
|
|
|
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
/* Define following if h/w is not dropping the AAD and IV data before
|
|
|
|
* giving the processed data
|
|
|
|
*/
|
|
|
|
|
2017-04-10 12:53:58 +00:00
|
|
|
#define CHCR_CRA_PRIORITY 500
|
|
|
|
#define CHCR_AEAD_PRIORITY 6000
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
#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_AUTHENC_AES_KEY_LEN 32 /* max aes key length*/
|
|
|
|
#define CHCR_MAX_AUTHENC_SHA_KEY_LEN 128 /* max sha key length*/
|
|
|
|
|
|
|
|
#define CHCR_GIVENCRYPT_OP 2
|
|
|
|
/* CPL/SCMD parameters */
|
|
|
|
|
|
|
|
#define CHCR_ENCRYPT_OP 0
|
|
|
|
#define CHCR_DECRYPT_OP 1
|
|
|
|
|
|
|
|
#define CHCR_SCMD_SEQ_NO_CTRL_32BIT 1
|
|
|
|
#define CHCR_SCMD_SEQ_NO_CTRL_48BIT 2
|
|
|
|
#define CHCR_SCMD_SEQ_NO_CTRL_64BIT 3
|
|
|
|
|
|
|
|
#define CHCR_SCMD_PROTO_VERSION_GENERIC 4
|
|
|
|
|
|
|
|
#define CHCR_SCMD_AUTH_CTRL_AUTH_CIPHER 0
|
|
|
|
#define CHCR_SCMD_AUTH_CTRL_CIPHER_AUTH 1
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
#define CHCR_SCMD_CIPHER_MODE_NOP 0
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_AES_CBC 1
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_AES_GCM 2
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_AES_CTR 3
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_GENERIC_AES 4
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_AES_XTS 6
|
|
|
|
#define CHCR_SCMD_CIPHER_MODE_AES_CCM 7
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_NOP 0
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA1 1
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA224 2
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA256 3
|
2016-11-29 13:30:43 +00:00
|
|
|
#define CHCR_SCMD_AUTH_MODE_GHASH 4
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA512_224 5
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA512_256 6
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA512_384 7
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_SHA512_512 8
|
2016-11-29 13:30:43 +00:00
|
|
|
#define CHCR_SCMD_AUTH_MODE_CBCMAC 9
|
|
|
|
#define CHCR_SCMD_AUTH_MODE_CMAC 10
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_NOP 0
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_NO_TRUNC 1
|
2016-11-29 13:30:43 +00:00
|
|
|
#define CHCR_SCMD_HMAC_CTRL_TRUNC_RFC4366 2
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_IPSEC_96BIT 3
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_PL1 4
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_PL2 5
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_PL3 6
|
|
|
|
#define CHCR_SCMD_HMAC_CTRL_DIV2 7
|
|
|
|
#define VERIFY_HW 0
|
|
|
|
#define VERIFY_SW 1
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
|
|
|
#define CHCR_SCMD_IVGEN_CTRL_HW 0
|
|
|
|
#define CHCR_SCMD_IVGEN_CTRL_SW 1
|
|
|
|
/* This are not really mac key size. They are intermediate values
|
|
|
|
* of sha engine and its size
|
|
|
|
*/
|
|
|
|
#define CHCR_KEYCTX_MAC_KEY_SIZE_128 0
|
|
|
|
#define CHCR_KEYCTX_MAC_KEY_SIZE_160 1
|
|
|
|
#define CHCR_KEYCTX_MAC_KEY_SIZE_192 2
|
|
|
|
#define CHCR_KEYCTX_MAC_KEY_SIZE_256 3
|
|
|
|
#define CHCR_KEYCTX_MAC_KEY_SIZE_512 4
|
|
|
|
#define CHCR_KEYCTX_CIPHER_KEY_SIZE_128 0
|
|
|
|
#define CHCR_KEYCTX_CIPHER_KEY_SIZE_192 1
|
|
|
|
#define CHCR_KEYCTX_CIPHER_KEY_SIZE_256 2
|
|
|
|
#define CHCR_KEYCTX_NO_KEY 15
|
|
|
|
|
|
|
|
#define CHCR_CPL_FW4_PLD_IV_OFFSET (5 * 64) /* bytes. flt #5 and #6 */
|
|
|
|
#define CHCR_CPL_FW4_PLD_HASH_RESULT_OFFSET (7 * 64) /* bytes. flt #7 */
|
|
|
|
#define CHCR_CPL_FW4_PLD_DATA_SIZE (4 * 64) /* bytes. flt #4 to #7 */
|
|
|
|
|
|
|
|
#define KEY_CONTEXT_HDR_SALT_AND_PAD 16
|
|
|
|
#define flits_to_bytes(x) (x * 8)
|
|
|
|
|
|
|
|
#define IV_NOP 0
|
|
|
|
#define IV_IMMEDIATE 1
|
|
|
|
#define IV_DSGL 2
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
#define AEAD_H_SIZE 16
|
|
|
|
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
#define CRYPTO_ALG_SUB_TYPE_MASK 0x0f000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_HASH_HMAC 0x01000000
|
2016-11-29 13:30:43 +00:00
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_RFC4106 0x02000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_GCM 0x03000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_AUTHENC 0x04000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_CCM 0x05000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_RFC4309 0x06000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_AEAD_NULL 0x07000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_CTR 0x08000000
|
2017-06-15 07:13:43 +00:00
|
|
|
#define CRYPTO_ALG_SUB_TYPE_CTR_RFC3686 0x09000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_XTS 0x0a000000
|
|
|
|
#define CRYPTO_ALG_SUB_TYPE_CBC 0x0b000000
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
#define CRYPTO_ALG_TYPE_HMAC (CRYPTO_ALG_TYPE_AHASH |\
|
|
|
|
CRYPTO_ALG_SUB_TYPE_HASH_HMAC)
|
|
|
|
|
|
|
|
#define MAX_SCRATCH_PAD_SIZE 32
|
|
|
|
|
|
|
|
#define CHCR_HASH_MAX_BLOCK_SIZE_64 64
|
|
|
|
#define CHCR_HASH_MAX_BLOCK_SIZE_128 128
|
2017-10-08 08:07:23 +00:00
|
|
|
#define CHCR_SRC_SG_SIZE (0x10000 - sizeof(int))
|
|
|
|
#define CHCR_DST_SG_SIZE 2048
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
2017-10-08 08:07:23 +00:00
|
|
|
static inline struct chcr_context *a_ctx(struct crypto_aead *tfm)
|
|
|
|
{
|
|
|
|
return crypto_aead_ctx(tfm);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct chcr_context *c_ctx(struct crypto_ablkcipher *tfm)
|
|
|
|
{
|
|
|
|
return crypto_ablkcipher_ctx(tfm);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct chcr_context *h_ctx(struct crypto_ahash *tfm)
|
|
|
|
{
|
|
|
|
return crypto_tfm_ctx(crypto_ahash_tfm(tfm));
|
|
|
|
}
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
|
|
|
struct ablk_ctx {
|
2017-06-15 07:13:43 +00:00
|
|
|
struct crypto_skcipher *sw_cipher;
|
2017-06-23 14:15:11 +00:00
|
|
|
struct crypto_cipher *aes_generic;
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
__be32 key_ctx_hdr;
|
|
|
|
unsigned int enckey_len;
|
|
|
|
unsigned char ciph_mode;
|
2017-06-15 07:13:43 +00:00
|
|
|
u8 key[CHCR_AES_MAX_KEY_LEN];
|
|
|
|
u8 nonce[4];
|
2016-11-29 13:30:42 +00:00
|
|
|
u8 rrkey[AES_MAX_KEY_SIZE];
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
};
|
2016-11-29 13:30:43 +00:00
|
|
|
struct chcr_aead_reqctx {
|
|
|
|
struct sk_buff *skb;
|
2017-10-08 08:07:23 +00:00
|
|
|
dma_addr_t iv_dma;
|
|
|
|
dma_addr_t b0_dma;
|
|
|
|
unsigned int b0_len;
|
|
|
|
unsigned int op;
|
|
|
|
short int aad_nents;
|
|
|
|
short int src_nents;
|
2016-11-29 13:30:43 +00:00
|
|
|
short int dst_nents;
|
2017-10-08 08:07:23 +00:00
|
|
|
u16 imm;
|
2016-11-29 13:30:43 +00:00
|
|
|
u16 verify;
|
|
|
|
u8 iv[CHCR_MAX_CRYPTO_IV_LEN];
|
|
|
|
unsigned char scratch_pad[MAX_SCRATCH_PAD_SIZE];
|
|
|
|
};
|
|
|
|
|
2017-10-08 08:07:23 +00:00
|
|
|
struct ulptx_walk {
|
|
|
|
struct ulptx_sgl *sgl;
|
|
|
|
unsigned int nents;
|
|
|
|
unsigned int pair_idx;
|
|
|
|
unsigned int last_sg_len;
|
|
|
|
struct scatterlist *last_sg;
|
|
|
|
struct ulptx_sge_pair *pair;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
struct dsgl_walk {
|
|
|
|
unsigned int nents;
|
|
|
|
unsigned int last_sg_len;
|
|
|
|
struct scatterlist *last_sg;
|
|
|
|
struct cpl_rx_phys_dsgl *dsgl;
|
|
|
|
struct phys_sge_pairs *to;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
struct chcr_gcm_ctx {
|
|
|
|
u8 ghash_h[AEAD_H_SIZE];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct chcr_authenc_ctx {
|
|
|
|
u8 dec_rrkey[AES_MAX_KEY_SIZE];
|
|
|
|
u8 h_iopad[2 * CHCR_HASH_MAX_DIGEST_SIZE];
|
|
|
|
unsigned char auth_mode;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct __aead_ctx {
|
|
|
|
struct chcr_gcm_ctx gcm[0];
|
|
|
|
struct chcr_authenc_ctx authenc[0];
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
struct chcr_aead_ctx {
|
|
|
|
__be32 key_ctx_hdr;
|
|
|
|
unsigned int enckey_len;
|
2017-04-10 12:54:01 +00:00
|
|
|
struct crypto_aead *sw_cipher;
|
2016-11-29 13:30:43 +00:00
|
|
|
u8 salt[MAX_SALT];
|
|
|
|
u8 key[CHCR_AES_MAX_KEY_LEN];
|
|
|
|
u16 hmac_ctrl;
|
|
|
|
u16 mayverify;
|
|
|
|
struct __aead_ctx ctx[0];
|
|
|
|
};
|
|
|
|
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
|
2016-11-29 13:30:42 +00:00
|
|
|
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
struct hmac_ctx {
|
2016-11-29 13:30:41 +00:00
|
|
|
struct crypto_shash *base_hash;
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
u8 ipad[CHCR_HASH_MAX_BLOCK_SIZE_128];
|
|
|
|
u8 opad[CHCR_HASH_MAX_BLOCK_SIZE_128];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct __crypto_ctx {
|
|
|
|
struct hmac_ctx hmacctx[0];
|
|
|
|
struct ablk_ctx ablkctx[0];
|
2016-11-29 13:30:43 +00:00
|
|
|
struct chcr_aead_ctx aeadctx[0];
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct chcr_context {
|
|
|
|
struct chcr_dev *dev;
|
2017-04-10 12:54:00 +00:00
|
|
|
unsigned char tx_qidx;
|
|
|
|
unsigned char rx_qidx;
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
struct __crypto_ctx crypto_ctx[0];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct chcr_ahash_req_ctx {
|
|
|
|
u32 result;
|
2016-11-29 13:30:38 +00:00
|
|
|
u8 bfr1[CHCR_HASH_MAX_BLOCK_SIZE_128];
|
|
|
|
u8 bfr2[CHCR_HASH_MAX_BLOCK_SIZE_128];
|
|
|
|
u8 *reqbfr;
|
|
|
|
u8 *skbfr;
|
2017-10-08 08:07:23 +00:00
|
|
|
dma_addr_t dma_addr;
|
|
|
|
u32 dma_len;
|
2016-11-29 13:30:38 +00:00
|
|
|
u8 reqlen;
|
2017-10-08 08:07:23 +00:00
|
|
|
u8 imm;
|
|
|
|
u8 is_sg_map;
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
u8 partial_hash[CHCR_HASH_MAX_DIGEST_SIZE];
|
|
|
|
u64 data_len; /* Data len till time */
|
|
|
|
/* SKB which is being sent to the hardware for processing */
|
|
|
|
struct sk_buff *skb;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct chcr_blkcipher_req_ctx {
|
|
|
|
struct sk_buff *skb;
|
2017-06-15 07:13:43 +00:00
|
|
|
struct scatterlist *dstsg;
|
|
|
|
unsigned int processed;
|
2017-10-08 08:07:21 +00:00
|
|
|
unsigned int last_req_len;
|
2017-10-08 08:07:23 +00:00
|
|
|
struct scatterlist *srcsg;
|
|
|
|
unsigned int src_ofst;
|
|
|
|
unsigned int dst_ofst;
|
2017-06-15 07:13:43 +00:00
|
|
|
unsigned int op;
|
2017-10-08 08:07:23 +00:00
|
|
|
dma_addr_t iv_dma;
|
|
|
|
u16 imm;
|
2016-11-29 13:30:42 +00:00
|
|
|
u8 iv[CHCR_MAX_CRYPTO_IV_LEN];
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct chcr_alg_template {
|
|
|
|
u32 type;
|
|
|
|
u32 is_registered;
|
|
|
|
union {
|
|
|
|
struct crypto_alg crypto;
|
|
|
|
struct ahash_alg hash;
|
2016-11-29 13:30:43 +00:00
|
|
|
struct aead_alg aead;
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
} alg;
|
|
|
|
};
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
typedef struct sk_buff *(*create_wr_t)(struct aead_request *req,
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
unsigned short qid,
|
2016-11-29 13:30:43 +00:00
|
|
|
int size,
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
unsigned short op_type);
|
|
|
|
|
2016-11-29 13:30:43 +00:00
|
|
|
static int chcr_aead_op(struct aead_request *req_base,
|
|
|
|
unsigned short op_type,
|
|
|
|
int size,
|
|
|
|
create_wr_t create_wr_fn);
|
|
|
|
static inline int get_aead_subtype(struct crypto_aead *aead);
|
2017-06-15 07:13:43 +00:00
|
|
|
static int chcr_handle_cipher_resp(struct ablkcipher_request *req,
|
|
|
|
unsigned char *input, int err);
|
2017-10-08 08:07:23 +00:00
|
|
|
static void chcr_verify_tag(struct aead_request *req, u8 *input, int *err);
|
|
|
|
static int chcr_aead_dma_map(struct device *dev, struct aead_request *req,
|
|
|
|
unsigned short op_type);
|
|
|
|
static void chcr_aead_dma_unmap(struct device *dev, struct aead_request
|
|
|
|
*req, unsigned short op_type);
|
|
|
|
static inline void chcr_add_aead_dst_ent(struct aead_request *req,
|
|
|
|
struct cpl_rx_phys_dsgl *phys_cpl,
|
|
|
|
unsigned int assoclen,
|
|
|
|
unsigned short op_type,
|
|
|
|
unsigned short qid);
|
|
|
|
static inline void chcr_add_aead_src_ent(struct aead_request *req,
|
|
|
|
struct ulptx_sgl *ulptx,
|
|
|
|
unsigned int assoclen,
|
|
|
|
unsigned short op_type);
|
|
|
|
static inline void chcr_add_cipher_src_ent(struct ablkcipher_request *req,
|
|
|
|
struct ulptx_sgl *ulptx,
|
|
|
|
struct cipher_wr_param *wrparam);
|
|
|
|
static int chcr_cipher_dma_map(struct device *dev,
|
|
|
|
struct ablkcipher_request *req);
|
|
|
|
static void chcr_cipher_dma_unmap(struct device *dev,
|
|
|
|
struct ablkcipher_request *req);
|
|
|
|
static inline void chcr_add_cipher_dst_ent(struct ablkcipher_request *req,
|
|
|
|
struct cpl_rx_phys_dsgl *phys_cpl,
|
|
|
|
struct cipher_wr_param *wrparam,
|
|
|
|
unsigned short qid);
|
|
|
|
int sg_nents_len_skip(struct scatterlist *sg, u64 len, u64 skip);
|
|
|
|
static inline void chcr_add_hash_src_ent(struct ahash_request *req,
|
|
|
|
struct ulptx_sgl *ulptx,
|
|
|
|
struct hash_wr_param *param);
|
|
|
|
static inline int chcr_hash_dma_map(struct device *dev,
|
|
|
|
struct ahash_request *req);
|
|
|
|
static inline void chcr_hash_dma_unmap(struct device *dev,
|
|
|
|
struct ahash_request *req);
|
chcr: Support for Chelsio's Crypto Hardware
The Chelsio's Crypto Hardware can perform the following operations:
SHA1, SHA224, SHA256, SHA384 and SHA512, HMAC(SHA1), HMAC(SHA224),
HMAC(SHA256), HMAC(SHA384), HAMC(SHA512), AES-128-CBC, AES-192-CBC,
AES-256-CBC, AES-128-XTS, AES-256-XTS
This patch implements the driver for above mentioned features. This
driver is an Upper Layer Driver which is attached to Chelsio's LLD
(cxgb4) and uses the queue allocated by the LLD for sending the crypto
requests to the Hardware and receiving the responses from it.
The crypto operations can be performed by Chelsio's hardware from the
userspace applications and/or from within the kernel space using the
kernel's crypto API.
The above mentioned crypto features have been tested using kernel's
tests mentioned in testmgr.h. They also have been tested from user
space using libkcapi and Openssl.
Signed-off-by: Atul Gupta <atul.gupta@chelsio.com>
Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com>
Acked-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-08-17 07:03:05 +00:00
|
|
|
#endif /* __CHCR_CRYPTO_H__ */
|