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

Reply via email to