net/mlx5: Added required metadata capability for ipsec
authorAviad Yehezkel <aviadye@mellanox.com>
Wed, 17 Jan 2018 09:20:33 +0000 (11:20 +0200)
committerSaeed Mahameed <saeedm@mellanox.com>
Wed, 7 Mar 2018 23:54:34 +0000 (15:54 -0800)
Currently our device requires additional metadata in packet
to perform ipsec crypto offload.

Signed-off-by: Aviad Yehezkel <aviadye@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/fpga/ipsec.c
include/linux/mlx5/accel.h

index e7e2827..8de992b 100644 (file)
@@ -256,10 +256,12 @@ u32 mlx5_fpga_ipsec_device_caps(struct mlx5_core_dev *mdev)
        struct mlx5_fpga_device *fdev = mdev->fpga;
        u32 ret = 0;
 
-       if (mlx5_fpga_is_ipsec_device(mdev))
+       if (mlx5_fpga_is_ipsec_device(mdev)) {
                ret |= MLX5_ACCEL_IPSEC_CAP_DEVICE;
-       else
+               ret |= MLX5_ACCEL_IPSEC_CAP_REQUIRED_METADATA;
+       } else {
                return ret;
+       }
 
        if (!fdev->ipsec)
                return ret;
index 601280c..b674af6 100644 (file)
@@ -38,6 +38,7 @@
 
 enum mlx5_accel_ipsec_caps {
        MLX5_ACCEL_IPSEC_CAP_DEVICE             = 1 << 0,
+       MLX5_ACCEL_IPSEC_CAP_REQUIRED_METADATA  = 1 << 1,
        MLX5_ACCEL_IPSEC_CAP_ESP                = 1 << 2,
        MLX5_ACCEL_IPSEC_CAP_IPV6               = 1 << 3,
        MLX5_ACCEL_IPSEC_CAP_LSO                = 1 << 4,