> On Mar 4, 2024, at 1:33 AM, Akhil Goyal <gak...@marvell.com> wrote:
> 
>>> Hi folks,
>>> 
>>> The introduction of a more unified IPsec MB library for DPDK is causing the
>>> snow3g tests to fail on ARM. Artifact here:
>>> https://lab.dpdk.org/results/dashboard/patchsets/29315/
>>> PMDs using the direct API (KASUMI, CHACHA, ZUC, SNOW3G) will use the job
>> API,
>>> from the AESNI MB PMD code.
>>> We have come across a similar issue in the past that related to an offset 
>>> issue as
>>> SNOW3G uses bits instead of bytes.
>> 
>> The above link does not seem to be working.
>> I believe from now on, since we continue to maintain two separate repos,
>> it would be better to get ack from ARM folks as well
>> before merging anything onto crypto/ipsec_mb PMD.
>> 
>> Arm folks, Could you please get the below change tested/incorporated in the
>> repo.
> 
> Hi Arm folks,
> Any update on the below fix?
This is being worked on. We are in the process of creating a new tag. We will 
update soon.
> 
> 
>> 
>> 
>>> 
>>> commit a501609ea6466ed8526c0dfadedee332a4d4a451
>>> Author: Pablo de Lara pablo.de.lara.gua...@intel.com
>>> Date:   Wed Feb 23 16:01:16 2022 +0000
>>> 
>>>    crypto/ipsec_mb: fix length and offset settings
>>> 
>>>    KASUMI, SNOW3G and ZUC require lengths and offsets to
>>>    be set in bits or bytes depending on the algorithm.
>>>    There were some algorithms that were mixing these two,
>>>    so this commit is fixing this issue.
>>> 
>>> This bug only appeared recently when the ARM ipsec version was bumped to
>> 1.4.
>>> It appears there could be a similar scenario happening now and this is a
>> potential
>>> fix that needs to be made in the ARM IPsec-mb repo:
>>> 
>>> diff --git a/lib/aarch64/mb_mgr_snow3g_submit_flush_common_aarch64.h
>>> b/lib/aarch64/mb_mgr_snow3g_submit_flush_common_aarch64.h
>>> index 13bca11b..de284ade 100644
>>> --- a/lib/aarch64/mb_mgr_snow3g_submit_flush_common_aarch64.h
>>> +++ b/lib/aarch64/mb_mgr_snow3g_submit_flush_common_aarch64.h
>>> @@ -94,8 +94,8 @@ static void
>>> snow3g_mb_mgr_insert_uea2_job(MB_MGR_SNOW3G_OOO *state, IMB_JOB
>>> *job
>>>     state->num_lanes_inuse++;
>>>     state->args.iv[used_lane_idx] = job->iv;
>>>     state->args.keys[used_lane_idx] = job->enc_keys;
>>> -    state->args.in[used_lane_idx] = job->src + job-
>>>> cipher_start_src_offset_in_bytes;
>>> -    state->args.out[used_lane_idx] = job->dst;
>>> +    state->args.in[used_lane_idx] = job->src + (job-
>>>> cipher_start_src_offset_in_bits / 8);
>>> +    state->args.out[used_lane_idx] = job->dst + (job-
>>>> cipher_start_src_offset_in_bits / 8);
>>>     state->args.byte_length[used_lane_idx] = job->msg_len_to_cipher_in_bits 
>>> /
>> 8;
>>>     state->args.INITIALIZED[used_lane_idx] = 0;
>>>     state->lens[used_lane_idx] = job->msg_len_to_cipher_in_bits / 8;
>>> 
>>> Thanks,
>>> Brian
>>> 
>>>> -----Original Message-----
>>>> From: Dooley, Brian <brian.doo...@intel.com>
>>>> Sent: Wednesday, February 28, 2024 11:33 AM
>>>> To: Ji, Kai <kai...@intel.com>; De Lara Guarch, Pablo
>>>> <pablo.de.lara.gua...@intel.com>
>>>> Cc: dev@dpdk.org; gak...@marvell.com; Dooley, Brian
>>>> <brian.doo...@intel.com>
>>>> Subject: [PATCH v4] crypto/ipsec_mb: unified IPsec MB interface
>>>> 
>>>> Currently IPsec MB provides both the JOB API and direct API.
>>>> AESNI_MB PMD is using the JOB API codepath while ZUC, KASUMI, SNOW3G
>>>> and CHACHA20_POLY1305 are using the direct API.
>>>> Instead of using the direct API for these PMDs, they should now make
>>>> use of the JOB API codepath. This would remove all use of the IPsec MB
>>>> direct API for these PMDs.
>>>> 
>>>> Signed-off-by: Brian Dooley <brian.doo...@intel.com>
>>>> ---
>>>> v2:
>>>> - Fix compilation failure
>>>> v3:
>>>> - Remove session configure pointer for each PMD
>>>> v4:
>>>> - Keep AES GCM PMD and fix extern issue
>>>> ---
>>>> doc/guides/rel_notes/release_24_03.rst        |   6 +
>>>> drivers/crypto/ipsec_mb/pmd_aesni_mb.c        |  10 +-
>>>> drivers/crypto/ipsec_mb/pmd_aesni_mb_priv.h   |  15 +-
>>>> drivers/crypto/ipsec_mb/pmd_chacha_poly.c     | 338 +----------
>>>> .../crypto/ipsec_mb/pmd_chacha_poly_priv.h    |  28 -
>>>> drivers/crypto/ipsec_mb/pmd_kasumi.c          | 410 +------------
>>>> drivers/crypto/ipsec_mb/pmd_kasumi_priv.h     |  20 -
>>>> drivers/crypto/ipsec_mb/pmd_snow3g.c          | 543 +-----------------
>>>> drivers/crypto/ipsec_mb/pmd_snow3g_priv.h     |  21 -
>>>> drivers/crypto/ipsec_mb/pmd_zuc.c             | 347 +----------
>>>> drivers/crypto/ipsec_mb/pmd_zuc_priv.h        |  20 -
>>>> 11 files changed, 48 insertions(+), 1710 deletions(-)
>>>> 
>>> <snip>

Reply via email to