mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 15:29:16 +00:00
Merge branch 'cxgb4-chcr-ktls-tx-ofld-support-on-T6-adapter'
Rohit Maheshwari says: ==================== cxgb4/chcr: ktls tx ofld support on T6 adapter This series of patches add support for kernel tls offload in Tx direction, over Chelsio T6 NICs. SKBs marked as decrypted will be treated as tls plain text packets and then offloaded to encrypt using network device (chelsio T6 adapter). This series is broken down as follows: Patch 1 defines a new macro and registers tls_dev_add and tls_dev_del callbacks. When tls_dev_add gets called we send a connection request to our hardware and to make HW understand about tls offload. Its a partial connection setup and only ipv4 part is done. Patch 2 handles the HW response of the connection request and then we request to update TCB and handle it's HW response as well. Also we save crypto key locally. Only supporting TLS_CIPHER_AES_GCM_128_KEY_SIZE. Patch 3 handles tls marked skbs (decrypted bit set) and sends it to ULD for crypto handling. This code has a minimal portion of tx handler, to handle only one complete record per skb. Patch 4 hanldes partial end part of records. Also added logic to handle multiple records in one single skb. It also adds support to send out tcp option(/s) if exists in skb. If a record is partial but has end part of a record, we'll fetch complete record and then only send it to HW to generate HASH on complete record. Patch 5 handles partial first or middle part of record, it uses AES_CTR to encrypt the partial record. If we are trying to send middle record, it's start should be 16 byte aligned, so we'll fetch few earlier bytes from the record and then send it to HW for encryption. Patch 6 enables ipv6 support and also includes ktls startistics. v1->v2: - mark tcb state to close in tls_dev_del. - u_ctx is now picked from adapter structure. - clear atid in case of failure. - corrected ULP_CRYPTO_KTLS_INLINE value. - optimized tcb update using control queue. - state machine handling when earlier states received. - chcr_write_cpl_set_tcb_ulp function is shifted to patch3. - un-necessary updating left variable. v2->v3: - add empty line after variable declaration. - local variable declaration in reverse christmas tree ordering. v3->v4: - replaced kfree_skb with dev_kfree_skb_any. - corrected error message reported by kbuild test robot <lkp@intel.com> - mss calculation logic. - correct place for Alloc skb check. - Replaced atomic_t with atomic64_t - added few more statistics counters. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
31de3f562f
@ -42,3 +42,14 @@ config CRYPTO_DEV_CHELSIO_TLS
|
||||
|
||||
To compile this driver as a module, choose M here: the module
|
||||
will be called chtls.
|
||||
|
||||
config CHELSIO_TLS_DEVICE
|
||||
bool "Chelsio Inline KTLS Offload"
|
||||
depends on CHELSIO_T4
|
||||
depends on TLS_DEVICE
|
||||
select CRYPTO_DEV_CHELSIO
|
||||
default y
|
||||
help
|
||||
This flag enables support for kernel tls offload over Chelsio T6
|
||||
crypto accelerator. CONFIG_CHELSIO_TLS_DEVICE flag can be enabled
|
||||
only if CONFIG_TLS and CONFIG_TLS_DEVICE flags are enabled.
|
||||
|
@ -3,5 +3,8 @@ ccflags-y := -I $(srctree)/drivers/net/ethernet/chelsio/cxgb4
|
||||
|
||||
obj-$(CONFIG_CRYPTO_DEV_CHELSIO) += chcr.o
|
||||
chcr-objs := chcr_core.o chcr_algo.o
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
chcr-objs += chcr_ktls.o
|
||||
#endif
|
||||
chcr-$(CONFIG_CHELSIO_IPSEC_INLINE) += chcr_ipsec.o
|
||||
obj-$(CONFIG_CRYPTO_DEV_CHELSIO_TLS) += chtls/
|
||||
|
135
drivers/crypto/chelsio/chcr_common.h
Normal file
135
drivers/crypto/chelsio/chcr_common.h
Normal file
@ -0,0 +1,135 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/* Copyright (C) 2020 Chelsio Communications. All rights reserved. */
|
||||
|
||||
#ifndef __CHCR_COMMON_H__
|
||||
#define __CHCR_COMMON_H__
|
||||
|
||||
#include "cxgb4.h"
|
||||
|
||||
#define CHCR_MAX_SALT 4
|
||||
#define CHCR_KEYCTX_MAC_KEY_SIZE_128 0
|
||||
#define CHCR_KEYCTX_CIPHER_KEY_SIZE_128 0
|
||||
#define CHCR_SCMD_CIPHER_MODE_AES_GCM 2
|
||||
#define CHCR_SCMD_CIPHER_MODE_AES_CTR 3
|
||||
#define CHCR_CPL_TX_SEC_PDU_LEN_64BIT 2
|
||||
#define CHCR_SCMD_SEQ_NO_CTRL_64BIT 3
|
||||
#define CHCR_SCMD_PROTO_VERSION_TLS 0
|
||||
#define CHCR_SCMD_PROTO_VERSION_GENERIC 4
|
||||
#define CHCR_SCMD_AUTH_MODE_GHASH 4
|
||||
#define AES_BLOCK_LEN 16
|
||||
|
||||
enum chcr_state {
|
||||
CHCR_INIT = 0,
|
||||
CHCR_ATTACH,
|
||||
CHCR_DETACH,
|
||||
};
|
||||
|
||||
struct chcr_dev {
|
||||
spinlock_t lock_chcr_dev; /* chcr dev structure lock */
|
||||
enum chcr_state state;
|
||||
atomic_t inflight;
|
||||
int wqretry;
|
||||
struct delayed_work detach_work;
|
||||
struct completion detach_comp;
|
||||
unsigned char tx_channel_id;
|
||||
};
|
||||
|
||||
struct uld_ctx {
|
||||
struct list_head entry;
|
||||
struct cxgb4_lld_info lldi;
|
||||
struct chcr_dev dev;
|
||||
};
|
||||
|
||||
struct ktls_key_ctx {
|
||||
__be32 ctx_hdr;
|
||||
u8 salt[CHCR_MAX_SALT];
|
||||
__be64 iv_to_auth;
|
||||
unsigned char key[TLS_CIPHER_AES_GCM_128_KEY_SIZE +
|
||||
TLS_CIPHER_AES_GCM_256_TAG_SIZE];
|
||||
};
|
||||
|
||||
/* Crypto key context */
|
||||
#define KEY_CONTEXT_CTX_LEN_S 24
|
||||
#define KEY_CONTEXT_CTX_LEN_V(x) ((x) << KEY_CONTEXT_CTX_LEN_S)
|
||||
|
||||
#define KEY_CONTEXT_SALT_PRESENT_S 10
|
||||
#define KEY_CONTEXT_SALT_PRESENT_V(x) ((x) << KEY_CONTEXT_SALT_PRESENT_S)
|
||||
#define KEY_CONTEXT_SALT_PRESENT_F KEY_CONTEXT_SALT_PRESENT_V(1U)
|
||||
|
||||
#define KEY_CONTEXT_VALID_S 0
|
||||
#define KEY_CONTEXT_VALID_V(x) ((x) << KEY_CONTEXT_VALID_S)
|
||||
#define KEY_CONTEXT_VALID_F KEY_CONTEXT_VALID_V(1U)
|
||||
|
||||
#define KEY_CONTEXT_CK_SIZE_S 6
|
||||
#define KEY_CONTEXT_CK_SIZE_V(x) ((x) << KEY_CONTEXT_CK_SIZE_S)
|
||||
|
||||
#define KEY_CONTEXT_MK_SIZE_S 2
|
||||
#define KEY_CONTEXT_MK_SIZE_V(x) ((x) << KEY_CONTEXT_MK_SIZE_S)
|
||||
|
||||
#define KEY_CONTEXT_OPAD_PRESENT_S 11
|
||||
#define KEY_CONTEXT_OPAD_PRESENT_V(x) ((x) << KEY_CONTEXT_OPAD_PRESENT_S)
|
||||
#define KEY_CONTEXT_OPAD_PRESENT_F KEY_CONTEXT_OPAD_PRESENT_V(1U)
|
||||
|
||||
#define FILL_KEY_CTX_HDR(ck_size, mk_size, ctx_len) \
|
||||
htonl(KEY_CONTEXT_MK_SIZE_V(mk_size) | \
|
||||
KEY_CONTEXT_CK_SIZE_V(ck_size) | \
|
||||
KEY_CONTEXT_VALID_F | \
|
||||
KEY_CONTEXT_SALT_PRESENT_F | \
|
||||
KEY_CONTEXT_CTX_LEN_V((ctx_len)))
|
||||
|
||||
struct uld_ctx *assign_chcr_device(void);
|
||||
|
||||
static inline void *chcr_copy_to_txd(const void *src, const struct sge_txq *q,
|
||||
void *pos, int length)
|
||||
{
|
||||
int left = (void *)q->stat - pos;
|
||||
u64 *p;
|
||||
|
||||
if (likely(length <= left)) {
|
||||
memcpy(pos, src, length);
|
||||
pos += length;
|
||||
} else {
|
||||
memcpy(pos, src, left);
|
||||
memcpy(q->desc, src + left, length - left);
|
||||
pos = (void *)q->desc + (length - left);
|
||||
}
|
||||
/* 0-pad to multiple of 16 */
|
||||
p = PTR_ALIGN(pos, 8);
|
||||
if ((uintptr_t)p & 8) {
|
||||
*p = 0;
|
||||
return p + 1;
|
||||
}
|
||||
return p;
|
||||
}
|
||||
|
||||
static inline unsigned int chcr_txq_avail(const struct sge_txq *q)
|
||||
{
|
||||
return q->size - 1 - q->in_use;
|
||||
}
|
||||
|
||||
static inline void chcr_txq_advance(struct sge_txq *q, unsigned int n)
|
||||
{
|
||||
q->in_use += n;
|
||||
q->pidx += n;
|
||||
if (q->pidx >= q->size)
|
||||
q->pidx -= q->size;
|
||||
}
|
||||
|
||||
static inline void chcr_eth_txq_stop(struct sge_eth_txq *q)
|
||||
{
|
||||
netif_tx_stop_queue(q->txq);
|
||||
q->q.stops++;
|
||||
}
|
||||
|
||||
static inline unsigned int chcr_sgl_len(unsigned int n)
|
||||
{
|
||||
n--;
|
||||
return (3 * n) / 2 + (n & 1) + 2;
|
||||
}
|
||||
|
||||
static inline unsigned int chcr_flits_to_desc(unsigned int n)
|
||||
{
|
||||
WARN_ON(n > SGE_MAX_WR_LEN / 8);
|
||||
return DIV_ROUND_UP(n, 8);
|
||||
}
|
||||
#endif /* __CHCR_COMMON_H__ */
|
@ -28,13 +28,17 @@
|
||||
|
||||
static struct chcr_driver_data drv_data;
|
||||
|
||||
typedef int (*chcr_handler_func)(struct chcr_dev *dev, unsigned char *input);
|
||||
static int cpl_fw6_pld_handler(struct chcr_dev *dev, unsigned char *input);
|
||||
typedef int (*chcr_handler_func)(struct adapter *adap, unsigned char *input);
|
||||
static int cpl_fw6_pld_handler(struct adapter *adap, unsigned char *input);
|
||||
static void *chcr_uld_add(const struct cxgb4_lld_info *lld);
|
||||
static int chcr_uld_state_change(void *handle, enum cxgb4_state state);
|
||||
|
||||
static chcr_handler_func work_handlers[NUM_CPL_CMDS] = {
|
||||
[CPL_FW6_PLD] = cpl_fw6_pld_handler,
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
[CPL_ACT_OPEN_RPL] = chcr_ktls_cpl_act_open_rpl,
|
||||
[CPL_SET_TCB_RPL] = chcr_ktls_cpl_set_tcb_rpl,
|
||||
#endif
|
||||
};
|
||||
|
||||
static struct cxgb4_uld_info chcr_uld_info = {
|
||||
@ -45,9 +49,9 @@ static struct cxgb4_uld_info chcr_uld_info = {
|
||||
.add = chcr_uld_add,
|
||||
.state_change = chcr_uld_state_change,
|
||||
.rx_handler = chcr_uld_rx_handler,
|
||||
#ifdef CONFIG_CHELSIO_IPSEC_INLINE
|
||||
#if defined(CONFIG_CHELSIO_IPSEC_INLINE) || defined(CONFIG_CHELSIO_TLS_DEVICE)
|
||||
.tx_handler = chcr_uld_tx_handler,
|
||||
#endif /* CONFIG_CHELSIO_IPSEC_INLINE */
|
||||
#endif /* CONFIG_CHELSIO_IPSEC_INLINE || CONFIG_CHELSIO_TLS_DEVICE */
|
||||
};
|
||||
|
||||
static void detach_work_fn(struct work_struct *work)
|
||||
@ -150,14 +154,13 @@ static int chcr_dev_move(struct uld_ctx *u_ctx)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int cpl_fw6_pld_handler(struct chcr_dev *dev,
|
||||
static int cpl_fw6_pld_handler(struct adapter *adap,
|
||||
unsigned char *input)
|
||||
{
|
||||
struct crypto_async_request *req;
|
||||
struct cpl_fw6_pld *fw6_pld;
|
||||
u32 ack_err_status = 0;
|
||||
int error_status = 0;
|
||||
struct adapter *adap = padap(dev);
|
||||
|
||||
fw6_pld = (struct cpl_fw6_pld *)input;
|
||||
req = (struct crypto_async_request *)(uintptr_t)be64_to_cpu(
|
||||
@ -205,6 +208,11 @@ static void *chcr_uld_add(const struct cxgb4_lld_info *lld)
|
||||
if (lld->crypto & ULP_CRYPTO_IPSEC_INLINE)
|
||||
chcr_add_xfrmops(lld);
|
||||
#endif /* CONFIG_CHELSIO_IPSEC_INLINE */
|
||||
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
if (lld->ulp_crypto & ULP_CRYPTO_KTLS_INLINE)
|
||||
chcr_enable_ktls(padap(&u_ctx->dev));
|
||||
#endif
|
||||
out:
|
||||
return u_ctx;
|
||||
}
|
||||
@ -214,26 +222,37 @@ int chcr_uld_rx_handler(void *handle, const __be64 *rsp,
|
||||
{
|
||||
struct uld_ctx *u_ctx = (struct uld_ctx *)handle;
|
||||
struct chcr_dev *dev = &u_ctx->dev;
|
||||
struct adapter *adap = padap(dev);
|
||||
const struct cpl_fw6_pld *rpl = (struct cpl_fw6_pld *)rsp;
|
||||
|
||||
if (rpl->opcode != CPL_FW6_PLD) {
|
||||
pr_err("Unsupported opcode\n");
|
||||
if (!work_handlers[rpl->opcode]) {
|
||||
pr_err("Unsupported opcode %d received\n", rpl->opcode);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (!pgl)
|
||||
work_handlers[rpl->opcode](dev, (unsigned char *)&rsp[1]);
|
||||
work_handlers[rpl->opcode](adap, (unsigned char *)&rsp[1]);
|
||||
else
|
||||
work_handlers[rpl->opcode](dev, pgl->va);
|
||||
work_handlers[rpl->opcode](adap, pgl->va);
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_CHELSIO_IPSEC_INLINE
|
||||
#if defined(CONFIG_CHELSIO_IPSEC_INLINE) || defined(CONFIG_CHELSIO_TLS_DEVICE)
|
||||
int chcr_uld_tx_handler(struct sk_buff *skb, struct net_device *dev)
|
||||
{
|
||||
/* In case if skb's decrypted bit is set, it's nic tls packet, else it's
|
||||
* ipsec packet.
|
||||
*/
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
if (skb->decrypted)
|
||||
return chcr_ktls_xmit(skb, dev);
|
||||
#endif
|
||||
#ifdef CONFIG_CHELSIO_IPSEC_INLINE
|
||||
return chcr_ipsec_xmit(skb, dev);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
#endif /* CONFIG_CHELSIO_IPSEC_INLINE */
|
||||
#endif /* CONFIG_CHELSIO_IPSEC_INLINE || CONFIG_CHELSIO_TLS_DEVICE */
|
||||
|
||||
static void chcr_detach_device(struct uld_ctx *u_ctx)
|
||||
{
|
||||
@ -304,12 +323,20 @@ static void __exit chcr_crypto_exit(void)
|
||||
list_for_each_entry_safe(u_ctx, tmp, &drv_data.act_dev, entry) {
|
||||
adap = padap(&u_ctx->dev);
|
||||
memset(&adap->chcr_stats, 0, sizeof(adap->chcr_stats));
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
if (u_ctx->lldi.ulp_crypto & ULP_CRYPTO_KTLS_INLINE)
|
||||
chcr_disable_ktls(adap);
|
||||
#endif
|
||||
list_del(&u_ctx->entry);
|
||||
kfree(u_ctx);
|
||||
}
|
||||
list_for_each_entry_safe(u_ctx, tmp, &drv_data.inact_dev, entry) {
|
||||
adap = padap(&u_ctx->dev);
|
||||
memset(&adap->chcr_stats, 0, sizeof(adap->chcr_stats));
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
if (u_ctx->lldi.ulp_crypto & ULP_CRYPTO_KTLS_INLINE)
|
||||
chcr_disable_ktls(adap);
|
||||
#endif
|
||||
list_del(&u_ctx->entry);
|
||||
kfree(u_ctx);
|
||||
}
|
||||
|
@ -222,4 +222,11 @@ int chcr_handle_resp(struct crypto_async_request *req, unsigned char *input,
|
||||
int err);
|
||||
int chcr_ipsec_xmit(struct sk_buff *skb, struct net_device *dev);
|
||||
void chcr_add_xfrmops(const struct cxgb4_lld_info *lld);
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
void chcr_enable_ktls(struct adapter *adap);
|
||||
void chcr_disable_ktls(struct adapter *adap);
|
||||
int chcr_ktls_cpl_act_open_rpl(struct adapter *adap, unsigned char *input);
|
||||
int chcr_ktls_cpl_set_tcb_rpl(struct adapter *adap, unsigned char *input);
|
||||
int chcr_ktls_xmit(struct sk_buff *skb, struct net_device *dev);
|
||||
#endif
|
||||
#endif /* __CHCR_CORE_H__ */
|
||||
|
2021
drivers/crypto/chelsio/chcr_ktls.c
Normal file
2021
drivers/crypto/chelsio/chcr_ktls.c
Normal file
File diff suppressed because it is too large
Load Diff
98
drivers/crypto/chelsio/chcr_ktls.h
Normal file
98
drivers/crypto/chelsio/chcr_ktls.h
Normal file
@ -0,0 +1,98 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/* Copyright (C) 2020 Chelsio Communications. All rights reserved. */
|
||||
|
||||
#ifndef __CHCR_KTLS_H__
|
||||
#define __CHCR_KTLS_H__
|
||||
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
#include <net/tls.h>
|
||||
#include "cxgb4.h"
|
||||
#include "t4_msg.h"
|
||||
#include "t4_tcb.h"
|
||||
#include "l2t.h"
|
||||
#include "chcr_common.h"
|
||||
#include "cxgb4_uld.h"
|
||||
|
||||
#define CHCR_TCB_STATE_CLOSED 0
|
||||
#define CHCR_KTLS_KEY_CTX_LEN 16
|
||||
#define CHCR_SET_TCB_FIELD_LEN sizeof(struct cpl_set_tcb_field)
|
||||
#define CHCR_PLAIN_TX_DATA_LEN (sizeof(struct fw_ulptx_wr) +\
|
||||
sizeof(struct ulp_txpkt) +\
|
||||
sizeof(struct ulptx_idata) +\
|
||||
sizeof(struct cpl_tx_data))
|
||||
|
||||
#define CHCR_KTLS_WR_SIZE (CHCR_PLAIN_TX_DATA_LEN +\
|
||||
sizeof(struct cpl_tx_sec_pdu))
|
||||
|
||||
enum chcr_ktls_conn_state {
|
||||
KTLS_CONN_CLOSED,
|
||||
KTLS_CONN_ACT_OPEN_REQ,
|
||||
KTLS_CONN_ACT_OPEN_RPL,
|
||||
KTLS_CONN_SET_TCB_REQ,
|
||||
KTLS_CONN_SET_TCB_RPL,
|
||||
KTLS_CONN_TX_READY,
|
||||
};
|
||||
|
||||
struct chcr_ktls_info {
|
||||
struct sock *sk;
|
||||
spinlock_t lock; /* state machine lock */
|
||||
struct ktls_key_ctx key_ctx;
|
||||
struct adapter *adap;
|
||||
struct l2t_entry *l2te;
|
||||
struct net_device *netdev;
|
||||
u64 iv;
|
||||
u64 record_no;
|
||||
int tid;
|
||||
int atid;
|
||||
int rx_qid;
|
||||
u32 iv_size;
|
||||
u32 prev_seq;
|
||||
u32 prev_ack;
|
||||
u32 salt_size;
|
||||
u32 key_ctx_len;
|
||||
u32 scmd0_seqno_numivs;
|
||||
u32 scmd0_ivgen_hdrlen;
|
||||
u32 tcp_start_seq_number;
|
||||
u32 scmd0_short_seqno_numivs;
|
||||
u32 scmd0_short_ivgen_hdrlen;
|
||||
enum chcr_ktls_conn_state connection_state;
|
||||
u16 prev_win;
|
||||
u8 tx_chan;
|
||||
u8 smt_idx;
|
||||
u8 port_id;
|
||||
u8 ip_family;
|
||||
u8 first_qset;
|
||||
};
|
||||
|
||||
struct chcr_ktls_ofld_ctx_tx {
|
||||
struct tls_offload_context_tx base;
|
||||
struct chcr_ktls_info *chcr_info;
|
||||
};
|
||||
|
||||
static inline struct chcr_ktls_ofld_ctx_tx *
|
||||
chcr_get_ktls_tx_context(struct tls_context *tls_ctx)
|
||||
{
|
||||
BUILD_BUG_ON(sizeof(struct chcr_ktls_ofld_ctx_tx) >
|
||||
TLS_OFFLOAD_CONTEXT_SIZE_TX);
|
||||
return container_of(tls_offload_ctx_tx(tls_ctx),
|
||||
struct chcr_ktls_ofld_ctx_tx,
|
||||
base);
|
||||
}
|
||||
|
||||
static inline int chcr_get_first_rx_qid(struct adapter *adap)
|
||||
{
|
||||
/* u_ctx is saved in adap, fetch it */
|
||||
struct uld_ctx *u_ctx = adap->uld[CXGB4_ULD_CRYPTO].handle;
|
||||
|
||||
if (!u_ctx)
|
||||
return -1;
|
||||
return u_ctx->lldi.rxq_ids[0];
|
||||
}
|
||||
|
||||
void chcr_enable_ktls(struct adapter *adap);
|
||||
void chcr_disable_ktls(struct adapter *adap);
|
||||
int chcr_ktls_cpl_act_open_rpl(struct adapter *adap, unsigned char *input);
|
||||
int chcr_ktls_cpl_set_tcb_rpl(struct adapter *adap, unsigned char *input);
|
||||
int chcr_ktls_xmit(struct sk_buff *skb, struct net_device *dev);
|
||||
#endif /* CONFIG_CHELSIO_TLS_DEVICE */
|
||||
#endif /* __CHCR_KTLS_H__ */
|
@ -640,6 +640,7 @@ enum { /* adapter flags */
|
||||
enum {
|
||||
ULP_CRYPTO_LOOKASIDE = 1 << 0,
|
||||
ULP_CRYPTO_IPSEC_INLINE = 1 << 1,
|
||||
ULP_CRYPTO_KTLS_INLINE = 1 << 3,
|
||||
};
|
||||
|
||||
struct rx_sw_desc;
|
||||
|
@ -3409,6 +3409,41 @@ static int chcr_stats_show(struct seq_file *seq, void *v)
|
||||
atomic_read(&adap->chcr_stats.tls_pdu_rx));
|
||||
seq_printf(seq, "TLS Keys (DDR) Count: %10u\n",
|
||||
atomic_read(&adap->chcr_stats.tls_key));
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
seq_puts(seq, "\nChelsio KTLS Crypto Accelerator Stats\n");
|
||||
seq_printf(seq, "Tx HW offload contexts added: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_ctx));
|
||||
seq_printf(seq, "Tx connection created: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_connection_open));
|
||||
seq_printf(seq, "Tx connection failed: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_connection_fail));
|
||||
seq_printf(seq, "Tx connection closed: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_connection_close));
|
||||
seq_printf(seq, "Packets passed for encryption : %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_encrypted_packets));
|
||||
seq_printf(seq, "Bytes passed for encryption : %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_encrypted_bytes));
|
||||
seq_printf(seq, "Tx records send: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_send_records));
|
||||
seq_printf(seq, "Tx partial start of records: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_start_pkts));
|
||||
seq_printf(seq, "Tx partial middle of records: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_middle_pkts));
|
||||
seq_printf(seq, "Tx partial end of record: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_end_pkts));
|
||||
seq_printf(seq, "Tx complete records: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_complete_pkts));
|
||||
seq_printf(seq, "TX trim pkts : %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_trimmed_pkts));
|
||||
seq_printf(seq, "Tx out of order packets: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_ooo));
|
||||
seq_printf(seq, "Tx drop pkts before HW offload: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_skip_no_sync_data));
|
||||
seq_printf(seq, "Tx drop not synced packets: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_drop_no_sync_data));
|
||||
seq_printf(seq, "Tx drop bypass req: %20llu\n",
|
||||
atomic64_read(&adap->chcr_stats.ktls_tx_drop_bypass_req));
|
||||
#endif
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -662,6 +662,25 @@ static int uld_attach(struct adapter *adap, unsigned int uld)
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
/* cxgb4_set_ktls_feature: request FW to enable/disable ktls settings.
|
||||
* @adap: adapter info
|
||||
* @enable: 1 to enable / 0 to disable ktls settings.
|
||||
*/
|
||||
static void cxgb4_set_ktls_feature(struct adapter *adap, bool enable)
|
||||
{
|
||||
u32 params = (FW_PARAMS_MNEM_V(FW_PARAMS_MNEM_DEV) |
|
||||
FW_PARAMS_PARAM_X_V(FW_PARAMS_PARAM_DEV_KTLS_TX_HW) |
|
||||
FW_PARAMS_PARAM_Y_V(enable));
|
||||
int ret = 0;
|
||||
|
||||
ret = t4_set_params(adap, adap->mbox, adap->pf, 0, 1, ¶ms, ¶ms);
|
||||
/* if fw returns failure, clear the ktls flag */
|
||||
if (ret)
|
||||
adap->params.crypto &= ~ULP_CRYPTO_KTLS_INLINE;
|
||||
}
|
||||
#endif
|
||||
|
||||
/* cxgb4_register_uld - register an upper-layer driver
|
||||
* @type: the ULD type
|
||||
* @p: the ULD methods
|
||||
@ -698,6 +717,12 @@ void cxgb4_register_uld(enum cxgb4_uld type,
|
||||
}
|
||||
if (adap->flags & CXGB4_FULL_INIT_DONE)
|
||||
enable_rx_uld(adap, type);
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
/* send mbox to enable ktls related settings. */
|
||||
if (type == CXGB4_ULD_CRYPTO &&
|
||||
(adap->params.crypto & FW_CAPS_CONFIG_TX_TLS_HW))
|
||||
cxgb4_set_ktls_feature(adap, 1);
|
||||
#endif
|
||||
if (adap->uld[type].add)
|
||||
goto free_irq;
|
||||
ret = setup_sge_txq_uld(adap, type, p);
|
||||
@ -750,6 +775,13 @@ int cxgb4_unregister_uld(enum cxgb4_uld type)
|
||||
continue;
|
||||
|
||||
cxgb4_shutdown_uld_adapter(adap, type);
|
||||
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
/* send mbox to disable ktls related settings. */
|
||||
if (type == CXGB4_ULD_CRYPTO &&
|
||||
(adap->params.crypto & FW_CAPS_CONFIG_TX_TLS_HW))
|
||||
cxgb4_set_ktls_feature(adap, 0);
|
||||
#endif
|
||||
}
|
||||
mutex_unlock(&uld_mutex);
|
||||
|
||||
|
@ -357,6 +357,26 @@ struct chcr_stats_debug {
|
||||
atomic_t tls_pdu_tx;
|
||||
atomic_t tls_pdu_rx;
|
||||
atomic_t tls_key;
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
atomic64_t ktls_tx_connection_open;
|
||||
atomic64_t ktls_tx_connection_fail;
|
||||
atomic64_t ktls_tx_connection_close;
|
||||
atomic64_t ktls_tx_send_records;
|
||||
atomic64_t ktls_tx_end_pkts;
|
||||
atomic64_t ktls_tx_start_pkts;
|
||||
atomic64_t ktls_tx_middle_pkts;
|
||||
atomic64_t ktls_tx_retransmit_pkts;
|
||||
atomic64_t ktls_tx_complete_pkts;
|
||||
atomic64_t ktls_tx_trimmed_pkts;
|
||||
atomic64_t ktls_tx_encrypted_packets;
|
||||
atomic64_t ktls_tx_encrypted_bytes;
|
||||
atomic64_t ktls_tx_ctx;
|
||||
atomic64_t ktls_tx_ooo;
|
||||
atomic64_t ktls_tx_skip_no_sync_data;
|
||||
atomic64_t ktls_tx_drop_no_sync_data;
|
||||
atomic64_t ktls_tx_drop_bypass_req;
|
||||
|
||||
#endif
|
||||
};
|
||||
|
||||
#define OCQ_WIN_OFFSET(pdev, vres) \
|
||||
|
@ -700,6 +700,17 @@ static char l2e_state(const struct l2t_entry *e)
|
||||
}
|
||||
}
|
||||
|
||||
bool cxgb4_check_l2t_valid(struct l2t_entry *e)
|
||||
{
|
||||
bool valid;
|
||||
|
||||
spin_lock(&e->lock);
|
||||
valid = (e->state == L2T_STATE_VALID);
|
||||
spin_unlock(&e->lock);
|
||||
return valid;
|
||||
}
|
||||
EXPORT_SYMBOL(cxgb4_check_l2t_valid);
|
||||
|
||||
static int l2t_seq_show(struct seq_file *seq, void *v)
|
||||
{
|
||||
if (v == SEQ_START_TOKEN)
|
||||
|
@ -122,6 +122,7 @@ struct l2t_entry *t4_l2t_alloc_switching(struct adapter *adap, u16 vlan,
|
||||
u8 port, u8 *dmac);
|
||||
struct l2t_data *t4_init_l2t(unsigned int l2t_start, unsigned int l2t_end);
|
||||
void do_l2t_write_rpl(struct adapter *p, const struct cpl_l2t_write_rpl *rpl);
|
||||
bool cxgb4_check_l2t_valid(struct l2t_entry *e);
|
||||
|
||||
extern const struct file_operations t4_l2t_fops;
|
||||
#endif /* __CXGB4_L2T_H */
|
||||
|
@ -1412,6 +1412,11 @@ static netdev_tx_t cxgb4_eth_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
return adap->uld[CXGB4_ULD_CRYPTO].tx_handler(skb, dev);
|
||||
#endif /* CHELSIO_IPSEC_INLINE */
|
||||
|
||||
#ifdef CONFIG_CHELSIO_TLS_DEVICE
|
||||
if (skb->decrypted)
|
||||
return adap->uld[CXGB4_ULD_CRYPTO].tx_handler(skb, dev);
|
||||
#endif /* CHELSIO_TLS_DEVICE */
|
||||
|
||||
qidx = skb_get_queue_mapping(skb);
|
||||
if (ptp_enabled) {
|
||||
spin_lock(&adap->ptp_lock);
|
||||
|
@ -47,6 +47,7 @@ enum {
|
||||
CPL_CLOSE_LISTSRV_REQ = 0x9,
|
||||
CPL_ABORT_REQ = 0xA,
|
||||
CPL_ABORT_RPL = 0xB,
|
||||
CPL_TX_DATA = 0xC,
|
||||
CPL_RX_DATA_ACK = 0xD,
|
||||
CPL_TX_PKT = 0xE,
|
||||
CPL_L2T_WRITE_REQ = 0x12,
|
||||
@ -705,6 +706,14 @@ struct cpl_set_tcb_field {
|
||||
__be64 val;
|
||||
};
|
||||
|
||||
struct cpl_set_tcb_field_core {
|
||||
union opcode_tid ot;
|
||||
__be16 reply_ctrl;
|
||||
__be16 word_cookie;
|
||||
__be64 mask;
|
||||
__be64 val;
|
||||
};
|
||||
|
||||
/* cpl_set_tcb_field.word_cookie fields */
|
||||
#define TCB_WORD_S 0
|
||||
#define TCB_WORD_V(x) ((x) << TCB_WORD_S)
|
||||
@ -1462,6 +1471,16 @@ struct cpl_tx_data {
|
||||
#define TX_FORCE_S 13
|
||||
#define TX_FORCE_V(x) ((x) << TX_FORCE_S)
|
||||
|
||||
#define TX_DATA_MSS_S 16
|
||||
#define TX_DATA_MSS_M 0xFFFF
|
||||
#define TX_DATA_MSS_V(x) ((x) << TX_DATA_MSS_S)
|
||||
#define TX_DATA_MSS_G(x) (((x) >> TX_DATA_MSS_S) & TX_DATA_MSS_M)
|
||||
|
||||
#define TX_LENGTH_S 0
|
||||
#define TX_LENGTH_M 0xFFFF
|
||||
#define TX_LENGTH_V(x) ((x) << TX_LENGTH_S)
|
||||
#define TX_LENGTH_G(x) (((x) >> TX_LENGTH_S) & TX_LENGTH_M)
|
||||
|
||||
#define T6_TX_FORCE_S 20
|
||||
#define T6_TX_FORCE_V(x) ((x) << T6_TX_FORCE_S)
|
||||
#define T6_TX_FORCE_F T6_TX_FORCE_V(1U)
|
||||
@ -1471,6 +1490,15 @@ struct cpl_tx_data {
|
||||
|
||||
#define TX_SHOVE_S 14
|
||||
#define TX_SHOVE_V(x) ((x) << TX_SHOVE_S)
|
||||
#define TX_SHOVE_F TX_SHOVE_V(1U)
|
||||
|
||||
#define TX_BYPASS_S 21
|
||||
#define TX_BYPASS_V(x) ((x) << TX_BYPASS_S)
|
||||
#define TX_BYPASS_F TX_BYPASS_V(1U)
|
||||
|
||||
#define TX_PUSH_S 22
|
||||
#define TX_PUSH_V(x) ((x) << TX_PUSH_S)
|
||||
#define TX_PUSH_F TX_PUSH_V(1U)
|
||||
|
||||
#define TX_ULP_MODE_S 10
|
||||
#define TX_ULP_MODE_M 0x7
|
||||
|
@ -35,6 +35,11 @@
|
||||
#ifndef __T4_TCB_H
|
||||
#define __T4_TCB_H
|
||||
|
||||
#define TCB_L2T_IX_W 0
|
||||
#define TCB_L2T_IX_S 12
|
||||
#define TCB_L2T_IX_M 0xfffULL
|
||||
#define TCB_L2T_IX_V(x) ((x) << TCB_L2T_IX_S)
|
||||
|
||||
#define TCB_SMAC_SEL_W 0
|
||||
#define TCB_SMAC_SEL_S 24
|
||||
#define TCB_SMAC_SEL_M 0xffULL
|
||||
@ -45,11 +50,6 @@
|
||||
#define TCB_T_FLAGS_M 0xffffffffffffffffULL
|
||||
#define TCB_T_FLAGS_V(x) ((__u64)(x) << TCB_T_FLAGS_S)
|
||||
|
||||
#define TCB_RQ_START_W 30
|
||||
#define TCB_RQ_START_S 0
|
||||
#define TCB_RQ_START_M 0x3ffffffULL
|
||||
#define TCB_RQ_START_V(x) ((x) << TCB_RQ_START_S)
|
||||
|
||||
#define TF_CCTRL_ECE_S 60
|
||||
#define TF_CCTRL_CWR_S 61
|
||||
#define TF_CCTRL_RFR_S 62
|
||||
@ -59,6 +59,11 @@
|
||||
#define TCB_RSS_INFO_M 0x3ffULL
|
||||
#define TCB_RSS_INFO_V(x) ((x) << TCB_RSS_INFO_S)
|
||||
|
||||
#define TCB_T_STATE_W 3
|
||||
#define TCB_T_STATE_S 16
|
||||
#define TCB_T_STATE_M 0xfULL
|
||||
#define TCB_T_STATE_V(x) ((x) << TCB_T_STATE_S)
|
||||
|
||||
#define TCB_TIMESTAMP_W 5
|
||||
#define TCB_TIMESTAMP_S 0
|
||||
#define TCB_TIMESTAMP_M 0xffffffffULL
|
||||
@ -69,13 +74,60 @@
|
||||
#define TCB_RTT_TS_RECENT_AGE_M 0xffffffffULL
|
||||
#define TCB_RTT_TS_RECENT_AGE_V(x) ((x) << TCB_RTT_TS_RECENT_AGE_S)
|
||||
|
||||
#define TCB_T_RTSEQ_RECENT_W 7
|
||||
#define TCB_T_RTSEQ_RECENT_S 0
|
||||
#define TCB_T_RTSEQ_RECENT_M 0xffffffffULL
|
||||
#define TCB_T_RTSEQ_RECENT_V(x) ((x) << TCB_T_RTSEQ_RECENT_S)
|
||||
|
||||
#define TCB_TX_MAX_W 9
|
||||
#define TCB_TX_MAX_S 0
|
||||
#define TCB_TX_MAX_M 0xffffffffULL
|
||||
#define TCB_TX_MAX_V(x) ((x) << TCB_TX_MAX_S)
|
||||
|
||||
#define TCB_SND_UNA_RAW_W 10
|
||||
#define TCB_SND_UNA_RAW_S 0
|
||||
#define TCB_SND_UNA_RAW_M 0xfffffffULL
|
||||
#define TCB_SND_UNA_RAW_V(x) ((x) << TCB_SND_UNA_RAW_S)
|
||||
|
||||
#define TCB_SND_NXT_RAW_W 10
|
||||
#define TCB_SND_NXT_RAW_S 28
|
||||
#define TCB_SND_NXT_RAW_M 0xfffffffULL
|
||||
#define TCB_SND_NXT_RAW_V(x) ((x) << TCB_SND_NXT_RAW_S)
|
||||
|
||||
#define TCB_SND_MAX_RAW_W 11
|
||||
#define TCB_SND_MAX_RAW_S 24
|
||||
#define TCB_SND_MAX_RAW_M 0xfffffffULL
|
||||
#define TCB_SND_MAX_RAW_V(x) ((x) << TCB_SND_MAX_RAW_S)
|
||||
|
||||
#define TCB_RCV_NXT_W 16
|
||||
#define TCB_RCV_NXT_S 10
|
||||
#define TCB_RCV_NXT_M 0xffffffffULL
|
||||
#define TCB_RCV_NXT_V(x) ((x) << TCB_RCV_NXT_S)
|
||||
|
||||
#define TCB_RCV_WND_W 17
|
||||
#define TCB_RCV_WND_S 10
|
||||
#define TCB_RCV_WND_M 0xffffffULL
|
||||
#define TCB_RCV_WND_V(x) ((x) << TCB_RCV_WND_S)
|
||||
|
||||
#define TCB_RX_FRAG2_PTR_RAW_W 27
|
||||
#define TCB_RX_FRAG3_LEN_RAW_W 29
|
||||
#define TCB_RX_FRAG3_START_IDX_OFFSET_RAW_W 30
|
||||
#define TCB_PDU_HDR_LEN_W 31
|
||||
|
||||
#define TCB_RQ_START_W 30
|
||||
#define TCB_RQ_START_S 0
|
||||
#define TCB_RQ_START_M 0x3ffffffULL
|
||||
#define TCB_RQ_START_V(x) ((x) << TCB_RQ_START_S)
|
||||
|
||||
#define TF_RX_PDU_OUT_S 49
|
||||
#define TF_RX_PDU_OUT_V(x) ((__u64)(x) << TF_RX_PDU_OUT_S)
|
||||
|
||||
#define TF_CORE_BYPASS_S 63
|
||||
#define TF_CORE_BYPASS_V(x) ((__u64)(x) << TF_CORE_BYPASS_S)
|
||||
#define TF_CORE_BYPASS_F TF_CORE_BYPASS_V(1)
|
||||
|
||||
#define TF_NON_OFFLOAD_S 1
|
||||
#define TF_NON_OFFLOAD_V(x) ((x) << TF_NON_OFFLOAD_S)
|
||||
#define TF_NON_OFFLOAD_F TF_NON_OFFLOAD_V(1)
|
||||
|
||||
#endif /* __T4_TCB_H */
|
||||
|
@ -1205,6 +1205,7 @@ enum fw_caps_config_crypto {
|
||||
FW_CAPS_CONFIG_CRYPTO_LOOKASIDE = 0x00000001,
|
||||
FW_CAPS_CONFIG_TLS_INLINE = 0x00000002,
|
||||
FW_CAPS_CONFIG_IPSEC_INLINE = 0x00000004,
|
||||
FW_CAPS_CONFIG_TX_TLS_HW = 0x00000008,
|
||||
};
|
||||
|
||||
enum fw_caps_config_fcoe {
|
||||
@ -1328,6 +1329,7 @@ enum fw_params_param_dev {
|
||||
FW_PARAMS_PARAM_DEV_DBQ_TIMERTICK = 0x2A,
|
||||
FW_PARAMS_PARAM_DEV_NUM_TM_CLASS = 0x2B,
|
||||
FW_PARAMS_PARAM_DEV_FILTER = 0x2E,
|
||||
FW_PARAMS_PARAM_DEV_KTLS_TX_HW = 0x31,
|
||||
};
|
||||
|
||||
/*
|
||||
|
Loading…
x
Reference in New Issue
Block a user