Skip to content

Commit 5eb20a7

Browse files
jgunthorpeAlex Williamson
authored andcommitted
drm/i915/gvt: Change from vfio_group_(un)pin_pages to vfio_(un)pin_pages
Use the existing vfio_device versions of vfio_(un)pin_pages(). There is no reason to use a group interface here, kvmgt has easy access to a vfio_device. Delete kvmgt_vdev::vfio_group since these calls were the last users. Reviewed-by: Kevin Tian <kevin.tian@intel.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com> Acked-by: Zhi Wang <zhi.a.wang@intel.com> Link: https://lore.kernel.org/r/5-v4-8045e76bf00b+13d-vfio_mdev_no_group_jgg@nvidia.com Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
1 parent c6250ff commit 5eb20a7

2 files changed

Lines changed: 6 additions & 22 deletions

File tree

drivers/gpu/drm/i915/gvt/gvt.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -231,7 +231,6 @@ struct intel_vgpu {
231231
struct kvm *kvm;
232232
struct work_struct release_work;
233233
atomic_t released;
234-
struct vfio_group *vfio_group;
235234

236235
struct kvm_page_track_notifier_node track_node;
237236
#define NR_BKT (1 << 18)

drivers/gpu/drm/i915/gvt/kvmgt.c

Lines changed: 6 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -243,7 +243,7 @@ static void gvt_unpin_guest_page(struct intel_vgpu *vgpu, unsigned long gfn,
243243
for (npage = 0; npage < total_pages; npage++) {
244244
unsigned long cur_gfn = gfn + npage;
245245

246-
ret = vfio_group_unpin_pages(vgpu->vfio_group, &cur_gfn, 1);
246+
ret = vfio_unpin_pages(&vgpu->vfio_device, &cur_gfn, 1);
247247
drm_WARN_ON(&i915->drm, ret != 1);
248248
}
249249
}
@@ -266,8 +266,8 @@ static int gvt_pin_guest_page(struct intel_vgpu *vgpu, unsigned long gfn,
266266
unsigned long cur_gfn = gfn + npage;
267267
unsigned long pfn;
268268

269-
ret = vfio_group_pin_pages(vgpu->vfio_group, &cur_gfn, 1,
270-
IOMMU_READ | IOMMU_WRITE, &pfn);
269+
ret = vfio_pin_pages(&vgpu->vfio_device, &cur_gfn, 1,
270+
IOMMU_READ | IOMMU_WRITE, &pfn);
271271
if (ret != 1) {
272272
gvt_vgpu_err("vfio_pin_pages failed for gfn 0x%lx, ret %d\n",
273273
cur_gfn, ret);
@@ -804,7 +804,6 @@ static int intel_vgpu_open_device(struct vfio_device *vfio_dev)
804804
struct intel_vgpu *vgpu = vfio_dev_to_vgpu(vfio_dev);
805805
unsigned long events;
806806
int ret;
807-
struct vfio_group *vfio_group;
808807

809808
vgpu->iommu_notifier.notifier_call = intel_vgpu_iommu_notifier;
810809
vgpu->group_notifier.notifier_call = intel_vgpu_group_notifier;
@@ -827,28 +826,19 @@ static int intel_vgpu_open_device(struct vfio_device *vfio_dev)
827826
goto undo_iommu;
828827
}
829828

830-
vfio_group =
831-
vfio_group_get_external_user_from_dev(vgpu->vfio_device.dev);
832-
if (IS_ERR_OR_NULL(vfio_group)) {
833-
ret = !vfio_group ? -EFAULT : PTR_ERR(vfio_group);
834-
gvt_vgpu_err("vfio_group_get_external_user_from_dev failed\n");
835-
goto undo_register;
836-
}
837-
vgpu->vfio_group = vfio_group;
838-
839829
ret = -EEXIST;
840830
if (vgpu->attached)
841-
goto undo_group;
831+
goto undo_register;
842832

843833
ret = -ESRCH;
844834
if (!vgpu->kvm || vgpu->kvm->mm != current->mm) {
845835
gvt_vgpu_err("KVM is required to use Intel vGPU\n");
846-
goto undo_group;
836+
goto undo_register;
847837
}
848838

849839
ret = -EEXIST;
850840
if (__kvmgt_vgpu_exist(vgpu))
851-
goto undo_group;
841+
goto undo_register;
852842

853843
vgpu->attached = true;
854844
kvm_get_kvm(vgpu->kvm);
@@ -868,10 +858,6 @@ static int intel_vgpu_open_device(struct vfio_device *vfio_dev)
868858
atomic_set(&vgpu->released, 0);
869859
return 0;
870860

871-
undo_group:
872-
vfio_group_put_external_user(vgpu->vfio_group);
873-
vgpu->vfio_group = NULL;
874-
875861
undo_register:
876862
vfio_unregister_notifier(vfio_dev, VFIO_GROUP_NOTIFY,
877863
&vgpu->group_notifier);
@@ -925,7 +911,6 @@ static void __intel_vgpu_release(struct intel_vgpu *vgpu)
925911
gvt_cache_destroy(vgpu);
926912

927913
intel_vgpu_release_msi_eventfd_ctx(vgpu);
928-
vfio_group_put_external_user(vgpu->vfio_group);
929914

930915
vgpu->kvm = NULL;
931916
vgpu->attached = false;

0 commit comments

Comments
 (0)