Commit 12b2905a authored by Marc Zyngier's avatar Marc Zyngier

irqchip/gic-v3-its: Honor hypervisor enforced LPI range

A recent extension to the GIC architecture allows a hypervisor to
arbitrarily reduce the number of LPIs available to a guest, no
matter what the GIC says about the valid range of IntIDs.

Let's factor in this information when computing the number of
available LPIs
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent a4f9edb2
...@@ -1541,8 +1541,17 @@ static int free_lpi_range(u32 base, u32 nr_lpis) ...@@ -1541,8 +1541,17 @@ static int free_lpi_range(u32 base, u32 nr_lpis)
static int __init its_lpi_init(u32 id_bits) static int __init its_lpi_init(u32 id_bits)
{ {
u32 lpis = (1UL << id_bits) - 8192; u32 lpis = (1UL << id_bits) - 8192;
u32 numlpis;
int err; int err;
numlpis = 1UL << GICD_TYPER_NUM_LPIS(gic_rdists->gicd_typer);
if (numlpis > 2 && !WARN_ON(numlpis > lpis)) {
lpis = numlpis;
pr_info("ITS: Using hypervisor restricted LPI range [%u]\n",
lpis);
}
/* /*
* Initializing the allocator is just the same as freeing the * Initializing the allocator is just the same as freeing the
* full range of LPIs. * full range of LPIs.
......
...@@ -73,6 +73,7 @@ ...@@ -73,6 +73,7 @@
#define GICD_TYPER_MBIS (1U << 16) #define GICD_TYPER_MBIS (1U << 16)
#define GICD_TYPER_ID_BITS(typer) ((((typer) >> 19) & 0x1f) + 1) #define GICD_TYPER_ID_BITS(typer) ((((typer) >> 19) & 0x1f) + 1)
#define GICD_TYPER_NUM_LPIS(typer) ((((typer) >> 11) & 0x1f) + 1)
#define GICD_TYPER_IRQS(typer) ((((typer) & 0x1f) + 1) * 32) #define GICD_TYPER_IRQS(typer) ((((typer) & 0x1f) + 1) * 32)
#define GICD_IROUTER_SPI_MODE_ONE (0U << 31) #define GICD_IROUTER_SPI_MODE_ONE (0U << 31)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment