[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [PATCH] xen/arm: gicv3: initialize eSPI unconditionally
Since the firmware may initialize eSPIs before Xen, and without CONFIG_GICV3_ESPI enabled, Xen would not reinitialize them properly during boot. In such cases, once the GIC is re-enabled in Xen, interrupts may be received that cannot be handled. To ensure proper operation on hardware with eSPI feature, even when the eSPI config is disabled, gicv3_dist_espi_common_init() should be invoked regardless of whether CONFIG_GICV3_ESPI is enabled or not. This will not affect hardware without eSPI support, as the function checks if the hardware supports eSPIs by reading the GICD_TYPER.ESPI field (using GICD_TYPER_ESPIS_NUM macro), which indicates whether the extended SPI range is supported. If the hardware does not support eSPI, the function will not perform any actions. There are no functional changes for setups where CONFIG_GICV3_ESPI=y. Signed-off-by: Leonid Komarianskyi <leonid_komarianskyi@xxxxxxxx> Suggested-by: Julien Grall <jgrall@xxxxxxxxxx> --- This is a follow-up patch related to the discussion: https://lore.kernel.org/xen-devel/820704d0-4047-4f02-a058-01daba2765f1@xxxxxxx/ Since the idea for the patch was proposed by Julien, I added Suggested-by, if Julien does not mind. --- xen/arch/arm/gic-v3.c | 32 ++++++++++++++------------ xen/arch/arm/include/asm/gic_v3_defs.h | 2 -- 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/xen/arch/arm/gic-v3.c b/xen/arch/arm/gic-v3.c index bc07f97c16..19457bff76 100644 --- a/xen/arch/arm/gic-v3.c +++ b/xen/arch/arm/gic-v3.c @@ -699,17 +699,32 @@ unsigned int gic_number_espis(void) return gic_hw_ops->info->nr_espi; } +static void __init gicv3_dist_espi_init_aff(uint64_t affinity) +{ + unsigned int i; + + for ( i = 0; i < gicv3_info.nr_espi; i++ ) + writeq_relaxed_non_atomic(affinity, GICD + GICD_IROUTERnE + i * 8); +} +#else + +static void __init gicv3_dist_espi_init_aff(uint64_t affinity) { } +#endif + static void __init gicv3_dist_espi_common_init(uint32_t type) { unsigned int espi_nr, i; espi_nr = min(1024U, GICD_TYPER_ESPIS_NUM(type)); +#ifdef CONFIG_GICV3_ESPI gicv3_info.nr_espi = espi_nr; +#endif /* The GIC HW doesn't support eSPI, so we can leave from here */ - if ( gicv3_info.nr_espi == 0 ) + if ( espi_nr == 0 ) return; - printk("GICv3: %u eSPI lines\n", gicv3_info.nr_espi); + if ( IS_ENABLED(CONFIG_GICV3_ESPI) ) + printk("GICv3: %u eSPI lines\n", espi_nr); /* The configuration for eSPIs is similar to that for regular SPIs */ for ( i = 0; i < espi_nr; i += 16 ) @@ -729,19 +744,6 @@ static void __init gicv3_dist_espi_common_init(uint32_t type) writel_relaxed(GENMASK(31, 0), GICD + GICD_IGROUPRnE + (i / 32) * 4); } -static void __init gicv3_dist_espi_init_aff(uint64_t affinity) -{ - unsigned int i; - - for ( i = 0; i < gicv3_info.nr_espi; i++ ) - writeq_relaxed_non_atomic(affinity, GICD + GICD_IROUTERnE + i * 8); -} -#else -static void __init gicv3_dist_espi_common_init(uint32_t type) { } - -static void __init gicv3_dist_espi_init_aff(uint64_t affinity) { } -#endif - static void __init gicv3_dist_init(void) { uint32_t type; diff --git a/xen/arch/arm/include/asm/gic_v3_defs.h b/xen/arch/arm/include/asm/gic_v3_defs.h index c373b94d19..4b90627df6 100644 --- a/xen/arch/arm/include/asm/gic_v3_defs.h +++ b/xen/arch/arm/include/asm/gic_v3_defs.h @@ -63,7 +63,6 @@ #define GICD_IROUTERnE (0x8000) #define GICD_IROUTERnEN (0x9FFC) -#ifdef CONFIG_GICV3_ESPI #define GICD_TYPER_ESPI_SHIFT 8 #define GICD_TYPER_ESPI_RANGE_SHIFT 27 #define GICD_TYPER_ESPI_RANGE_MASK (0x1F) @@ -73,7 +72,6 @@ #define GICD_TYPER_ESPIS_NUM(typer) \ (((typer) & GICD_TYPER_ESPI) ? \ GICD_TYPER_ESPI_RANGE((typer) >> GICD_TYPER_ESPI_RANGE_SHIFT) : 0) -#endif /* Common between GICD_PIDR2 and GICR_PIDR2 */ #define GIC_PIDR2_ARCH_MASK (0xf0) -- 2.34.1
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |