1 // SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB
2 // Copyright (c) 2019 Mellanox Technologies.
5 #include "en_accel/ktls.h"
6 #include "en_accel/ktls_utils.h"
7 #include "en_accel/fs_tcp.h"
9 static int mlx5e_ktls_add(struct net_device *netdev, struct sock *sk,
10 enum tls_offload_ctx_dir direction,
11 struct tls_crypto_info *crypto_info,
12 u32 start_offload_tcp_sn)
14 struct mlx5e_priv *priv = netdev_priv(netdev);
15 struct mlx5_core_dev *mdev = priv->mdev;
18 if (WARN_ON(!mlx5e_ktls_type_check(mdev, crypto_info)))
21 if (direction == TLS_OFFLOAD_CTX_DIR_TX)
22 err = mlx5e_ktls_add_tx(netdev, sk, crypto_info, start_offload_tcp_sn);
24 err = mlx5e_ktls_add_rx(netdev, sk, crypto_info, start_offload_tcp_sn);
29 static void mlx5e_ktls_del(struct net_device *netdev,
30 struct tls_context *tls_ctx,
31 enum tls_offload_ctx_dir direction)
33 if (direction == TLS_OFFLOAD_CTX_DIR_TX)
34 mlx5e_ktls_del_tx(netdev, tls_ctx);
36 mlx5e_ktls_del_rx(netdev, tls_ctx);
39 static int mlx5e_ktls_resync(struct net_device *netdev,
40 struct sock *sk, u32 seq, u8 *rcd_sn,
41 enum tls_offload_ctx_dir direction)
43 if (unlikely(direction != TLS_OFFLOAD_CTX_DIR_RX))
46 mlx5e_ktls_rx_resync(netdev, sk, seq, rcd_sn);
50 static const struct tlsdev_ops mlx5e_ktls_ops = {
51 .tls_dev_add = mlx5e_ktls_add,
52 .tls_dev_del = mlx5e_ktls_del,
53 .tls_dev_resync = mlx5e_ktls_resync,
56 void mlx5e_ktls_build_netdev(struct mlx5e_priv *priv)
58 struct net_device *netdev = priv->netdev;
59 struct mlx5_core_dev *mdev = priv->mdev;
61 if (!mlx5_accel_is_ktls_device(mdev))
64 if (mlx5_accel_is_ktls_tx(mdev)) {
65 netdev->hw_features |= NETIF_F_HW_TLS_TX;
66 netdev->features |= NETIF_F_HW_TLS_TX;
69 if (mlx5_accel_is_ktls_rx(mdev))
70 netdev->hw_features |= NETIF_F_HW_TLS_RX;
72 netdev->tlsdev_ops = &mlx5e_ktls_ops;
75 int mlx5e_ktls_set_feature_rx(struct net_device *netdev, bool enable)
77 struct mlx5e_priv *priv = netdev_priv(netdev);
80 mutex_lock(&priv->state_lock);
82 err = mlx5e_accel_fs_tcp_create(priv);
84 mlx5e_accel_fs_tcp_destroy(priv);
85 mutex_unlock(&priv->state_lock);
90 int mlx5e_ktls_init_rx(struct mlx5e_priv *priv)
94 if (priv->netdev->features & NETIF_F_HW_TLS_RX)
95 err = mlx5e_accel_fs_tcp_create(priv);
100 void mlx5e_ktls_cleanup_rx(struct mlx5e_priv *priv)
102 if (priv->netdev->features & NETIF_F_HW_TLS_RX)
103 mlx5e_accel_fs_tcp_destroy(priv);