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_uninit(const char *name)
int rte_vdev_init(const char *name, const char *args)
int() rte_vdev_dma_map_t(struct rte_vdev_device *dev, void *addr, uint64_t iova, size_t len)
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)
int() rte_vdev_remove_t(struct rte_vdev_device *dev)
rte_vdev_dma_unmap_t * dma_unmap
TAILQ_HEAD(vdev_driver_list, rte_vdev_driver)
int() rte_vdev_dma_unmap_t(struct rte_vdev_device *dev, void *addr, uint64_t iova, size_t len)
int() rte_vdev_probe_t(struct rte_vdev_device *dev)