> > 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? > > > > > > 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>