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 10:03:05 +03: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 16:30:43 +03:00
# define GHASH_BLOCK_SIZE 16
# define GHASH_DIGEST_SIZE 16
# define CCM_B0_SIZE 16
# define CCM_AAD_FIELD_SIZE 2
2018-12-11 13:51:37 +03:00
// 511 - 16(For IV)
# define T6_MAX_AAD_SIZE 495
2016-11-29 16:30:43 +03: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 10:03:05 +03:00
/* Define following if h/w is not dropping the AAD and IV data before
* giving the processed data
*/
2017-04-10 15:53:58 +03: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 10:03:05 +03: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 16:30:43 +03: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 10:03:05 +03: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 16:30:43 +03: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 10:03:05 +03: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 16:30:43 +03: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 10:03:05 +03:00
# define CHCR_SCMD_HMAC_CTRL_NOP 0
# define CHCR_SCMD_HMAC_CTRL_NO_TRUNC 1
2016-11-29 16:30:43 +03: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 10:03:05 +03: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 16:30:43 +03: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 10:03:05 +03:00
# define CRYPTO_ALG_SUB_TYPE_MASK 0x0f000000
# define CRYPTO_ALG_SUB_TYPE_HASH_HMAC 0x01000000
2016-11-29 16:30:43 +03:00
# define CRYPTO_ALG_SUB_TYPE_AEAD_RFC4106 0x02000000
# define CRYPTO_ALG_SUB_TYPE_AEAD_GCM 0x03000000
2018-01-11 14:15:51 +03:00
# define CRYPTO_ALG_SUB_TYPE_CBC_SHA 0x04000000
2016-11-29 16:30:43 +03:00
# define CRYPTO_ALG_SUB_TYPE_AEAD_CCM 0x05000000
# define CRYPTO_ALG_SUB_TYPE_AEAD_RFC4309 0x06000000
2018-01-11 14:15:51 +03:00
# define CRYPTO_ALG_SUB_TYPE_CBC_NULL 0x07000000
2016-11-29 16:30:43 +03:00
# define CRYPTO_ALG_SUB_TYPE_CTR 0x08000000
2017-06-15 10:13:43 +03:00
# define CRYPTO_ALG_SUB_TYPE_CTR_RFC3686 0x09000000
# define CRYPTO_ALG_SUB_TYPE_XTS 0x0a000000
# define CRYPTO_ALG_SUB_TYPE_CBC 0x0b000000
2018-01-11 14:15:51 +03:00
# define CRYPTO_ALG_SUB_TYPE_CTR_SHA 0x0c000000
# define CRYPTO_ALG_SUB_TYPE_CTR_NULL 0x0d000000
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 10:03:05 +03: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 11:07:23 +03: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 10:03:05 +03:00
2017-10-08 11:07:23 +03: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 10:03:05 +03:00
struct ablk_ctx {
2018-09-19 05:10:56 +03:00
struct crypto_sync_skcipher * sw_cipher ;
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 10:03:05 +03:00
__be32 key_ctx_hdr ;
unsigned int enckey_len ;
unsigned char ciph_mode ;
2017-06-15 10:13:43 +03:00
u8 key [ CHCR_AES_MAX_KEY_LEN ] ;
u8 nonce [ 4 ] ;
2016-11-29 16:30:42 +03: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 10:03:05 +03:00
} ;
2016-11-29 16:30:43 +03:00
struct chcr_aead_reqctx {
struct sk_buff * skb ;
2017-10-08 11:07:23 +03:00
dma_addr_t iv_dma ;
dma_addr_t b0_dma ;
unsigned int b0_len ;
unsigned int op ;
u16 imm ;
2016-11-29 16:30:43 +03:00
u16 verify ;
2018-05-24 14:56:39 +03:00
u8 iv [ CHCR_MAX_CRYPTO_IV_LEN + MAX_SCRATCH_PAD_SIZE ] ;
u8 * scratch_pad ;
2016-11-29 16:30:43 +03:00
} ;
2017-10-08 11:07:23 +03: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 16:30:43 +03: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 15:54:01 +03:00
struct crypto_aead * sw_cipher ;
2016-11-29 16:30:43 +03:00
u8 salt [ MAX_SALT ] ;
u8 key [ CHCR_AES_MAX_KEY_LEN ] ;
2018-01-11 14:15:51 +03:00
u8 nonce [ 4 ] ;
2016-11-29 16:30:43 +03:00
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 10:03:05 +03:00
struct hmac_ctx {
2016-11-29 16:30:41 +03: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 10:03:05 +03: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 16:30:43 +03: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 10:03:05 +03:00
} ;
struct chcr_context {
struct chcr_dev * dev ;
2017-04-10 15:54:00 +03:00
unsigned char tx_qidx ;
unsigned char rx_qidx ;
2018-09-19 20:12:16 +03:00
unsigned char tx_chan_id ;
unsigned char pci_chan_id ;
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 10:03:05 +03:00
struct __crypto_ctx crypto_ctx [ 0 ] ;
} ;
2018-03-06 08:07:52 +03:00
struct chcr_hctx_per_wr {
struct scatterlist * srcsg ;
struct sk_buff * skb ;
dma_addr_t dma_addr ;
u32 dma_len ;
unsigned int src_ofst ;
unsigned int processed ;
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 10:03:05 +03:00
u32 result ;
2018-03-06 08:07:52 +03:00
u8 is_sg_map ;
u8 imm ;
/*Final callback called. Driver cannot rely on nbytes to decide
* final call
*/
u8 isfinal ;
} ;
struct chcr_ahash_req_ctx {
struct chcr_hctx_per_wr hctx_wr ;
2016-11-29 16:30:38 +03:00
u8 * reqbfr ;
u8 * skbfr ;
2018-03-06 08:07:52 +03:00
/* SKB which is being sent to the hardware for processing */
u64 data_len ; /* Data len till time */
2016-11-29 16:30:38 +03:00
u8 reqlen ;
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 10:03:05 +03:00
u8 partial_hash [ CHCR_HASH_MAX_DIGEST_SIZE ] ;
2018-03-06 08:07:52 +03:00
u8 bfr1 [ CHCR_HASH_MAX_BLOCK_SIZE_128 ] ;
u8 bfr2 [ CHCR_HASH_MAX_BLOCK_SIZE_128 ] ;
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 10:03:05 +03:00
} ;
struct chcr_blkcipher_req_ctx {
struct sk_buff * skb ;
2017-06-15 10:13:43 +03:00
struct scatterlist * dstsg ;
unsigned int processed ;
2017-10-08 11:07:21 +03:00
unsigned int last_req_len ;
2017-10-08 11:07:23 +03:00
struct scatterlist * srcsg ;
unsigned int src_ofst ;
unsigned int dst_ofst ;
2017-06-15 10:13:43 +03:00
unsigned int op ;
2017-10-08 11:07:23 +03:00
u16 imm ;
2016-11-29 16:30:42 +03: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 10:03:05 +03:00
} ;
struct chcr_alg_template {
u32 type ;
u32 is_registered ;
union {
struct crypto_alg crypto ;
struct ahash_alg hash ;
2016-11-29 16:30:43 +03: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 10:03:05 +03:00
} alg ;
} ;
2016-11-29 16:30:43 +03: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 10:03:05 +03:00
unsigned short qid ,
2018-05-24 14:56:39 +03: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 10:03:05 +03:00
2017-11-16 14:27:08 +03:00
void chcr_verify_tag ( struct aead_request * req , u8 * input , int * err ) ;
int chcr_aead_dma_map ( struct device * dev , struct aead_request * req ,
unsigned short op_type ) ;
void chcr_aead_dma_unmap ( struct device * dev , struct aead_request * req ,
unsigned short op_type ) ;
void chcr_add_aead_dst_ent ( struct aead_request * req ,
struct cpl_rx_phys_dsgl * phys_cpl ,
unsigned short qid ) ;
2018-12-11 13:51:37 +03:00
void chcr_add_aead_src_ent ( struct aead_request * req , struct ulptx_sgl * ulptx ) ;
2017-11-16 14:27:08 +03:00
void chcr_add_cipher_src_ent ( struct ablkcipher_request * req ,
2018-05-24 14:56:38 +03:00
void * ulptx ,
2017-11-16 14:27:08 +03:00
struct cipher_wr_param * wrparam ) ;
int chcr_cipher_dma_map ( struct device * dev , struct ablkcipher_request * req ) ;
void chcr_cipher_dma_unmap ( struct device * dev , struct ablkcipher_request * req ) ;
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 ) ;
2017-10-08 11:07:23 +03:00
int sg_nents_len_skip ( struct scatterlist * sg , u64 len , u64 skip ) ;
2017-11-16 14:27:08 +03:00
void chcr_add_hash_src_ent ( struct ahash_request * req , struct ulptx_sgl * ulptx ,
struct hash_wr_param * param ) ;
int chcr_hash_dma_map ( struct device * dev , struct ahash_request * req ) ;
void chcr_hash_dma_unmap ( struct device * dev , struct ahash_request * req ) ;
2018-05-24 14:56:39 +03:00
void chcr_aead_common_exit ( 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 10:03:05 +03:00
# endif /* __CHCR_CRYPTO_H__ */