bus/fslmc: fix VFIO setup
At device probe, the fslmc bus driver calls rte_vfio_get_group_fd() to
get a fd associated to a vfio group. This function first checks if the
group is already opened, else it opens /dev/vfio/%u, and increases the
number of active groups in default_vfio_cfg (which references the
default vfio container).
When adding the first group to a vfio_cfg, the caller is supposed to
pick an IOMMU type and set up DMA mappings for container, as it's done
by pci bus, but it is not done here. Instead, a new container is created
and used.
This prevents the pci bus driver, which uses the default_vfio_cfg
container, to configure the container because
default_vfio_cfg->active_group > 1.
This patch fixes the issue by always creating a new container (and its
associated vfio_cfg) and binding the group to it.
Fixes: a69f793002
("bus/fslmc: support multi VFIO group")
Cc: stable@dpdk.org
Signed-off-by: Romain Delhomel <romain.delhomel@6wind.com>
Acked-by: Hemant Agrawal <hemant.agrawal@nxp.com>
This commit is contained in:
parent
013b4c52c7
commit
36c3c4df13
@ -995,6 +995,7 @@ fslmc_vfio_setup_group(void)
|
|||||||
{
|
{
|
||||||
int groupid;
|
int groupid;
|
||||||
int ret;
|
int ret;
|
||||||
|
int vfio_container_fd;
|
||||||
struct vfio_group_status status = { .argsz = sizeof(status) };
|
struct vfio_group_status status = { .argsz = sizeof(status) };
|
||||||
|
|
||||||
/* if already done once */
|
/* if already done once */
|
||||||
@ -1013,8 +1014,15 @@ fslmc_vfio_setup_group(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ret = rte_vfio_container_create();
|
||||||
|
if (ret < 0) {
|
||||||
|
DPAA2_BUS_ERR("Failed to open VFIO container");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
vfio_container_fd = ret;
|
||||||
|
|
||||||
/* Get the actual group fd */
|
/* Get the actual group fd */
|
||||||
ret = rte_vfio_get_group_fd(groupid);
|
ret = rte_vfio_container_group_bind(vfio_container_fd, groupid);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
vfio_group.fd = ret;
|
vfio_group.fd = ret;
|
||||||
|
Loading…
Reference in New Issue
Block a user