vfio/spapr: Move VFIO_CHECK_EXTENSION into tce_iommu_ioctl()
authorJason Gunthorpe <jgg@nvidia.com>
Mon, 5 Dec 2022 15:29:17 +0000 (11:29 -0400)
committerAlex Williamson <alex.williamson@redhat.com>
Mon, 5 Dec 2022 19:04:32 +0000 (12:04 -0700)
The PPC64 kconfig is a bit of a rats nest, but it turns out that if
CONFIG_SPAPR_TCE_IOMMU is on then EEH must be too:

config SPAPR_TCE_IOMMU
bool "sPAPR TCE IOMMU Support"
depends on PPC_POWERNV || PPC_PSERIES
select IOMMU_API
help
  Enables bits of IOMMU API required by VFIO. The iommu_ops
  is not implemented as it is not necessary for VFIO.

config PPC_POWERNV
select FORCE_PCI

config PPC_PSERIES
select FORCE_PCI

config EEH
bool
depends on (PPC_POWERNV || PPC_PSERIES) && PCI
default y

So, just open code the call to eeh_enabled() into tce_iommu_ioctl().

Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Cornelia Huck <cohuck@redhat.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Link: https://lore.kernel.org/r/2-v5-fc5346cacfd4+4c482-vfio_modules_jgg@nvidia.com
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
drivers/vfio/vfio_iommu_spapr_tce.c
drivers/vfio/vfio_spapr_eeh.c

index 169f07ac162d9c9520eefa47674591a820ca97eb..73cec2beae70b18762d86aebf18f13fa50e09ae2 100644 (file)
@@ -785,14 +785,12 @@ static long tce_iommu_ioctl(void *iommu_data,
                switch (arg) {
                case VFIO_SPAPR_TCE_IOMMU:
                case VFIO_SPAPR_TCE_v2_IOMMU:
-                       ret = 1;
-                       break;
+                       return 1;
+               case VFIO_EEH:
+                       return eeh_enabled();
                default:
-                       ret = vfio_spapr_iommu_eeh_ioctl(NULL, cmd, arg);
-                       break;
+                       return 0;
                }
-
-               return (ret < 0) ? 0 : ret;
        }
 
        /*
index c9d102aafbcd11167bdabef5412318c9ff496de6..221b1b637e18b0f7f03e7510b0b42305e10da9f4 100644 (file)
@@ -24,12 +24,6 @@ long vfio_spapr_iommu_eeh_ioctl(struct iommu_group *group,
        long ret = -EINVAL;
 
        switch (cmd) {
-       case VFIO_CHECK_EXTENSION:
-               if (arg == VFIO_EEH)
-                       ret = eeh_enabled() ? 1 : 0;
-               else
-                       ret = 0;
-               break;
        case VFIO_EEH_PE_OP:
                pe = eeh_iommu_group_to_pe(group);
                if (!pe)