|
@@ -51,6 +51,22 @@ static struct vfio_group *kvm_vfio_group_get_external_user(struct file *filep)
|
|
|
return vfio_group;
|
|
|
}
|
|
|
|
|
|
+static bool kvm_vfio_external_group_match_file(struct vfio_group *group,
|
|
|
+ struct file *filep)
|
|
|
+{
|
|
|
+ bool ret, (*fn)(struct vfio_group *, struct file *);
|
|
|
+
|
|
|
+ fn = symbol_get(vfio_external_group_match_file);
|
|
|
+ if (!fn)
|
|
|
+ return false;
|
|
|
+
|
|
|
+ ret = fn(group, filep);
|
|
|
+
|
|
|
+ symbol_put(vfio_external_group_match_file);
|
|
|
+
|
|
|
+ return ret;
|
|
|
+}
|
|
|
+
|
|
|
static void kvm_vfio_group_put_external_user(struct vfio_group *vfio_group)
|
|
|
{
|
|
|
void (*fn)(struct vfio_group *);
|
|
@@ -231,18 +247,13 @@ static int kvm_vfio_set_group(struct kvm_device *dev, long attr, u64 arg)
|
|
|
if (!f.file)
|
|
|
return -EBADF;
|
|
|
|
|
|
- vfio_group = kvm_vfio_group_get_external_user(f.file);
|
|
|
- fdput(f);
|
|
|
-
|
|
|
- if (IS_ERR(vfio_group))
|
|
|
- return PTR_ERR(vfio_group);
|
|
|
-
|
|
|
ret = -ENOENT;
|
|
|
|
|
|
mutex_lock(&kv->lock);
|
|
|
|
|
|
list_for_each_entry(kvg, &kv->group_list, node) {
|
|
|
- if (kvg->vfio_group != vfio_group)
|
|
|
+ if (!kvm_vfio_external_group_match_file(kvg->vfio_group,
|
|
|
+ f.file))
|
|
|
continue;
|
|
|
|
|
|
list_del(&kvg->node);
|
|
@@ -260,7 +271,7 @@ static int kvm_vfio_set_group(struct kvm_device *dev, long attr, u64 arg)
|
|
|
|
|
|
mutex_unlock(&kv->lock);
|
|
|
|
|
|
- kvm_vfio_group_put_external_user(vfio_group);
|
|
|
+ fdput(f);
|
|
|
|
|
|
kvm_vfio_update_coherency(dev);
|
|
|
|