18 #include <sys/queue.h>
22 struct rte_vdev_device {
23 TAILQ_ENTRY(rte_vdev_device) next;
31 #define RTE_DEV_TO_VDEV(ptr) \
32 container_of(ptr, struct rte_vdev_device, device)
34 #define RTE_DEV_TO_VDEV_CONST(ptr) \
35 container_of(ptr, const struct rte_vdev_device, device)
37 #define RTE_ETH_DEV_TO_VDEV(eth_dev) RTE_DEV_TO_VDEV((eth_dev)->device)
39 static inline const char *
40 rte_vdev_device_name(
const struct rte_vdev_device *dev)
42 if (dev && dev->device.name)
43 return dev->device.name;
47 static inline const char *
48 rte_vdev_device_args(
const struct rte_vdev_device *dev)
50 if (dev && dev->device.devargs)
51 return dev->device.devargs->args;
85 uint64_t iova,
size_t len);
104 uint64_t iova,
size_t len);
120 #define RTE_VDEV_DRV_NEED_IOVA_AS_VA 0x0001
140 #define RTE_PMD_REGISTER_VDEV(nm, vdrv)\
141 static const char *vdrvinit_ ## nm ## _alias;\
142 RTE_INIT(vdrvinitfn_ ##vdrv)\
144 (vdrv).driver.name = RTE_STR(nm);\
145 (vdrv).driver.alias = vdrvinit_ ## nm ## _alias;\
146 rte_vdev_register(&vdrv);\
148 RTE_PMD_EXPORT_NAME(nm, __COUNTER__)
150 #define RTE_PMD_REGISTER_ALIAS(nm, alias)\
151 static const char *vdrvinit_ ## nm ## _alias = RTE_STR(alias)
153 typedef void (*rte_vdev_scan_callback)(
void *user_arg);
rte_vdev_dma_map_t * dma_map
int( rte_vdev_remove_t)(struct rte_vdev_device *dev)
int rte_vdev_uninit(const char *name)
int rte_vdev_init(const char *name, const char *args)
void rte_vdev_register(struct rte_vdev_driver *driver)
int rte_vdev_remove_custom_scan(rte_vdev_scan_callback callback, void *user_arg)
void rte_vdev_unregister(struct rte_vdev_driver *driver)
int rte_vdev_add_custom_scan(rte_vdev_scan_callback callback, void *user_arg)
rte_vdev_dma_unmap_t * dma_unmap
int( rte_vdev_dma_unmap_t)(struct rte_vdev_device *dev, void *addr, uint64_t iova, size_t len)
int( rte_vdev_dma_map_t)(struct rte_vdev_device *dev, void *addr, uint64_t iova, size_t len)
TAILQ_HEAD(vdev_driver_list, rte_vdev_driver)
int( rte_vdev_probe_t)(struct rte_vdev_device *dev)