};
struct xgene_msi {
- struct device_node *node;
struct irq_domain *inner_domain;
u64 msi_addr;
void __iomem *msi_regs;
unsigned long *bitmap;
struct mutex bitmap_lock;
struct xgene_msi_group *msi_groups;
- int num_cpus;
};
/* Global data */
*/
static int hwirq_to_cpu(unsigned long hwirq)
{
- return (hwirq % xgene_msi_ctrl.num_cpus);
+ return (hwirq % num_possible_cpus());
}
static unsigned long hwirq_to_canonical_hwirq(unsigned long hwirq)
mutex_lock(&msi->bitmap_lock);
msi_irq = bitmap_find_next_zero_area(msi->bitmap, NR_MSI_VEC, 0,
- msi->num_cpus, 0);
+ num_possible_cpus(), 0);
if (msi_irq < NR_MSI_VEC)
- bitmap_set(msi->bitmap, msi_irq, msi->num_cpus);
+ bitmap_set(msi->bitmap, msi_irq, num_possible_cpus());
else
msi_irq = -ENOSPC;
mutex_lock(&msi->bitmap_lock);
hwirq = hwirq_to_canonical_hwirq(d->hwirq);
- bitmap_clear(msi->bitmap, hwirq, msi->num_cpus);
+ bitmap_clear(msi->bitmap, hwirq, num_possible_cpus());
mutex_unlock(&msi->bitmap_lock);
.init_dev_msi_info = msi_lib_init_dev_msi_info,
};
-static int xgene_allocate_domains(struct xgene_msi *msi)
+static int xgene_allocate_domains(struct device_node *node,
+ struct xgene_msi *msi)
{
struct irq_domain_info info = {
- .fwnode = of_fwnode_handle(msi->node),
+ .fwnode = of_fwnode_handle(node),
.ops = &xgene_msi_domain_ops,
.size = NR_MSI_VEC,
.host_data = msi,
int i;
int err;
- for (i = cpu; i < NR_HW_IRQS; i += msi->num_cpus) {
+ for (i = cpu; i < NR_HW_IRQS; i += num_possible_cpus()) {
msi_group = &msi->msi_groups[i];
/*
struct xgene_msi_group *msi_group;
int i;
- for (i = cpu; i < NR_HW_IRQS; i += msi->num_cpus) {
+ for (i = cpu; i < NR_HW_IRQS; i += num_possible_cpus()) {
msi_group = &msi->msi_groups[i];
irq_set_chained_handler_and_data(msi_group->gic_irq, NULL,
NULL);
goto error;
}
xgene_msi->msi_addr = res->start;
- xgene_msi->node = pdev->dev.of_node;
- xgene_msi->num_cpus = num_possible_cpus();
rc = xgene_msi_init_allocator(xgene_msi);
if (rc) {
goto error;
}
- rc = xgene_allocate_domains(xgene_msi);
+ rc = xgene_allocate_domains(dev_of_node(&pdev->dev), xgene_msi);
if (rc) {
dev_err(&pdev->dev, "Failed to allocate MSI domain\n");
goto error;