16#include <rte_compat.h>
22#ifdef RTE_EXEC_ENV_LINUX
24#define RTE_VFIO_DIR "/dev/vfio"
25#define RTE_VFIO_CONTAINER_PATH "/dev/vfio/vfio"
26#define RTE_VFIO_GROUP_FMT "/dev/vfio/%u"
27#define RTE_VFIO_NOIOMMU_GROUP_FMT "/dev/vfio/noiommu-%u"
28#define RTE_VFIO_NOIOMMU_MODE \
29 "/sys/module/vfio/parameters/enable_unsafe_noiommu_mode"
34struct vfio_device_info;
36#define RTE_VFIO_DEFAULT_CONTAINER_FD (-1)
64 int *vfio_dev_fd,
struct vfio_device_info *device_info);
166 const char *dev_addr,
int *iommu_group_num);
192 int *vfio_dev_fd,
struct vfio_device_info *device_info);
308 uint64_t iova, uint64_t len);
332 uint64_t iova, uint64_t len);
int rte_vfio_clear_group(int vfio_group_fd)
int rte_vfio_setup_device(const char *sysfs_base, const char *dev_addr, int *vfio_dev_fd, struct vfio_device_info *device_info)
int rte_vfio_get_group_num(const char *sysfs_base, const char *dev_addr, int *iommu_group_num)
int rte_vfio_is_enabled(const char *modname)
int rte_vfio_container_group_bind(int container_fd, int iommu_group_num)
int rte_vfio_container_group_unbind(int container_fd, int iommu_group_num)
int rte_vfio_get_container_fd(void)
int rte_vfio_enable(const char *modname)
int rte_vfio_container_destroy(int container_fd)
int rte_vfio_container_dma_map(int container_fd, uint64_t vaddr, uint64_t iova, uint64_t len)
int rte_vfio_noiommu_is_enabled(void)
int rte_vfio_release_device(const char *sysfs_base, const char *dev_addr, int fd)
int rte_vfio_container_dma_unmap(int container_fd, uint64_t vaddr, uint64_t iova, uint64_t len)
int rte_vfio_container_create(void)
__rte_experimental int rte_vfio_get_device_info(const char *sysfs_base, const char *dev_addr, int *vfio_dev_fd, struct vfio_device_info *device_info)
int rte_vfio_get_group_fd(int iommu_group_num)