Commit b7fd35a0 authored by Thomas Gleixner's avatar Thomas Gleixner
Browse files

Merge tag 'irqchip-fixes-5.16-2' of...

Merge tag 'irqchip-fixes-5.16-2' of git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms into irq/urgent

Pull irqchip fixes from Marc Zyngier:

 - Fix Armada-370-XP Multi-MSi allocation to be aligned on the allocation
   size, as required by the PCI spec

 - Fix aspeed-scu interrupt acknowledgement by directly writing to the
   register instead of a read-modify-write sequence

 - Use standard bitfirl helpers in the MIPS GIC driver instead of custom
   constructs

 - Fix the NVIC driver IPR register offset

 - Correctly drop the reference of the device node in the irq-bcm7120-l2
   driver

 - Fix the GICv3 ITS INVALL command by issueing a following SYNC command

 - Add a missing __init attribute to the init function of the Apple AIC
   driver

Link: https://lore.kernel.org/r/20211210133516.664497-1-maz@kernel.org
parents 0fcfb00b c3fbab77
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -707,7 +707,7 @@ static const struct irq_domain_ops aic_ipi_domain_ops = {
	.free = aic_ipi_free,
	.free = aic_ipi_free,
};
};


static int aic_init_smp(struct aic_irq_chip *irqc, struct device_node *node)
static int __init aic_init_smp(struct aic_irq_chip *irqc, struct device_node *node)
{
{
	struct irq_domain *ipi_domain;
	struct irq_domain *ipi_domain;
	int base_ipi;
	int base_ipi;
+6 −10
Original line number Original line Diff line number Diff line
@@ -232,16 +232,12 @@ static int armada_370_xp_msi_alloc(struct irq_domain *domain, unsigned int virq,
	int hwirq, i;
	int hwirq, i;


	mutex_lock(&msi_used_lock);
	mutex_lock(&msi_used_lock);

	hwirq = bitmap_find_free_region(msi_used, PCI_MSI_DOORBELL_NR,
	hwirq = bitmap_find_next_zero_area(msi_used, PCI_MSI_DOORBELL_NR,
					order_base_2(nr_irqs));
					   0, nr_irqs, 0);
	if (hwirq >= PCI_MSI_DOORBELL_NR) {
	mutex_unlock(&msi_used_lock);
	mutex_unlock(&msi_used_lock);
		return -ENOSPC;
	}


	bitmap_set(msi_used, hwirq, nr_irqs);
	if (hwirq < 0)
	mutex_unlock(&msi_used_lock);
		return -ENOSPC;


	for (i = 0; i < nr_irqs; i++) {
	for (i = 0; i < nr_irqs; i++) {
		irq_domain_set_info(domain, virq + i, hwirq + i,
		irq_domain_set_info(domain, virq + i, hwirq + i,
@@ -250,7 +246,7 @@ static int armada_370_xp_msi_alloc(struct irq_domain *domain, unsigned int virq,
				    NULL, NULL);
				    NULL, NULL);
	}
	}


	return hwirq;
	return 0;
}
}


static void armada_370_xp_msi_free(struct irq_domain *domain,
static void armada_370_xp_msi_free(struct irq_domain *domain,
@@ -259,7 +255,7 @@ static void armada_370_xp_msi_free(struct irq_domain *domain,
	struct irq_data *d = irq_domain_get_irq_data(domain, virq);
	struct irq_data *d = irq_domain_get_irq_data(domain, virq);


	mutex_lock(&msi_used_lock);
	mutex_lock(&msi_used_lock);
	bitmap_clear(msi_used, d->hwirq, nr_irqs);
	bitmap_release_region(msi_used, d->hwirq, order_base_2(nr_irqs));
	mutex_unlock(&msi_used_lock);
	mutex_unlock(&msi_used_lock);
}
}


+2 −2
Original line number Original line Diff line number Diff line
@@ -76,7 +76,7 @@ static void aspeed_scu_ic_irq_handler(struct irq_desc *desc)
		generic_handle_domain_irq(scu_ic->irq_domain,
		generic_handle_domain_irq(scu_ic->irq_domain,
					  bit - scu_ic->irq_shift);
					  bit - scu_ic->irq_shift);


		regmap_update_bits(scu_ic->scu, scu_ic->reg, mask,
		regmap_write_bits(scu_ic->scu, scu_ic->reg, mask,
				  BIT(bit + ASPEED_SCU_IC_STATUS_SHIFT));
				  BIT(bit + ASPEED_SCU_IC_STATUS_SHIFT));
	}
	}


+1 −0
Original line number Original line Diff line number Diff line
@@ -238,6 +238,7 @@ static int __init bcm7120_l2_intc_probe(struct device_node *dn,
	}
	}


	data->num_parent_irqs = platform_irq_count(pdev);
	data->num_parent_irqs = platform_irq_count(pdev);
	put_device(&pdev->dev);
	if (data->num_parent_irqs <= 0) {
	if (data->num_parent_irqs <= 0) {
		pr_err("invalid number of parent interrupts\n");
		pr_err("invalid number of parent interrupts\n");
		ret = -ENOMEM;
		ret = -ENOMEM;
+1 −1
Original line number Original line Diff line number Diff line
@@ -742,7 +742,7 @@ static struct its_collection *its_build_invall_cmd(struct its_node *its,


	its_fixup_cmd(cmd);
	its_fixup_cmd(cmd);


	return NULL;
	return desc->its_invall_cmd.col;
}
}


static struct its_vpe *its_build_vinvall_cmd(struct its_node *its,
static struct its_vpe *its_build_vinvall_cmd(struct its_node *its,
Loading