patches for DPDK stable branches
 help / color / mirror / Atom feed
From: Kevin Traynor <ktraynor@redhat.com>
To: Bing Zhao <bingz@nvidia.com>
Cc: Dariusz Sosnowski <dsosnowski@nvidia.com>, dpdk stable <stable@dpdk.org>
Subject: patch 'net/mlx5: fix leak of flow action data list' has been queued to stable release 24.11.2
Date: Thu, 13 Feb 2025 09:57:48 +0000	[thread overview]
Message-ID: <20250213095933.362078-21-ktraynor@redhat.com> (raw)
In-Reply-To: <20250213095933.362078-1-ktraynor@redhat.com>

Hi,

FYI, your patch has been queued to stable release 24.11.2

Note it hasn't been pushed to http://dpdk.org/browse/dpdk-stable yet.
It will be pushed if I get no objections before 02/17/25. So please
shout if anyone has objections.

Also note that after the patch there's a diff of the upstream commit vs the
patch applied to the branch. This will indicate if there was any rebasing
needed to apply to the stable branch. If there were code changes for rebasing
(ie: not only metadata diffs), please double check that the rebase was
correctly done.

Queued patches are on a temporary branch at:
https://github.com/kevintraynor/dpdk-stable

This queued commit can be viewed at:
https://github.com/kevintraynor/dpdk-stable/commit/fbc041172e9c2008acd74e8e09f2b9ef0dd4624e

Thanks.

Kevin

---
From fbc041172e9c2008acd74e8e09f2b9ef0dd4624e Mon Sep 17 00:00:00 2001
From: Bing Zhao <bingz@nvidia.com>
Date: Tue, 26 Nov 2024 10:34:40 +0200
Subject: [PATCH] net/mlx5: fix leak of flow action data list

[ upstream commit d68bcfb6da221ee114835db8c2ab9449d277590f ]

In the actions construction for HWS non-template API, the `masks`
parameter is always set to NULL and all the actions will be
translated in the "construct" stage as non-fixed ones.

In the stage of translating actions template, the actions data would
be allocated from the pool and managed in a list. The list would be
released when destroying the template with the actions. In the NT2HWS
implementation, the temporary template was freed directly and the
actions will be destroyed with the flow rule deletion. No other rule
would use this list anymore.

The actions data in the list should be freed when the actions
construction is done.

Fixes: ff4064d5b1fe ("net/mlx5: support bulk actions in non-template flow")

Signed-off-by: Bing Zhao <bingz@nvidia.com>
Acked-by: Dariusz Sosnowski <dsosnowski@nvidia.com>
---
 drivers/net/mlx5/mlx5_flow_hw.c | 63 ++++++++++++++++++++-------------
 1 file changed, 39 insertions(+), 24 deletions(-)

diff --git a/drivers/net/mlx5/mlx5_flow_hw.c b/drivers/net/mlx5/mlx5_flow_hw.c
index 50dbaa27ab..1de6b889a7 100644
--- a/drivers/net/mlx5/mlx5_flow_hw.c
+++ b/drivers/net/mlx5/mlx5_flow_hw.c
@@ -967,8 +967,5 @@ __flow_hw_actions_release(struct rte_eth_dev *dev, struct mlx5_hw_actions *acts)
 
 /**
- * Destroy DR actions created by action template.
- *
- * For DR actions created during table creation's action translate.
- * Need to destroy the DR action when destroying the table.
+ * Release the action data back into the pool without destroy any action.
  *
  * @param[in] dev
@@ -977,6 +974,6 @@ __flow_hw_actions_release(struct rte_eth_dev *dev, struct mlx5_hw_actions *acts)
  *   Pointer to the template HW steering DR actions.
  */
-static void
-__flow_hw_action_template_destroy(struct rte_eth_dev *dev, struct mlx5_hw_actions *acts)
+static inline void
+__flow_hw_act_data_flush(struct rte_eth_dev *dev, struct mlx5_hw_actions *acts)
 {
 	struct mlx5_priv *priv = dev->data->dev_private;
@@ -988,5 +985,21 @@ __flow_hw_action_template_destroy(struct rte_eth_dev *dev, struct mlx5_hw_action
 		mlx5_ipool_free(priv->acts_ipool, data->idx);
 	}
+}
 
+/*
+ * Destroy DR actions created by action template.
+ *
+ * For DR actions created during table creation's action translate.
+ * Need to destroy the DR action when destroying the table.
+ *
+ * @param[in] dev
+ *   Pointer to the rte_eth_dev structure.
+ * @param[in] acts
+ *   Pointer to the template HW steering DR actions.
+ */
+static void
+__flow_hw_action_template_destroy(struct rte_eth_dev *dev, struct mlx5_hw_actions *acts)
+{
+	__flow_hw_act_data_flush(dev, acts);
 	__flow_hw_actions_release(dev, acts);
 }
@@ -13493,12 +13506,12 @@ flow_nta_build_template_mask(const struct rte_flow_action actions[],
 static int
 flow_hw_translate_flow_actions(struct rte_eth_dev *dev,
-			  const struct rte_flow_attr *attr,
-			  const struct rte_flow_action actions[],
-			  struct rte_flow_hw *flow,
-			  struct mlx5_flow_hw_action_params *ap,
-			  struct mlx5_hw_actions *hw_acts,
-			  uint64_t item_flags, uint64_t action_flags,
-			  bool external,
-			  struct rte_flow_error *error)
+			       const struct rte_flow_attr *attr,
+			       const struct rte_flow_action actions[],
+			       struct rte_flow_hw *flow,
+			       struct mlx5_flow_hw_action_params *ap,
+			       struct mlx5_hw_actions *hw_acts,
+			       uint64_t item_flags, uint64_t action_flags,
+			       bool external,
+			       struct rte_flow_error *error)
 {
 	int ret = 0;
@@ -13543,5 +13556,5 @@ flow_hw_translate_flow_actions(struct rte_eth_dev *dev,
 	if (!table)
 		return rte_flow_error_set(error, ENOMEM, RTE_FLOW_ERROR_TYPE_ACTION,
-				   actions, "Failed to allocate dummy table");
+					  actions, "Failed to allocate dummy table");
 	at = __flow_hw_actions_template_create(dev, &template_attr, actions, masks, true, error);
 	if (!at) {
@@ -13557,5 +13570,5 @@ flow_hw_translate_flow_actions(struct rte_eth_dev *dev,
 	table->ats[0].action_template = at;
 	ret = __flow_hw_translate_actions_template(dev, &table->cfg, hw_acts, at,
-		&table->mpctx, true, error);
+						   &table->mpctx, true, error);
 	if (ret)
 		goto end;
@@ -13563,19 +13576,21 @@ flow_hw_translate_flow_actions(struct rte_eth_dev *dev,
 	ret = flow_hw_encap_decap_resource_register(dev, table, hw_acts, flow, error);
 	if (ret)
-		goto clean_up;
+		goto end;
 	ret = flow_hw_modify_hdr_resource_register(dev, table, hw_acts, flow, error);
 	if (ret)
-		goto clean_up;
+		goto end;
 	table->ats[0].acts = *hw_acts;
 	ret = flow_hw_actions_construct(dev, flow, ap,
-		&table->ats[0], item_flags, table,
-		actions, hw_acts->rule_acts, 0, error);
+					&table->ats[0], item_flags, table,
+					actions, hw_acts->rule_acts, 0, error);
 	if (ret)
-		goto clean_up;
+		goto end;
 	goto end;
-clean_up:
-	/* Make sure that there is no garbage in the actions. */
-	__flow_hw_action_template_destroy(dev, hw_acts);
 end:
+	if (ret)
+		/* Make sure that there is no garbage in the actions. */
+		__flow_hw_action_template_destroy(dev, hw_acts);
+	else
+		__flow_hw_act_data_flush(dev, hw_acts);
 	if (table)
 		mlx5_free(table);
-- 
2.48.1

---
  Diff of the applied patch vs upstream commit (please double-check if non-empty:
---
--- -	2025-02-12 17:29:36.830390319 +0000
+++ 0021-net-mlx5-fix-leak-of-flow-action-data-list.patch	2025-02-12 17:29:34.215945124 +0000
@@ -1 +1 @@
-From d68bcfb6da221ee114835db8c2ab9449d277590f Mon Sep 17 00:00:00 2001
+From fbc041172e9c2008acd74e8e09f2b9ef0dd4624e Mon Sep 17 00:00:00 2001
@@ -5,0 +6,2 @@
+[ upstream commit d68bcfb6da221ee114835db8c2ab9449d277590f ]
+
@@ -21 +22,0 @@
-Cc: stable@dpdk.org


  parent reply	other threads:[~2025-02-13 10:00 UTC|newest]

Thread overview: 123+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-02-13  9:57 patch 'log: fix double free on cleanup' " Kevin Traynor
2025-02-13  9:57 ` patch 'test/ring: fix init with custom number of lcores' " Kevin Traynor
2025-02-13  9:57 ` patch 'vhost: clear ring addresses when getting vring base' " Kevin Traynor
2025-02-13  9:57 ` patch 'vhost: check GSO size validity' " Kevin Traynor
2025-02-13  9:57 ` patch 'vhost: fix log when setting max queue num' " Kevin Traynor
2025-02-13  9:57 ` patch 'vhost: reset packets count when not ready' " Kevin Traynor
2025-02-13  9:57 ` patch 'crypto/cnxk: fix build with GCC 15' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/thunderx/base: " Kevin Traynor
2025-02-13  9:57 ` patch 'examples/flow_filtering: " Kevin Traynor
2025-02-13  9:57 ` patch 'eal/x86: fix some intrinsics header include for Windows' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ena: fix missing default LLQ policy' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/nfp: fix VF link speed' " Kevin Traynor
2025-02-13  9:57 ` patch 'test/bonding: fix active backup receive test' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/bonding: fix dedicated queue setup' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/hns3: fix mbuf freeing in simple Tx path' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/hns3: remove PVID info dump for VF' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/hns3: rename RAS module' " Kevin Traynor
2025-02-13  9:57 ` patch 'examples/flow_filtering: remove duplicate assignment' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/sfc: remove unnecessary " Kevin Traynor
2025-02-13  9:57 ` patch 'net/mlx5: fix polling CQEs' " Kevin Traynor
2025-02-13  9:57 ` Kevin Traynor [this message]
2025-02-13  9:57 ` patch 'net/mlx5: fix unneeded stub flow table allocation' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ixgbe: fix E610 support in flow engine' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ixgbe/base: fix TSAM checking return value' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ixgbe/base: remove 2.5/5G from auto-negotiation for E610' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ixgbe/base: fix driver hang in VM' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ixgbe/base: add missing buffer copy for ACI' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/iavf: remove reset of Tx prepare function pointer' " Kevin Traynor
2025-02-13  9:57 ` patch 'net/ice: fix memory leak in scalar Rx' " Kevin Traynor
2025-02-13  9:57 ` patch 'common/cnxk: fix atomic load in batch ops' " Kevin Traynor
2025-02-13  9:57 ` patch 'common/cnxk: fix DPI mailbox structure' " Kevin Traynor
2025-02-13  9:57 ` patch 'eventdev: fix format string data type in log messages' " Kevin Traynor
2025-02-13  9:58 ` patch 'crypto/virtio: fix redundant queue free' " Kevin Traynor
2025-02-13  9:58 ` patch 'crypto/openssl: fix CMAC auth context update' " Kevin Traynor
2025-02-13 15:18   ` Wathsala Wathawana Vithanage
2025-02-13  9:58 ` patch 'cryptodev: fix C++ include' " Kevin Traynor
2025-02-13  9:58 ` patch 'crypto/virtio: fix data queues iteration' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/octeon_ep: remove useless assignment' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/enetfec: " Kevin Traynor
2025-02-13  9:58 ` patch 'net/gve: allocate Rx QPL pages using malloc' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/nfp: fix multiple PFs check from NSP' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/nfp: fix misuse of function return values' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/nfp: fix multi-PF control flag' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/nfp: fix firmware load from flash' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/ice: fix flows handling' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/cnxk: fix NIX send header L3 type' " Kevin Traynor
2025-02-13  9:58 ` patch 'gro: fix unprocessed IPv4 packets' " Kevin Traynor
2025-02-13  9:58 ` patch 'log: fix systemd journal socket open' " Kevin Traynor
2025-02-13  9:58 ` patch 'eal/linux: fix memseg length in legacy mem init' " Kevin Traynor
2025-02-13  9:58 ` patch 'service: fix getting service lcore attributes' " Kevin Traynor
2025-02-13  9:58 ` patch 'ptr_compress: fix build with Arm SVE' " Kevin Traynor
2025-02-13  9:58 ` patch 'buildtools: fix some Python regex syntax warnings' " Kevin Traynor
2025-02-13  9:58 ` patch 'dts: fix MTU set command' " Kevin Traynor
2025-02-13  9:58 ` patch 'dts: fix pass rate edge case in results' " Kevin Traynor
2025-02-13  9:58 ` patch 'use Python raw string notation' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/af_packet: fix socket close on device stop' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mana: do not ring short doorbell for every mbuf alloc' " Kevin Traynor
2025-02-13  9:58 ` patch 'ethdev: fix functions available in new device event' " Kevin Traynor
2025-02-13  9:58 ` patch 'vhost: add null callback checks' " Kevin Traynor
2025-02-13  9:58 ` patch 'vhost: fix FD entries cleanup' " Kevin Traynor
2025-02-13  9:58 ` patch 'build: force GCC 15 to initialize padding bits' " Kevin Traynor
2025-02-13  9:58 ` patch 'random: defer seeding to EAL init' " Kevin Traynor
2025-02-13  9:58 ` patch 'power: defer lcore variable allocation' " Kevin Traynor
2025-02-13  9:58 ` patch 'eal/x86: defer power intrinsics " Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: fix indication of " Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: fix Rx handler' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: fix crash when representor is re-attached' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: fix dead code' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: fix overflow' " Kevin Traynor
2025-02-13  9:58 ` Kevin Traynor
2025-02-13  9:58 ` patch 'net/bnxt: address uninitialized variables' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mlx5: fix Netlink socket leak' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mlx5: adjust actions per rule limitation' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mlx5: fix crash in non-template metadata split' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mlx5: fix flush of non-template flow rules' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/mlx5: fix GRE flow match with SWS' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix deadlock when writing i225 register' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix infinite loop' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix bitwise operation type' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: increase PHY power up delay' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: reset loop variable' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix LTR for i225' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix typo in LTR calculation' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix unused value' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix semaphore timeout " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix iterator type' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix MAC address hash bit shift' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix data type in MAC hash' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/igc/base: fix NVM data type in bit shift' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/e1000/base: fix semaphore timeout value' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/e1000/base: correct mPHY access logic' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/e1000/base: fix iterator type' " Kevin Traynor
2025-02-13  9:58 ` patch 'net/e1000/base: fix MAC address hash bit shift' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix data type in MAC hash' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix uninitialized variable' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix bitwise operation type' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix NVM data type in bit shift' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix reset for 82580' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: fix unchecked return' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/e1000/base: skip management check for 82575' " Kevin Traynor
2025-02-13  9:59 ` patch 'common/idpf: fix void function returning a value' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/intel: fix void functions " Kevin Traynor
2025-02-13  9:59 ` patch 'net/intel: fix build with icx' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/hns3: fix copper port initialization' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/hns3: fix reset timeout' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/cpfl: fix representor parsing log' " Kevin Traynor
2025-02-13  9:59 ` patch 'raw/cnxk_gpio: fix file descriptor leak' " Kevin Traynor
2025-02-13  9:59 ` patch 'eal: fix devargs layers parsing out of bounds' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/qede: fix debug messages array' " Kevin Traynor
2025-02-13  9:59 ` patch 'examples/ptpclient: fix message parsing' " Kevin Traynor
2025-02-13  9:59 ` patch 'net/hinic: fix flow type bitmask overflow' " Kevin Traynor
2025-02-13  9:59 ` patch 'crypto/dpaa2_sec: fix bitmask truncation' " Kevin Traynor
2025-02-13  9:59 ` patch 'crypto/dpaa_sec: " Kevin Traynor
2025-02-13  9:59 ` patch 'event/dpaa: " Kevin Traynor
2025-02-13  9:59 ` patch 'net/dpaa: " Kevin Traynor
2025-02-13  9:59 ` patch 'net/dpaa2: " Kevin Traynor
2025-02-13  9:59 ` patch 'net/qede: fix nested loops' " Kevin Traynor
2025-02-13  9:59 ` patch 'examples/l3fwd: fix socket ID check' " Kevin Traynor
2025-02-13  9:59 ` patch 'common/cnxk: fix null " Kevin Traynor
2025-02-13  9:59 ` patch 'eal/linux: remove useless assignments' " Kevin Traynor
2025-02-13  9:59 ` patch 'mempool: fix errno in empty create' " Kevin Traynor
2025-02-13  9:59 ` patch 'doc: add tested platforms with NVIDIA NICs in 24.11' " Kevin Traynor
2025-02-13  9:59 ` patch 'doc: add two more tested Intel " Kevin Traynor

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=20250213095933.362078-21-ktraynor@redhat.com \
    --to=ktraynor@redhat.com \
    --cc=bingz@nvidia.com \
    --cc=dsosnowski@nvidia.com \
    --cc=stable@dpdk.org \
    /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).