This patch add a xform that is used with the crypto flow
steering action to offload ipsec crypto inline.

Signed-off-by: Boris Pismenny <bor...@mellanox.com>
Signed-off-by: Aviad Yehezkel <avia...@mellanox.com>
---
 lib/librte_cryptodev/rte_crypto_sym.h | 42 ++++++++++++++++++++++++++++++++++-
 1 file changed, 41 insertions(+), 1 deletion(-)

diff --git a/lib/librte_cryptodev/rte_crypto_sym.h 
b/lib/librte_cryptodev/rte_crypto_sym.h
index 3a40844..139443e 100644
--- a/lib/librte_cryptodev/rte_crypto_sym.h
+++ b/lib/librte_cryptodev/rte_crypto_sym.h
@@ -346,11 +346,49 @@ struct rte_crypto_auth_xform {
         */
 };
 
+/**
+ * IPsec transformation data
+ *
+ * This structure contains data relating to an IPsec crypto
+ * transforms. The fields op, algo and key are common to all
+ * IPsec encryptions and MUST be set. The salt is useful for AEAD ciphers
+ * which must provide an out-of-band nonce for each SA.
+ */
+struct rte_crypto_ipsec_xform {
+       enum rte_crypto_cipher_operation op;
+       /**< IPsec operation type */
+       enum rte_crypto_cipher_algorithm algo;
+       /**<  Encryption algorithm selection */
+
+       struct {
+               uint8_t *data;  /**< pointer to key data */
+               size_t length;  /**< key length in bytes */
+       } key;
+       /**< Cipher key
+        *
+        * Cipher key length is in bytes. For AES it can be 128 bits (16 bytes),
+        * 192 bits (24 bytes) or 256 bits (32 bytes).
+        *
+        * For the CCM mode of operation, the only supported key length is 128
+        * bits (16 bytes).
+        *
+        **/
+
+       uint32_t salt; /* salt for this security association */
+       /** <Implicit IV
+        *
+        * Implicit IV is set once per SA as defined by RFC 4106 (ESP AES-GCM)
+        *
+        **/
+
+};
+
 /** Crypto transformation types */
 enum rte_crypto_sym_xform_type {
        RTE_CRYPTO_SYM_XFORM_NOT_SPECIFIED = 0, /**< No xform specified */
        RTE_CRYPTO_SYM_XFORM_AUTH,              /**< Authentication xform */
-       RTE_CRYPTO_SYM_XFORM_CIPHER             /**< Cipher xform  */
+       RTE_CRYPTO_SYM_XFORM_CIPHER,            /**< Cipher xform */
+       RTE_CRYPTO_SYM_XFORM_IPSEC,             /**< IPsec xform */
 };
 
 /**
@@ -373,6 +411,8 @@ struct rte_crypto_sym_xform {
                /**< Authentication / hash xform */
                struct rte_crypto_cipher_xform cipher;
                /**< Cipher xform */
+               struct rte_crypto_ipsec_xform ipsec;
+               /**< IPsec xform */
        };
 };
 
-- 
1.8.3.1

Reply via email to