Commit 5c6de3ea authored by Yi Liu's avatar Yi Liu Committed by Alex Williamson

vfio: Test kvm pointer in _vfio_device_get_kvm_safe()

This saves some lines when adding the kvm get logic for the vfio_device
cdev path.

This also renames _vfio_device_get_kvm_safe() to be vfio_device_get_kvm_safe().
Suggested-by: default avatarJason Gunthorpe <jgg@nvidia.com>
Reviewed-by: default avatarJason Gunthorpe <jgg@nvidia.com>
Tested-by: default avatarZhenzhong Duan <zhenzhong.duan@intel.com>
Tested-by: default avatarYanting Jiang <yanting.jiang@intel.com>
Signed-off-by: default avatarYi Liu <yi.l.liu@intel.com>
Link: https://lore.kernel.org/r/20230718135551.6592-20-yi.l.liu@intel.comSigned-off-by: default avatarAlex Williamson <alex.williamson@redhat.com>
parent 8b6f173a
...@@ -160,12 +160,7 @@ static int vfio_group_ioctl_set_container(struct vfio_group *group, ...@@ -160,12 +160,7 @@ static int vfio_group_ioctl_set_container(struct vfio_group *group,
static void vfio_device_group_get_kvm_safe(struct vfio_device *device) static void vfio_device_group_get_kvm_safe(struct vfio_device *device)
{ {
spin_lock(&device->group->kvm_ref_lock); spin_lock(&device->group->kvm_ref_lock);
if (!device->group->kvm) vfio_device_get_kvm_safe(device, device->group->kvm);
goto unlock;
_vfio_device_get_kvm_safe(device, device->group->kvm);
unlock:
spin_unlock(&device->group->kvm_ref_lock); spin_unlock(&device->group->kvm_ref_lock);
} }
......
...@@ -340,10 +340,10 @@ enum { vfio_noiommu = false }; ...@@ -340,10 +340,10 @@ enum { vfio_noiommu = false };
#endif #endif
#ifdef CONFIG_HAVE_KVM #ifdef CONFIG_HAVE_KVM
void _vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm); void vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm);
void vfio_device_put_kvm(struct vfio_device *device); void vfio_device_put_kvm(struct vfio_device *device);
#else #else
static inline void _vfio_device_get_kvm_safe(struct vfio_device *device, static inline void vfio_device_get_kvm_safe(struct vfio_device *device,
struct kvm *kvm) struct kvm *kvm)
{ {
} }
......
...@@ -373,7 +373,7 @@ void vfio_unregister_group_dev(struct vfio_device *device) ...@@ -373,7 +373,7 @@ void vfio_unregister_group_dev(struct vfio_device *device)
EXPORT_SYMBOL_GPL(vfio_unregister_group_dev); EXPORT_SYMBOL_GPL(vfio_unregister_group_dev);
#ifdef CONFIG_HAVE_KVM #ifdef CONFIG_HAVE_KVM
void _vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm) void vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm)
{ {
void (*pfn)(struct kvm *kvm); void (*pfn)(struct kvm *kvm);
bool (*fn)(struct kvm *kvm); bool (*fn)(struct kvm *kvm);
...@@ -381,6 +381,9 @@ void _vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm) ...@@ -381,6 +381,9 @@ void _vfio_device_get_kvm_safe(struct vfio_device *device, struct kvm *kvm)
lockdep_assert_held(&device->dev_set->lock); lockdep_assert_held(&device->dev_set->lock);
if (!kvm)
return;
pfn = symbol_get(kvm_put_kvm); pfn = symbol_get(kvm_put_kvm);
if (WARN_ON(!pfn)) if (WARN_ON(!pfn))
return; return;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment