[dpdk-dev] [PATCH v1] net/pfe: fix to set mac_addrs to NULL after freeing

Ferruh Yigit ferruh.yigit at intel.com
Wed Apr 8 16:27:31 CEST 2020


On 4/7/2020 12:39 PM, wangyunjian wrote:
> From: Yunjian Wang <wangyunjian at huawei.com>
> 
> It does not correctly set the mac_addrs variable to NULL after
> freeing it, which will lead to a double free.
> 
> Fixes: 67fc3ff97c39 ("net/pfe: introduce basic functions")
> Cc: stable at dpdk.org
> 
> Signed-off-by: Yunjian Wang <wangyunjian at huawei.com>
> ---
>  drivers/net/pfe/pfe_ethdev.c | 1 +
>  1 file changed, 1 insertion(+)
> 
> diff --git a/drivers/net/pfe/pfe_ethdev.c b/drivers/net/pfe/pfe_ethdev.c
> index 940347819..ba0f8dd3f 100644
> --- a/drivers/net/pfe/pfe_ethdev.c
> +++ b/drivers/net/pfe/pfe_ethdev.c
> @@ -397,6 +397,7 @@ pfe_eth_exit(struct rte_eth_dev *dev, struct pfe *pfe)
>  	pfe_eth_close_cdev(dev->data->dev_private);
>  
>  	rte_free(dev->data->mac_addrs);
> +	dev->data->mac_addrs = NULL;

Why not remove 'rte_free(dev->data->mac_addrs);', since
'rte_eth_dev_release_port()' does free the 'mac_addrs'?

>  	rte_eth_dev_release_port(dev);
>  	pfe->nb_devs--;
>  }
> 



More information about the dev mailing list