ethdev: add internal function to device struct from name

The PMDs would need a function to access the rte_eth_devices
without accessing the global rte_eth_device array.

Cc: stable@dpdk.org

Signed-off-by: Kumara Parameshwaran <kparameshwar@vmware.com>
Reviewed-by: Ferruh Yigit <ferruh.yigit@intel.com>
This commit is contained in:
Kumara Parameshwaran 2022-01-31 20:02:33 +05:30 committed by Ferruh Yigit
parent fa4dfda5fe
commit 961fb4029b
3 changed files with 30 additions and 0 deletions

View File

@ -1629,6 +1629,24 @@ rte_eth_hairpin_queue_peer_bind(uint16_t cur_port, uint16_t cur_queue,
struct rte_hairpin_peer_info *peer_info,
uint32_t direction);
/**
* @internal
* Get rte_eth_dev from device name. The device name should be specified
* as below:
* - PCIe address (Domain:Bus:Device.Function), for example 0000:2:00.0
* - SoC device name, for example fsl-gmac0
* - vdev dpdk name, for example net_[pcap0|null0|tap0]
*
* @param name
* PCI address or name of the device
* @return
* - rte_eth_dev if successful
* - NULL on failure
*/
__rte_internal
struct rte_eth_dev*
rte_eth_dev_get_by_name(const char *name);
/**
* @internal
* Reset the current queue state and configuration to disconnect (unbind) it

View File

@ -894,6 +894,17 @@ rte_eth_dev_get_port_by_name(const char *name, uint16_t *port_id)
return -ENODEV;
}
struct rte_eth_dev *
rte_eth_dev_get_by_name(const char *name)
{
uint16_t pid;
if (rte_eth_dev_get_port_by_name(name, &pid))
return NULL;
return &rte_eth_devices[pid];
}
static int
eth_err(uint16_t port_id, int ret)
{

View File

@ -267,6 +267,7 @@ INTERNAL {
rte_eth_dev_callback_process;
rte_eth_dev_create;
rte_eth_dev_destroy;
rte_eth_dev_get_by_name;
rte_eth_dev_is_rx_hairpin_queue;
rte_eth_dev_is_tx_hairpin_queue;
rte_eth_dev_probing_finish;