Message ID | 20250416092243.65573-3-bsdhenrymartin@gmail.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | net/mlx5: Fix NULL dereference and memory leak in ttc_table creation | expand |
On Wed, Apr 16, 2025 at 05:22:43PM +0800, Henry Martin wrote: > Relocate the memory allocation for ttc table after the switch statement > that validates params->ns_type in both mlx5_create_inner_ttc_table() and > mlx5_create_ttc_table(). This ensures memory is only allocated after > confirming valid input, eliminating potential memory leaks when invalid > ns_type cases occur. > > Signed-off-by: Henry Martin <bsdhenrymartin@gmail.com> > --- > .../net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c | 16 ++++++++-------- > 1 file changed, 8 insertions(+), 8 deletions(-) > > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > index 066121fed718..513dafd5ebf2 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > @@ -637,10 +637,6 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, > bool use_l4_type; > int err; > > - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > - if (!ttc) > - return ERR_PTR(-ENOMEM); > - > switch (params->ns_type) { > case MLX5_FLOW_NAMESPACE_PORT_SEL: > use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && > @@ -654,6 +650,10 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, > return ERR_PTR(-EINVAL); > } > > + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > + if (!ttc) > + return ERR_PTR(-ENOMEM); > + > ns = mlx5_get_flow_namespace(dev, params->ns_type); > if (!ns) { > kvfree(ttc); > @@ -715,10 +715,6 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, > bool use_l4_type; > int err; > > - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > - if (!ttc) > - return ERR_PTR(-ENOMEM); > - > switch (params->ns_type) { > case MLX5_FLOW_NAMESPACE_PORT_SEL: > use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && > @@ -732,6 +728,10 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, > return ERR_PTR(-EINVAL); > } > > + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > + if (!ttc) > + return ERR_PTR(-ENOMEM); > + > ns = mlx5_get_flow_namespace(dev, params->ns_type); > if (!ns) { > kvfree(ttc); Thanks for fixing Reviewed-by: Michal Swiatkowski <michal.swiatkowski@linux.intel.com> > -- > 2.34.1 >
On 16/04/2025 12:22, Henry Martin wrote: > Relocate the memory allocation for ttc table after the switch statement > that validates params->ns_type in both mlx5_create_inner_ttc_table() and > mlx5_create_ttc_table(). This ensures memory is only allocated after > confirming valid input, eliminating potential memory leaks when invalid > ns_type cases occur. > > Signed-off-by: Henry Martin <bsdhenrymartin@gmail.com> > --- > .../net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c | 16 ++++++++-------- > 1 file changed, 8 insertions(+), 8 deletions(-) > > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > index 066121fed718..513dafd5ebf2 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c > @@ -637,10 +637,6 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, > bool use_l4_type; > int err; > > - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > - if (!ttc) > - return ERR_PTR(-ENOMEM); > - > switch (params->ns_type) { > case MLX5_FLOW_NAMESPACE_PORT_SEL: > use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && > @@ -654,6 +650,10 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, > return ERR_PTR(-EINVAL); > } > > + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > + if (!ttc) > + return ERR_PTR(-ENOMEM); > + > ns = mlx5_get_flow_namespace(dev, params->ns_type); > if (!ns) { > kvfree(ttc); > @@ -715,10 +715,6 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, > bool use_l4_type; > int err; > > - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > - if (!ttc) > - return ERR_PTR(-ENOMEM); > - > switch (params->ns_type) { > case MLX5_FLOW_NAMESPACE_PORT_SEL: > use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && > @@ -732,6 +728,10 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, > return ERR_PTR(-EINVAL); > } > > + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); > + if (!ttc) > + return ERR_PTR(-ENOMEM); > + > ns = mlx5_get_flow_namespace(dev, params->ns_type); > if (!ns) { > kvfree(ttc); Reviewed-by: Mark Bloch <mbloch@nvidia.com> Mark
On Wed, 16 Apr 2025 15:02:13 +0300 Mark Bloch wrote: > On 16/04/2025 12:22, Henry Martin wrote: > > Relocate the memory allocation for ttc table after the switch statement > > that validates params->ns_type in both mlx5_create_inner_ttc_table() and > > mlx5_create_ttc_table(). This ensures memory is only allocated after > > confirming valid input, eliminating potential memory leaks when invalid > > ns_type cases occur. > > Reviewed-by: Mark Bloch <mbloch@nvidia.com> A bit hard to see from the context but I'm guessing this fixes a memory leak? We need a Fixes tag.. reminder: please trim your replies
> A bit hard to see from the context but I'm guessing this fixes > a memory leak? We need a Fixes tag.. Thanks for the reminder. I've added the Fixes tag in v7. Regards, Henry
diff --git a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c index 066121fed718..513dafd5ebf2 100644 --- a/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c +++ b/drivers/net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c @@ -637,10 +637,6 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, bool use_l4_type; int err; - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); - if (!ttc) - return ERR_PTR(-ENOMEM); - switch (params->ns_type) { case MLX5_FLOW_NAMESPACE_PORT_SEL: use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && @@ -654,6 +650,10 @@ struct mlx5_ttc_table *mlx5_create_inner_ttc_table(struct mlx5_core_dev *dev, return ERR_PTR(-EINVAL); } + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); + if (!ttc) + return ERR_PTR(-ENOMEM); + ns = mlx5_get_flow_namespace(dev, params->ns_type); if (!ns) { kvfree(ttc); @@ -715,10 +715,6 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, bool use_l4_type; int err; - ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); - if (!ttc) - return ERR_PTR(-ENOMEM); - switch (params->ns_type) { case MLX5_FLOW_NAMESPACE_PORT_SEL: use_l4_type = MLX5_CAP_GEN_2(dev, pcc_ifa2) && @@ -732,6 +728,10 @@ struct mlx5_ttc_table *mlx5_create_ttc_table(struct mlx5_core_dev *dev, return ERR_PTR(-EINVAL); } + ttc = kvzalloc(sizeof(*ttc), GFP_KERNEL); + if (!ttc) + return ERR_PTR(-ENOMEM); + ns = mlx5_get_flow_namespace(dev, params->ns_type); if (!ns) { kvfree(ttc);
Relocate the memory allocation for ttc table after the switch statement that validates params->ns_type in both mlx5_create_inner_ttc_table() and mlx5_create_ttc_table(). This ensures memory is only allocated after confirming valid input, eliminating potential memory leaks when invalid ns_type cases occur. Signed-off-by: Henry Martin <bsdhenrymartin@gmail.com> --- .../net/ethernet/mellanox/mlx5/core/lib/fs_ttc.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-)