f-stack/dpdk/lib/ethdev/ethdev_vdev.h

64 lines
1.4 KiB
C
Raw Normal View History

2021-02-05 08:48:47 +00:00
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright(c) 2017 Brocade Communications Systems, Inc.
* Author: Jan Blunck <jblunck@infradead.org>
*/
2017-04-21 10:43:26 +00:00
#ifndef _RTE_ETHDEV_VDEV_H_
#define _RTE_ETHDEV_VDEV_H_
2017-04-21 10:43:26 +00:00
2022-09-02 04:40:05 +00:00
#ifdef __cplusplus
extern "C" {
#endif
#include <rte_config.h>
#include <rte_malloc.h>
#include <rte_bus_vdev.h>
2022-09-06 04:00:10 +00:00
#include <ethdev_driver.h>
2017-04-21 10:43:26 +00:00
/**
* @internal
2022-09-06 04:00:10 +00:00
* Allocates a new ethdev slot for an Ethernet device and returns the pointer
* to that slot for the driver to use.
*
* @param dev
* Pointer to virtual device
*
* @param private_data_size
* Size of private data structure
2017-04-21 10:43:26 +00:00
*
* @return
* A pointer to a rte_eth_dev or NULL if allocation failed.
2017-04-21 10:43:26 +00:00
*/
static inline struct rte_eth_dev *
rte_eth_vdev_allocate(struct rte_vdev_device *dev, size_t private_data_size)
2017-04-21 10:43:26 +00:00
{
struct rte_eth_dev *eth_dev;
const char *name = rte_vdev_device_name(dev);
2017-04-21 10:43:26 +00:00
eth_dev = rte_eth_dev_allocate(name);
if (!eth_dev)
return NULL;
if (private_data_size) {
eth_dev->data->dev_private = rte_zmalloc_socket(name,
private_data_size, RTE_CACHE_LINE_SIZE,
dev->device.numa_node);
if (!eth_dev->data->dev_private) {
rte_eth_dev_release_port(eth_dev);
return NULL;
}
}
2017-04-21 10:43:26 +00:00
eth_dev->device = &dev->device;
eth_dev->intr_handle = NULL;
2017-04-21 10:43:26 +00:00
eth_dev->data->numa_node = dev->device.numa_node;
return eth_dev;
2017-04-21 10:43:26 +00:00
}
2022-09-02 04:40:05 +00:00
#ifdef __cplusplus
}
#endif
#endif /* _RTE_ETHDEV_VDEV_H_ */