DPDK patches and discussions
 help / color / mirror / Atom feed
From: Stephen Hemminger <stephen@networkplumber.org>
To: dev@dpdk.org
Cc: Stephen Hemminger <stephen@networkplumber.org>,
	Hemant Agrawal <hemant.agrawal@nxp.com>,
	Sachin Saxena <sachin.saxena@nxp.com>
Subject: [PATCH v5 10/10] common/dpaxx: replace zero length array
Date: Tue, 28 Nov 2023 18:39:17 -0800	[thread overview]
Message-ID: <20231129024221.57653-11-stephen@networkplumber.org> (raw)
In-Reply-To: <20231129024221.57653-1-stephen@networkplumber.org>

The zero length ip_header is used as an overlay to the
encap IP header. Since the code is already assuming the layout
of the structure, replace the array with direct access.

Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
Acked-by: Hemant Agrawal <hemant.agrawal@nxp.com>
---
 drivers/common/dpaax/caamflib/desc/ipsec.h | 20 ++++++++++++++------
 1 file changed, 14 insertions(+), 6 deletions(-)

diff --git a/drivers/common/dpaax/caamflib/desc/ipsec.h b/drivers/common/dpaax/caamflib/desc/ipsec.h
index 95fc3ea5ba3b..d1411cc6aab4 100644
--- a/drivers/common/dpaax/caamflib/desc/ipsec.h
+++ b/drivers/common/dpaax/caamflib/desc/ipsec.h
@@ -334,9 +334,7 @@ struct ipsec_encap_gcm {
  * @seq_num: IPsec sequence number
  * @spi: IPsec SPI (Security Parameters Index)
  * @ip_hdr_len: optional IP Header length (in bytes)
- *  reserved - 16b
- *  Opt. IP Hdr Len - 16b
- * @ip_hdr: optional IP Header content (only for IPsec legacy mode)
+ *  Ip header must follow directly after ipsec_encap_pdb
  */
 struct ipsec_encap_pdb {
 	uint32_t options;
@@ -350,7 +348,6 @@ struct ipsec_encap_pdb {
 	};
 	uint32_t spi;
 	uint32_t ip_hdr_len;
-	uint8_t ip_hdr[0];
 };
 
 static inline unsigned int
@@ -776,7 +773,12 @@ cnstr_shdsc_ipsec_encap(uint32_t *descbuf, bool ps, bool swap,
 		PROGRAM_SET_36BIT_ADDR(p);
 	phdr = SHR_HDR(p, share, hdr, 0);
 	__rta_copy_ipsec_encap_pdb(p, pdb, cipherdata->algtype);
-	COPY_DATA(p, pdb->ip_hdr, pdb->ip_hdr_len);
+
+	/* ip header if any follows the encap_pdb */
+	if (pdb->ip_hdr_len > 0) {
+		void *ip_hdr = pdb + 1;
+		COPY_DATA(p, ip_hdr, pdb->ip_hdr_len);
+	}
 	SET_LABEL(p, hdr);
 	pkeyjmp = JUMP(p, keyjmp, LOCAL_JUMP, ALL_TRUE, BOTH|SHRD);
 	if (authdata->keylen)
@@ -913,7 +915,13 @@ cnstr_shdsc_ipsec_encap_des_aes_xcbc(uint32_t *descbuf,
 	PROGRAM_CNTXT_INIT(p, descbuf, 0);
 	phdr = SHR_HDR(p, share, hdr, 0);
 	__rta_copy_ipsec_encap_pdb(p, pdb, cipherdata->algtype);
-	COPY_DATA(p, pdb->ip_hdr, pdb->ip_hdr_len);
+
+	/* ip header if any follows the encap_pdb */
+	if (pdb->ip_hdr_len > 0) {
+		void *ip_hdr = pdb + 1;
+		COPY_DATA(p, ip_hdr, pdb->ip_hdr_len);
+	}
+
 	SET_LABEL(p, hdr);
 	pkeyjump = JUMP(p, keyjump, LOCAL_JUMP, ALL_TRUE, SHRD | SELF);
 	/*
-- 
2.42.0


  parent reply	other threads:[~2023-11-29  2:43 UTC|newest]

Thread overview: 84+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-01-13 21:51 [PATCH 0/7] replace zero length arrays Stephen Hemminger
2023-01-13 21:51 ` [PATCH 1/7] member: replace zero length array with flex array Stephen Hemminger
2023-01-14  0:19   ` Tyler Retzlaff
2023-01-14  0:36     ` Stephen Hemminger
2023-01-14  0:42       ` Tyler Retzlaff
2023-01-13 21:52 ` [PATCH 2/7] cryptodev: " Stephen Hemminger
2023-01-13 21:52 ` [PATCH 3/7] security: " Stephen Hemminger
2023-01-13 21:52 ` [PATCH 4/7] mlx5: " Stephen Hemminger
2023-01-14 17:08   ` Stephen Hemminger
2023-03-06 13:29     ` Slava Ovsiienko
2023-01-13 21:52 ` [PATCH 5/7] nfp: " Stephen Hemminger
2023-01-15 15:22   ` Niklas Söderlund
2023-01-13 21:52 ` [PATCH 6/7] enic: " Stephen Hemminger
2023-01-14  1:12   ` John Daley (johndale)
2023-01-13 21:52 ` [PATCH 7/7] dpaax: " Stephen Hemminger
2023-01-15 11:59   ` Hemant Agrawal
2023-01-14 10:43 ` [PATCH 0/7] replace zero length arrays Morten Brørup
2023-11-17  4:03 ` [PATCH v2 00/10] " Stephen Hemminger
2023-11-17  4:03   ` [PATCH v2 01/10] member: replace zero length array with flex array Stephen Hemminger
2023-11-17  4:17     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 02/10] cryptodev: " Stephen Hemminger
2023-11-17  4:18     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 03/10] security: " Stephen Hemminger
2023-11-17  4:18     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 04/10] pipeline: " Stephen Hemminger
2023-11-17  4:19     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 05/10] net/nfp: " Stephen Hemminger
2023-11-17  4:19     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 06/10] net/enic: " Stephen Hemminger
2023-11-17  4:20     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 07/10] net/mlx5: " Stephen Hemminger
2023-11-17  4:20     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 08/10] pdcp: " Stephen Hemminger
2023-11-17  4:20     ` Tyler Retzlaff
2023-11-17  5:28     ` [EXT] " Anoob Joseph
2023-11-17  4:03   ` [PATCH v2 09/10] net/cpfl: " Stephen Hemminger
2023-11-17  4:20     ` Tyler Retzlaff
2023-11-17  4:03   ` [PATCH v2 10/10] common/dpaxx: " Stephen Hemminger
2023-11-17  4:21     ` Tyler Retzlaff
2023-11-17  8:31   ` [PATCH v2 00/10] replace zero length arrays Morten Brørup
2023-11-17 16:18     ` Stephen Hemminger
2023-11-17 19:59       ` Tyler Retzlaff
2023-11-20 17:06 ` [PATCH v4 00/10] Replace " Stephen Hemminger
2023-11-20 17:06   ` [PATCH v4 01/10] member: replace zero length array with flex array Stephen Hemminger
2023-11-20 17:06   ` [PATCH v4 02/10] cryptodev: " Stephen Hemminger
2023-11-21  5:29     ` [EXT] " Anoob Joseph
2023-11-20 17:06   ` [PATCH v4 03/10] security: " Stephen Hemminger
2023-11-21  5:30     ` [EXT] " Anoob Joseph
2023-11-20 17:06   ` [PATCH v4 04/10] pipeline: " Stephen Hemminger
2023-11-20 17:07   ` [PATCH v4 05/10] net/nfp: " Stephen Hemminger
2023-11-21  1:14     ` Chaoyong He
2023-11-20 17:07   ` [PATCH v4 06/10] net/enic: " Stephen Hemminger
2023-11-20 17:07   ` [PATCH v4 07/10] net/mlx5: " Stephen Hemminger
2023-11-23 17:54     ` Dariusz Sosnowski
2023-11-20 17:07   ` [PATCH v4 08/10] pdcp: " Stephen Hemminger
2023-11-20 17:07   ` [PATCH v4 09/10] net/cpfl: " Stephen Hemminger
2023-11-20 17:07   ` [PATCH v4 10/10] common/dpaxx: remove zero length array Stephen Hemminger
2023-11-21 10:49     ` Hemant Agrawal
2023-11-21 16:46       ` Stephen Hemminger
2023-11-21 17:01         ` Stephen Hemminger
2023-11-21 17:18         ` Tyler Retzlaff
2023-11-22  7:23           ` Hemant Agrawal
2023-11-23  1:43             ` Stephen Hemminger
2023-11-23 19:18             ` Stephen Hemminger
2023-11-28  6:43               ` Hemant Agrawal
2023-11-21  7:26   ` [PATCH v4 00/10] Replace zero length arrays Morten Brørup
2023-11-21  8:30     ` fengchengwen
2023-11-29  2:39 ` [PATCH v5 " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 01/10] member: replace zero length array with flex array Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 02/10] cryptodev: " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 03/10] security: " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 04/10] pipeline: " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 05/10] net/nfp: " Stephen Hemminger
2023-11-30  1:21     ` Chaoyong He
2023-11-29  2:39   ` [PATCH v5 06/10] net/enic: " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 07/10] net/mlx5: " Stephen Hemminger
2024-01-23  9:44     ` Thomas Monjalon
2024-01-23 10:28       ` Thomas Monjalon
2024-01-23 11:18         ` Dariusz Sosnowski
2023-11-29  2:39   ` [PATCH v5 08/10] pdcp: " Stephen Hemminger
2023-11-29  2:39   ` [PATCH v5 09/10] net/cpfl: " Stephen Hemminger
2023-11-29  2:39   ` Stephen Hemminger [this message]
2024-01-23  9:42     ` [PATCH v5 10/10] common/dpaxx: replace zero length array Thomas Monjalon
2024-01-23 10:48   ` [PATCH v5 00/10] Replace zero length arrays Thomas Monjalon

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20231129024221.57653-11-stephen@networkplumber.org \
    --to=stephen@networkplumber.org \
    --cc=dev@dpdk.org \
    --cc=hemant.agrawal@nxp.com \
    --cc=sachin.saxena@nxp.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).