diff options
| -rw-r--r-- | drivers/irqchip/irq-gic-v3-its.c | 9 | 
1 files changed, 4 insertions, 5 deletions
| diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index 94b7d74d519f..2cbb19cddbf8 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -1412,7 +1412,7 @@ static struct irq_chip its_irq_chip = {   * This gives us (((1UL << id_bits) - 8192) >> 5) possible allocations.   */  #define IRQS_PER_CHUNK_SHIFT	5 -#define IRQS_PER_CHUNK		(1 << IRQS_PER_CHUNK_SHIFT) +#define IRQS_PER_CHUNK		(1UL << IRQS_PER_CHUNK_SHIFT)  #define ITS_MAX_LPI_NRBITS	16 /* 64K LPIs */  static unsigned long *lpi_bitmap; @@ -2119,11 +2119,10 @@ static struct its_device *its_create_device(struct its_node *its, u32 dev_id,  	dev = kzalloc(sizeof(*dev), GFP_KERNEL);  	/* -	 * At least one bit of EventID is being used, hence a minimum -	 * of two entries. No, the architecture doesn't let you -	 * express an ITT with a single entry. +	 * We allocate at least one chunk worth of LPIs bet device, +	 * and thus that many ITEs. The device may require less though.  	 */ -	nr_ites = max(2UL, roundup_pow_of_two(nvecs)); +	nr_ites = max(IRQS_PER_CHUNK, roundup_pow_of_two(nvecs));  	sz = nr_ites * its->ite_size;  	sz = max(sz, ITS_ITT_ALIGN) + ITS_ITT_ALIGN - 1;  	itt = kzalloc(sz, GFP_KERNEL); | 
