ethdev: fix port data reset timing
rte_eth_dev_data structure is allocated per ethdev port and can be
used to get a data of the port internally.
rte_eth_dev_attach_secondary tries to find the port identifier using
rte_eth_dev_data name field comparison and may get an identifier of
invalid port in case of this port was released by the primary process
because the port release API doesn't reset the port data.
So, it will be better to reset the port data in release time instead of
allocation time.
Move the port data reset to the port release API.
Fixes: d948f596fe
("ethdev: fix port data mismatched in multiple process model")
Cc: stable@dpdk.org
Signed-off-by: Matan Azrad <matan@mellanox.com>
Acked-by: Thomas Monjalon <thomas@monjalon.net>
Acked-by: Konstantin Ananyev <konstantin.ananyev@intel.com>
This commit is contained in:
parent
e56447980e
commit
133b54779a
@ -261,7 +261,6 @@ rte_eth_dev_allocate(const char *name)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memset(&rte_eth_dev_data[port_id], 0, sizeof(struct rte_eth_dev_data));
|
||||
eth_dev = eth_dev_get(port_id);
|
||||
snprintf(eth_dev->data->name, sizeof(eth_dev->data->name), "%s", name);
|
||||
eth_dev->data->port_id = port_id;
|
||||
@ -309,6 +308,7 @@ rte_eth_dev_release_port(struct rte_eth_dev *eth_dev)
|
||||
if (eth_dev == NULL)
|
||||
return -EINVAL;
|
||||
|
||||
memset(eth_dev->data, 0, sizeof(struct rte_eth_dev_data));
|
||||
eth_dev->state = RTE_ETH_DEV_UNUSED;
|
||||
|
||||
_rte_eth_dev_callback_process(eth_dev, RTE_ETH_EVENT_DESTROY, NULL);
|
||||
|
Loading…
Reference in New Issue
Block a user