Skip to content

Commit cdbc723

Browse files
jgunthorpejoergroedel
authored andcommitted
acpi: Do not return struct iommu_ops from acpi_iommu_configure_id()
Nothing needs this pointer. Return a normal error code with the usual IOMMU semantic that ENODEV means 'there is no IOMMU driver'. Acked-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Reviewed-by: Jerry Snitselaar <jsnitsel@redhat.com> Reviewed-by: Lu Baolu <baolu.lu@linux.intel.com> Reviewed-by: Moritz Fischer <moritzf@google.com> Tested-by: Hector Martin <marcan@marcan.st> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com> Link: https://lore.kernel.org/r/6-v2-16e4def25ebb+820-iommu_fwspec_p1_jgg@nvidia.com Signed-off-by: Joerg Roedel <jroedel@suse.de>
1 parent eda1a94 commit cdbc723

1 file changed

Lines changed: 17 additions & 12 deletions

File tree

drivers/acpi/scan.c

Lines changed: 17 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -1562,8 +1562,7 @@ static inline const struct iommu_ops *acpi_iommu_fwspec_ops(struct device *dev)
15621562
return fwspec ? fwspec->ops : NULL;
15631563
}
15641564

1565-
static const struct iommu_ops *acpi_iommu_configure_id(struct device *dev,
1566-
const u32 *id_in)
1565+
static int acpi_iommu_configure_id(struct device *dev, const u32 *id_in)
15671566
{
15681567
int err;
15691568
const struct iommu_ops *ops;
@@ -1577,7 +1576,7 @@ static const struct iommu_ops *acpi_iommu_configure_id(struct device *dev,
15771576
ops = acpi_iommu_fwspec_ops(dev);
15781577
if (ops) {
15791578
mutex_unlock(&iommu_probe_device_lock);
1580-
return ops;
1579+
return 0;
15811580
}
15821581

15831582
err = iort_iommu_configure_id(dev, id_in);
@@ -1594,12 +1593,14 @@ static const struct iommu_ops *acpi_iommu_configure_id(struct device *dev,
15941593

15951594
/* Ignore all other errors apart from EPROBE_DEFER */
15961595
if (err == -EPROBE_DEFER) {
1597-
return ERR_PTR(err);
1596+
return err;
15981597
} else if (err) {
15991598
dev_dbg(dev, "Adding to IOMMU failed: %d\n", err);
1600-
return NULL;
1599+
return -ENODEV;
16011600
}
1602-
return acpi_iommu_fwspec_ops(dev);
1601+
if (!acpi_iommu_fwspec_ops(dev))
1602+
return -ENODEV;
1603+
return 0;
16031604
}
16041605

16051606
#else /* !CONFIG_IOMMU_API */
@@ -1611,10 +1612,9 @@ int acpi_iommu_fwspec_init(struct device *dev, u32 id,
16111612
return -ENODEV;
16121613
}
16131614

1614-
static const struct iommu_ops *acpi_iommu_configure_id(struct device *dev,
1615-
const u32 *id_in)
1615+
static int acpi_iommu_configure_id(struct device *dev, const u32 *id_in)
16161616
{
1617-
return NULL;
1617+
return -ENODEV;
16181618
}
16191619

16201620
#endif /* !CONFIG_IOMMU_API */
@@ -1628,7 +1628,7 @@ static const struct iommu_ops *acpi_iommu_configure_id(struct device *dev,
16281628
int acpi_dma_configure_id(struct device *dev, enum dev_dma_attr attr,
16291629
const u32 *input_id)
16301630
{
1631-
const struct iommu_ops *iommu;
1631+
int ret;
16321632

16331633
if (attr == DEV_DMA_NOT_SUPPORTED) {
16341634
set_dma_ops(dev, &dma_dummy_ops);
@@ -1637,10 +1637,15 @@ int acpi_dma_configure_id(struct device *dev, enum dev_dma_attr attr,
16371637

16381638
acpi_arch_dma_setup(dev);
16391639

1640-
iommu = acpi_iommu_configure_id(dev, input_id);
1641-
if (PTR_ERR(iommu) == -EPROBE_DEFER)
1640+
ret = acpi_iommu_configure_id(dev, input_id);
1641+
if (ret == -EPROBE_DEFER)
16421642
return -EPROBE_DEFER;
16431643

1644+
/*
1645+
* Historically this routine doesn't fail driver probing due to errors
1646+
* in acpi_iommu_configure_id()
1647+
*/
1648+
16441649
arch_setup_dma_ops(dev, 0, U64_MAX, attr == DEV_DMA_COHERENT);
16451650

16461651
return 0;

0 commit comments

Comments
 (0)