[dpdk-dev] [PATCH v4 02/15] crypto: add total raw buffer length
Hemant Agrawal
hemant.agrawal at oss.nxp.com
Sun Oct 17 10:30:59 CEST 2021
Hi Fan
On 10/14/2021 6:09 PM, Zhang, Roy Fan wrote:
> Hi Hemant,
>
> I still think it is enough to use rte_crypto_vec as well as
> rte_crypto_sym_ofs is enough to describe the data including both the data
> and aad.
>
> Imagine 2 10 bytes segments case, encryption/hash size of 12 and aad of 8.
> We will have
> struct rte_crypto_vec sgl[2] = {{.base = x, .len = 10}, {.base = y, .len = 10}};
> union rte_crypto_sym_ofs ofs = {.cipher.head = 0, .cipher.tail = 8, .auth.head = 0, .auth.tail = 8};
>
> The driver shall understand there are 8 bytes not included for cipher/auth.
This is the protocol offload case. It won't work in that case.
>
> Regards,
> Fan
>
>> -----Original Message-----
>> From: Hemant Agrawal <hemant.agrawal at nxp.com>
>> Sent: Wednesday, October 13, 2021 8:00 PM
>> To: dev at dpdk.org; gakhil at marvell.com
>> Cc: Ananyev, Konstantin <konstantin.ananyev at intel.com>; Zhang, Roy Fan
>> <roy.fan.zhang at intel.com>; Gagandeep Singh <g.singh at nxp.com>
>> Subject: [PATCH v4 02/15] crypto: add total raw buffer length
>>
>> From: Gagandeep Singh <g.singh at nxp.com>
>>
>> The current crypto raw data vectors is extended to support
>> rte_security usecases, where we need total data length to know
>> how much additional memory space is available in buffer other
>> than data length so that driver/HW can write expanded size
>> data after encryption.
>>
>> Signed-off-by: Gagandeep Singh <g.singh at nxp.com>
>> Acked-by: Akhil Goyal <gakhil at marvell.com>
>> ---
>> doc/guides/rel_notes/deprecation.rst | 7 -------
>> lib/cryptodev/rte_crypto_sym.h | 7 +++++++
>> 2 files changed, 7 insertions(+), 7 deletions(-)
>>
>> diff --git a/doc/guides/rel_notes/deprecation.rst
>> b/doc/guides/rel_notes/deprecation.rst
>> index a4e86b31f5..53155459a0 100644
>> --- a/doc/guides/rel_notes/deprecation.rst
>> +++ b/doc/guides/rel_notes/deprecation.rst
>> @@ -188,13 +188,6 @@ Deprecation Notices
>> This field will be null for inplace processing.
>> This change is targeted for DPDK 21.11.
>>
>> -* cryptodev: The structure ``rte_crypto_vec`` would be updated to add
>> - ``tot_len`` to support total buffer length.
>> - This is required for security cases like IPsec and PDCP encryption offload
>> - to know how much additional memory space is available in buffer other
>> than
>> - data length so that driver/HW can write expanded size data after
>> encryption.
>> - This change is targeted for DPDK 21.11.
>> -
>> * cryptodev: Hide structures ``rte_cryptodev_sym_session`` and
>> ``rte_cryptodev_asym_session`` to remove unnecessary indirection
>> between
>> session and the private data of session. An opaque pointer can be exposed
>> diff --git a/lib/cryptodev/rte_crypto_sym.h
>> b/lib/cryptodev/rte_crypto_sym.h
>> index dcc0bd5933..6be283e83c 100644
>> --- a/lib/cryptodev/rte_crypto_sym.h
>> +++ b/lib/cryptodev/rte_crypto_sym.h
>> @@ -37,6 +37,8 @@ struct rte_crypto_vec {
>> rte_iova_t iova;
>> /** length of the data buffer */
>> uint32_t len;
>> + /** total buffer length */
>> + uint32_t tot_len;
>> };
>>
>> /**
>> @@ -980,12 +982,14 @@ rte_crypto_mbuf_to_vec(const struct rte_mbuf
>> *mb, uint32_t ofs, uint32_t len,
>> seglen = mb->data_len - ofs;
>> if (len <= seglen) {
>> vec[0].len = len;
>> + vec[0].tot_len = mb->buf_len - rte_pktmbuf_headroom(mb)
>> - ofs;
>> return 1;
>> }
>>
>> /* data spread across segments */
>> vec[0].len = seglen;
>> left = len - seglen;
>> + vec[0].tot_len = mb->buf_len - rte_pktmbuf_headroom(mb) - ofs;
>> for (i = 1, nseg = mb->next; nseg != NULL; nseg = nseg->next, i++) {
>>
>> vec[i].base = rte_pktmbuf_mtod(nseg, void *);
>> @@ -995,6 +999,8 @@ rte_crypto_mbuf_to_vec(const struct rte_mbuf *mb,
>> uint32_t ofs, uint32_t len,
>> if (left <= seglen) {
>> /* whole requested data is completed */
>> vec[i].len = left;
>> + vec[i].tot_len = mb->buf_len -
>> rte_pktmbuf_headroom(mb)
>> + - ofs;
>> left = 0;
>> break;
>> }
>> @@ -1002,6 +1008,7 @@ rte_crypto_mbuf_to_vec(const struct rte_mbuf
>> *mb, uint32_t ofs, uint32_t len,
>> /* use whole segment */
>> vec[i].len = seglen;
>> left -= seglen;
>> + vec[i].tot_len = mb->buf_len - rte_pktmbuf_headroom(mb)
>> - ofs;
>> }
>>
>> RTE_ASSERT(left == 0);
>> --
>> 2.17.1
More information about the dev
mailing list