Enable users the option to call rte_vfio_dma_map with request to map to the default vfio fd.
Signed-off-by: Shahaf Shuler <shah...@mellanox.com> --- lib/librte_eal/common/include/rte_vfio.h | 6 ++++-- lib/librte_eal/linuxapp/eal/eal_vfio.c | 14 ++++++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/lib/librte_eal/common/include/rte_vfio.h b/lib/librte_eal/common/include/rte_vfio.h index cae96fab90..2a6827012f 100644 --- a/lib/librte_eal/common/include/rte_vfio.h +++ b/lib/librte_eal/common/include/rte_vfio.h @@ -347,7 +347,8 @@ rte_vfio_container_group_unbind(int container_fd, int iommu_group_num); * Perform DMA mapping for devices in a container. * * @param container_fd - * the specified container fd + * the specified container fd. In case of -1 the default container + * fd will be used. * * @param vaddr * Starting virtual address of memory to be mapped. @@ -370,7 +371,8 @@ rte_vfio_container_dma_map(int container_fd, uint64_t vaddr, * Perform DMA unmapping for devices in a container. * * @param container_fd - * the specified container fd + * the specified container fd. In case of -1 the default container + * fd will be used. * * @param vaddr * Starting virtual address of memory to be unmapped. diff --git a/lib/librte_eal/linuxapp/eal/eal_vfio.c b/lib/librte_eal/linuxapp/eal/eal_vfio.c index c821e83826..48ca9465d4 100644 --- a/lib/librte_eal/linuxapp/eal/eal_vfio.c +++ b/lib/librte_eal/linuxapp/eal/eal_vfio.c @@ -1897,7 +1897,12 @@ rte_vfio_container_dma_map(int container_fd, uint64_t vaddr, uint64_t iova, return -1; } - vfio_cfg = get_vfio_cfg_by_container_fd(container_fd); + if (container_fd > 0) { + vfio_cfg = get_vfio_cfg_by_container_fd(container_fd); + } else { + /* when no fd provided use the default. */ + vfio_cfg = &vfio_cfgs[0]; + } if (vfio_cfg == NULL) { RTE_LOG(ERR, EAL, "Invalid container fd\n"); return -1; @@ -1917,7 +1922,12 @@ rte_vfio_container_dma_unmap(int container_fd, uint64_t vaddr, uint64_t iova, return -1; } - vfio_cfg = get_vfio_cfg_by_container_fd(container_fd); + if (container_fd > 0) { + vfio_cfg = get_vfio_cfg_by_container_fd(container_fd); + } else { + /* when no fd provided use the default. */ + vfio_cfg = &vfio_cfgs[0]; + } if (vfio_cfg == NULL) { RTE_LOG(ERR, EAL, "Invalid container fd\n"); return -1; -- 2.12.0