]> xenbits.xensource.com Git - people/tklengyel/xen.git/commitdiff
xen/iommu: Check if the IOMMU was initialized before tearing down
authorJulien Grall <jgrall@amazon.com>
Thu, 17 Dec 2020 12:27:21 +0000 (12:27 +0000)
committerJulien Grall <jgrall@amazon.com>
Wed, 17 Feb 2021 11:30:05 +0000 (11:30 +0000)
is_iommu_enabled() will return true even if the IOMMU has not been
initialized (e.g. the ops are not set).

In the case of an early failure in arch_domain_init(), the function
iommu_destroy_domain() will be called even if the IOMMU is not
initialized.

This will result to dereference the ops which will be NULL and an host
crash.

Fix the issue by checking that ops has been set before accessing it.

Fixes: 71e617a6b8f6 ("use is_iommu_enabled() where appropriate...")
Signed-off-by: Julien Grall <jgrall@amazon.com>
Reviewed-by: Paul Durrant <paul@xen.org>
xen/drivers/passthrough/iommu.c

index 2358b6eb09f49f5b48e5db672df39027062d00d7..879d238bcd318472e300079fc95fa67b6ae807bc 100644 (file)
@@ -221,6 +221,13 @@ static void iommu_teardown(struct domain *d)
 {
     struct domain_iommu *hd = dom_iommu(d);
 
+    /*
+     * During early domain creation failure, we may reach here with the
+     * ops not yet initialized.
+     */
+    if ( !hd->platform_ops )
+        return;
+
     iommu_vcall(hd->platform_ops, teardown, d);
 }