> -----Original Message-----
> From: Min Hu (Connor) <humi...@huawei.com>
> Sent: Thursday, April 22, 2021 7:39 AM
> To: dev@dpdk.org
> Cc: Yigit, Ferruh <ferruh.yi...@intel.com>; Dumitrescu, Cristian
> <cristian.dumitre...@intel.com>
> Subject: [PATCH] pipeline: fix deallocate null pointer
>
> From: HongBo Zheng <zhenghong...@huawei.com>
>
> Fix deallocate null pointer in instruction_config, while
> pointer 'data' or 'instr' may be null.
>
> Fixes: a1711f948dbf ("pipeline: add SWX Rx and extract instructions")
> Cc: sta...@dpdk.org
>
> Signed-off-by: HongBo Zheng <zhenghong...@huawei.com>
> Signed-off-by: Min Hu (Connor) <humi...@huawei.com>
> ---
> lib/librte_pipeline/rte_swx_pipeline.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/lib/librte_pipeline/rte_swx_pipeline.c
> b/lib/librte_pipeline/rte_swx_pipeline.c
> index 4455d91..6084635 100644
> --- a/lib/librte_pipeline/rte_swx_pipeline.c
> +++ b/lib/librte_pipeline/rte_swx_pipeline.c
> @@ -8015,8 +8015,10 @@ instruction_config(struct rte_swx_pipeline *p,
> return 0;
>
> error:
> - free(data);
> - free(instr);
> + if (data)
> + free(data);
> + if (instr)
> + free(instr);
> return err;
> }
>
> --
> 2.7.4
Hi,
NACK.
Thanks for the patch, but the tests for data and instr being non-NULL before
calling free are not required, because:
1. Both data and instr are initialized to NULL.
2. free(NULL) is supported.
Regards,
Cristian