cryptodev: remove AAD length from crypto op
[dpdk.git] / drivers / crypto / openssl / rte_openssl_pmd_private.h
index 65c5f97..fa8cabc 100644 (file)
@@ -1,7 +1,7 @@
 /*-
  *   BSD LICENSE
  *
- *   Copyright(c) 2016 Intel Corporation. All rights reserved.
+ *   Copyright(c) 2016-2017 Intel Corporation. All rights reserved.
  *
  *   Redistribution and use in source and binary forms, with or without
  *   modification, are permitted provided that the following conditions
@@ -62,6 +62,7 @@
 enum openssl_chain_order {
        OPENSSL_CHAIN_ONLY_CIPHER,
        OPENSSL_CHAIN_ONLY_AUTH,
+       OPENSSL_CHAIN_CIPHER_BPI,
        OPENSSL_CHAIN_CIPHER_AUTH,
        OPENSSL_CHAIN_AUTH_CIPHER,
        OPENSSL_CHAIN_COMBINED,
@@ -107,6 +108,11 @@ struct openssl_session {
        enum openssl_chain_order chain_order;
        /**< chain order mode */
 
+       struct {
+               uint16_t length;
+               uint16_t offset;
+       } iv;
+       /**< IV parameters */
        /** Cipher Parameters */
        struct {
                enum rte_crypto_cipher_operation direction;
@@ -127,6 +133,7 @@ struct openssl_session {
                /**< pointer to EVP algorithm function */
                EVP_CIPHER_CTX *ctx;
                /**< pointer to EVP context structure */
+               EVP_CIPHER_CTX *bpi_ctx;
        } cipher;
 
        /** Authentication Parameters */
@@ -155,6 +162,9 @@ struct openssl_session {
                                /**< pointer to EVP context structure */
                        } hmac;
                };
+
+               uint16_t aad_length;
+               /**< AAD length */
        } auth;
 
 } __rte_cache_aligned;