DPDK patches and discussions
 help / color / mirror / Atom feed
* [PATCH] lib/ethdev: sanity check on callback before resource allocation
@ 2023-07-11  1:18 Kaiyu Zhang
  2023-07-11  1:48 ` fengchengwen
  2023-08-01 16:19 ` Stephen Hemminger
  0 siblings, 2 replies; 4+ messages in thread
From: Kaiyu Zhang @ 2023-07-11  1:18 UTC (permalink / raw)
  To: thomas, ferruh.yigit, andrew.rybchenko; +Cc: dev, Kaiyu Zhang

sanity check is performed after a rte_eth_dev object is allocated.
The object is not freed if the check fails, though in the current
reality this never happens, but it's better programming paradigm
to move the quick check up front to the start of
rte_eth_dev_pci_generic_probe.

Signed-off-by: Kaiyu Zhang <squirrel.prog@gmail.com>
---
 lib/ethdev/ethdev_pci.h | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/lib/ethdev/ethdev_pci.h b/lib/ethdev/ethdev_pci.h
index 94b8fba5d7..320e3e0093 100644
--- a/lib/ethdev/ethdev_pci.h
+++ b/lib/ethdev/ethdev_pci.h
@@ -126,12 +126,13 @@ rte_eth_dev_pci_generic_probe(struct rte_pci_device *pci_dev,
 	struct rte_eth_dev *eth_dev;
 	int ret;
 
+	if (*dev_init == NULL)
+		return -EINVAL;
+
 	eth_dev = rte_eth_dev_pci_allocate(pci_dev, private_data_size);
 	if (!eth_dev)
 		return -ENOMEM;
 
-	if (*dev_init == NULL)
-		return -EINVAL;
 	ret = dev_init(eth_dev);
 	if (ret)
 		rte_eth_dev_release_port(eth_dev);
-- 
2.34.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] lib/ethdev: sanity check on callback before resource allocation
  2023-07-11  1:18 [PATCH] lib/ethdev: sanity check on callback before resource allocation Kaiyu Zhang
@ 2023-07-11  1:48 ` fengchengwen
  2023-07-11 13:37   ` Ferruh Yigit
  2023-08-01 16:19 ` Stephen Hemminger
  1 sibling, 1 reply; 4+ messages in thread
From: fengchengwen @ 2023-07-11  1:48 UTC (permalink / raw)
  To: Kaiyu Zhang, thomas, ferruh.yigit, andrew.rybchenko; +Cc: dev

Please add Cc.
Reviewed-by: Chengwen Feng <fengchengwen@huawei.com>

On 2023/7/11 9:18, Kaiyu Zhang wrote:
> sanity check is performed after a rte_eth_dev object is allocated.
> The object is not freed if the check fails, though in the current
> reality this never happens, but it's better programming paradigm
> to move the quick check up front to the start of
> rte_eth_dev_pci_generic_probe.
> 
> Signed-off-by: Kaiyu Zhang <squirrel.prog@gmail.com>
> ---
>  lib/ethdev/ethdev_pci.h | 5 +++--
>  1 file changed, 3 insertions(+), 2 deletions(-)
> 
> diff --git a/lib/ethdev/ethdev_pci.h b/lib/ethdev/ethdev_pci.h
> index 94b8fba5d7..320e3e0093 100644
> --- a/lib/ethdev/ethdev_pci.h
> +++ b/lib/ethdev/ethdev_pci.h
> @@ -126,12 +126,13 @@ rte_eth_dev_pci_generic_probe(struct rte_pci_device *pci_dev,
>  	struct rte_eth_dev *eth_dev;
>  	int ret;
>  
> +	if (*dev_init == NULL)
> +		return -EINVAL;
> +
>  	eth_dev = rte_eth_dev_pci_allocate(pci_dev, private_data_size);
>  	if (!eth_dev)
>  		return -ENOMEM;
>  
> -	if (*dev_init == NULL)
> -		return -EINVAL;
>  	ret = dev_init(eth_dev);
>  	if (ret)
>  		rte_eth_dev_release_port(eth_dev);
> 

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] lib/ethdev: sanity check on callback before resource allocation
  2023-07-11  1:48 ` fengchengwen
@ 2023-07-11 13:37   ` Ferruh Yigit
  0 siblings, 0 replies; 4+ messages in thread
From: Ferruh Yigit @ 2023-07-11 13:37 UTC (permalink / raw)
  To: fengchengwen, Kaiyu Zhang, thomas, andrew.rybchenko; +Cc: dev

On 7/11/2023 2:48 AM, fengchengwen wrote:

> On 2023/7/11 9:18, Kaiyu Zhang wrote:
>> sanity check is performed after a rte_eth_dev object is allocated.
>> The object is not freed if the check fails, though in the current
>> reality this never happens, but it's better programming paradigm
>> to move the quick check up front to the start of
>> rte_eth_dev_pci_generic_probe.
>>
>> Signed-off-by: Kaiyu Zhang <squirrel.prog@gmail.com>
>> 
> 
> Reviewed-by: Chengwen Feng <fengchengwen@huawei.com>
> 
    Fixes: dcd5c8112bc3 ("ethdev: add PCI driver helpers")
    Cc: stable@dpdk.org

Reviewed-by: Ferruh Yigit <ferruh.yigit@amd.com>

Applied to dpdk-next-net/main, thanks.

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] lib/ethdev: sanity check on callback before resource allocation
  2023-07-11  1:18 [PATCH] lib/ethdev: sanity check on callback before resource allocation Kaiyu Zhang
  2023-07-11  1:48 ` fengchengwen
@ 2023-08-01 16:19 ` Stephen Hemminger
  1 sibling, 0 replies; 4+ messages in thread
From: Stephen Hemminger @ 2023-08-01 16:19 UTC (permalink / raw)
  To: Kaiyu Zhang; +Cc: thomas, ferruh.yigit, andrew.rybchenko, dev

On Tue, 11 Jul 2023 01:18:09 +0000
Kaiyu Zhang <squirrel.prog@gmail.com> wrote:

> sanity check is performed after a rte_eth_dev object is allocated.
> The object is not freed if the check fails, though in the current
> reality this never happens, but it's better programming paradigm
> to move the quick check up front to the start of
> rte_eth_dev_pci_generic_probe.
> 
> Signed-off-by: Kaiyu Zhang <squirrel.prog@gmail.com>

The term sanity check is on the non-inclusive naming word list.
Please don't use that term in DPDK.
There is an outstanding patchset to remove all use of the term.

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2023-08-01 16:19 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-07-11  1:18 [PATCH] lib/ethdev: sanity check on callback before resource allocation Kaiyu Zhang
2023-07-11  1:48 ` fengchengwen
2023-07-11 13:37   ` Ferruh Yigit
2023-08-01 16:19 ` Stephen Hemminger

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).