vfio/spapr: Use iommu memory region's get_attr()
In order to enable TCE operations support in KVM, we have to inform the KVM about VFIO groups being attached to specific LIOBNs. The KVM already knows about VFIO groups, the only bit missing is which in-kernel TCE table (the one with user visible TCEs) should update the attached broups. There is an KVM_DEV_VFIO_GROUP_SET_SPAPR_TCE attribute of the VFIO KVM device which receives a groupfd/tablefd couple. This uses a new memory_region_iommu_get_attr() helper to get the IOMMU fd and calls KVM to establish the link. As get_attr() is not implemented yet, this should cause no behavioural change. Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru> Acked-by: Paolo Bonzini <pbonzini@redhat.com> Acked-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
This commit is contained in:
parent
f1334de60b
commit
07bc681a33
@ -457,6 +457,33 @@ static void vfio_listener_region_add(MemoryListener *listener,
|
|||||||
vfio_host_win_add(container, section->offset_within_address_space,
|
vfio_host_win_add(container, section->offset_within_address_space,
|
||||||
section->offset_within_address_space +
|
section->offset_within_address_space +
|
||||||
int128_get64(section->size) - 1, pgsize);
|
int128_get64(section->size) - 1, pgsize);
|
||||||
|
#ifdef CONFIG_KVM
|
||||||
|
if (kvm_enabled()) {
|
||||||
|
VFIOGroup *group;
|
||||||
|
IOMMUMemoryRegion *iommu_mr = IOMMU_MEMORY_REGION(section->mr);
|
||||||
|
struct kvm_vfio_spapr_tce param;
|
||||||
|
struct kvm_device_attr attr = {
|
||||||
|
.group = KVM_DEV_VFIO_GROUP,
|
||||||
|
.attr = KVM_DEV_VFIO_GROUP_SET_SPAPR_TCE,
|
||||||
|
.addr = (uint64_t)(unsigned long)¶m,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!memory_region_iommu_get_attr(iommu_mr, IOMMU_ATTR_SPAPR_TCE_FD,
|
||||||
|
¶m.tablefd)) {
|
||||||
|
QLIST_FOREACH(group, &container->group_list, container_next) {
|
||||||
|
param.groupfd = group->fd;
|
||||||
|
if (ioctl(vfio_kvm_device_fd, KVM_SET_DEVICE_ATTR, &attr)) {
|
||||||
|
error_report("vfio: failed to setup fd %d "
|
||||||
|
"for a group with fd %d: %s",
|
||||||
|
param.tablefd, param.groupfd,
|
||||||
|
strerror(errno));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
trace_vfio_spapr_group_attach(param.groupfd, param.tablefd);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
hostwin_found = false;
|
hostwin_found = false;
|
||||||
|
@ -123,3 +123,4 @@ vfio_prereg_register(uint64_t va, uint64_t size, int ret) "va=0x%"PRIx64" size=0
|
|||||||
vfio_prereg_unregister(uint64_t va, uint64_t size, int ret) "va=0x%"PRIx64" size=0x%"PRIx64" ret=%d"
|
vfio_prereg_unregister(uint64_t va, uint64_t size, int ret) "va=0x%"PRIx64" size=0x%"PRIx64" ret=%d"
|
||||||
vfio_spapr_create_window(int ps, uint64_t ws, uint64_t off) "pageshift=0x%x winsize=0x%"PRIx64" offset=0x%"PRIx64
|
vfio_spapr_create_window(int ps, uint64_t ws, uint64_t off) "pageshift=0x%x winsize=0x%"PRIx64" offset=0x%"PRIx64
|
||||||
vfio_spapr_remove_window(uint64_t off) "offset=0x%"PRIx64
|
vfio_spapr_remove_window(uint64_t off) "offset=0x%"PRIx64
|
||||||
|
vfio_spapr_group_attach(int groupfd, int tablefd) "Attached groupfd %d to liobn fd %d"
|
||||||
|
Loading…
Reference in New Issue
Block a user