iommu/core: Convert iommu_found to iommu_present
[linux-2.6.git] / drivers / iommu / iommu.c
index c0afcd4..3529e34 100644 (file)
@@ -16,6 +16,7 @@
  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  */
 
+#include <linux/device.h>
 #include <linux/kernel.h>
 #include <linux/bug.h>
 #include <linux/types.h>
@@ -34,16 +35,56 @@ void register_iommu(struct iommu_ops *ops)
        iommu_ops = ops;
 }
 
-bool iommu_found(void)
+static void iommu_bus_init(struct bus_type *bus, struct iommu_ops *ops)
 {
-       return iommu_ops != NULL;
 }
-EXPORT_SYMBOL_GPL(iommu_found);
+
+/**
+ * bus_set_iommu - set iommu-callbacks for the bus
+ * @bus: bus.
+ * @ops: the callbacks provided by the iommu-driver
+ *
+ * This function is called by an iommu driver to set the iommu methods
+ * used for a particular bus. Drivers for devices on that bus can use
+ * the iommu-api after these ops are registered.
+ * This special function is needed because IOMMUs are usually devices on
+ * the bus itself, so the iommu drivers are not initialized when the bus
+ * is set up. With this function the iommu-driver can set the iommu-ops
+ * afterwards.
+ */
+int bus_set_iommu(struct bus_type *bus, struct iommu_ops *ops)
+{
+       if (bus->iommu_ops != NULL)
+               return -EBUSY;
+
+       bus->iommu_ops = ops;
+
+       /* Do IOMMU specific setup for this bus-type */
+       iommu_bus_init(bus, ops);
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(bus_set_iommu);
+
+bool iommu_present(struct bus_type *bus)
+{
+       if (bus->iommu_ops != NULL)
+               return true;
+       else
+               return iommu_ops != NULL;
+}
+EXPORT_SYMBOL_GPL(iommu_present);
 
 /**
  * iommu_set_fault_handler() - set a fault handler for an iommu domain
  * @domain: iommu domain
  * @handler: fault handler
+ *
+ * This function should be used by IOMMU users which want to be notified
+ * whenever an IOMMU fault happens.
+ *
+ * The fault handler itself should return 0 on success, and an appropriate
+ * error code otherwise.
  */
 void iommu_set_fault_handler(struct iommu_domain *domain,
                                        iommu_fault_handler_t handler)
@@ -52,16 +93,28 @@ void iommu_set_fault_handler(struct iommu_domain *domain,
 
        domain->handler = handler;
 }
+EXPORT_SYMBOL_GPL(iommu_set_fault_handler);
 
-struct iommu_domain *iommu_domain_alloc(void)
+struct iommu_domain *iommu_domain_alloc(struct bus_type *bus)
 {
        struct iommu_domain *domain;
+       struct iommu_ops *ops;
        int ret;
 
+       if (bus->iommu_ops)
+               ops = bus->iommu_ops;
+       else
+               ops = iommu_ops;
+
+       if (ops == NULL)
+               return NULL;
+
        domain = kmalloc(sizeof(*domain), GFP_KERNEL);
        if (!domain)
                return NULL;
 
+       domain->ops = ops;
+
        ret = iommu_ops->domain_init(domain);
        if (ret)
                goto out_free;