]> xenbits.xensource.com Git - people/dariof/xen.git/commitdiff
xen/arm: GICv3: Only initialize ITS when the distributor supports LPIs.
authorJulien Grall <julien.grall@linaro.org>
Wed, 24 Jan 2018 18:26:16 +0000 (18:26 +0000)
committerStefano Stabellini <sstabellini@kernel.org>
Tue, 30 Jan 2018 17:56:30 +0000 (09:56 -0800)
There are firmware tables out describing the ITS but does not support
LPIs. This will result to a data abort when trying to initialize ITS.

While this can be consider a bug in the Device-Tree, same configuration
boots on Linux. So gate the ITS initialization with the support of LPIs
in the distributor.

Signed-off-by: Julien Grall <julien.grall@linaro.org>
Reviewed-by: Stefano Stabellini <sstabellini@kernel.org>
xen/arch/arm/gic-v3.c

index 9f9cf59f82c12785c711a93378de0ee4c05fab2b..730450e34b7695ea889dd9a6d4e31d07b7dd5a7e 100644 (file)
@@ -1637,6 +1637,11 @@ static unsigned long gicv3_get_hwdom_extra_madt_size(const struct domain *d)
 }
 #endif
 
+static bool gic_dist_supports_lpis(void)
+{
+    return (readl_relaxed(GICD + GICD_TYPER) & GICD_TYPE_LPIS);
+}
+
 /* Set up the GIC */
 static int __init gicv3_init(void)
 {
@@ -1699,9 +1704,12 @@ static int __init gicv3_init(void)
 
     gicv3_dist_init();
 
-    res = gicv3_its_init();
-    if ( res )
-        panic("GICv3: ITS: initialization failed: %d\n", res);
+    if ( gic_dist_supports_lpis() )
+    {
+        res = gicv3_its_init();
+        if ( res )
+            panic("GICv3: ITS: initialization failed: %d\n", res);
+    }
 
     res = gicv3_cpu_init();
     if ( res )