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 static inline const char *
38 rte_vdev_device_name(
const struct rte_vdev_device *dev)
40 if (dev && dev->device.name)
41 return dev->device.name;
45 static inline const char *
46 rte_vdev_device_args(
const struct rte_vdev_device *dev)
48 if (dev && dev->device.devargs)
49 return dev->device.devargs->args;
83 uint64_t iova,
size_t len);
102 uint64_t iova,
size_t len);
134 #define RTE_PMD_REGISTER_VDEV(nm, vdrv)\ 135 static const char *vdrvinit_ ## nm ## _alias;\ 136 RTE_INIT(vdrvinitfn_ ##vdrv)\ 138 (vdrv).driver.name = RTE_STR(nm);\ 139 (vdrv).driver.alias = vdrvinit_ ## nm ## _alias;\ 140 rte_vdev_register(&vdrv);\ 142 RTE_PMD_EXPORT_NAME(nm, __COUNTER__) 144 #define RTE_PMD_REGISTER_ALIAS(nm, alias)\ 145 static const char *vdrvinit_ ## nm ## _alias = RTE_STR(alias) 147 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)