aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorGrant Likely <grant.likely@secretlab.ca>2012-06-04 01:04:36 -0400
committerGrant Likely <grant.likely@secretlab.ca>2012-07-11 11:15:34 -0400
commit2a71a1a9da40dfbd5b23d4312aa1641385581f4a (patch)
tree9a246c0aa997d98acb9a931e10331468a3661ac0 /kernel
parent913af2070731bfc1bd39bb35c5cd2fd66f5eff12 (diff)
irqdomain: Always update revmap when setting up a virq
At irq_setup_virq() time all of the data needed to update the reverse map is available, but the current code ignores it and relies upon the slow path to insert revmap records. This patch adds revmap updating to the setup path so the slow path will no longer be necessary. Signed-off-by: Grant Likely <grant.likely@secretlab.ca> Cc: Paul Mundt <lethal@linux-sh.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Rob Herring <rob.herring@calxeda.com>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/irq/irqdomain.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/kernel/irq/irqdomain.c b/kernel/irq/irqdomain.c
index 17634f2c9f6c..091732c9dbdc 100644
--- a/kernel/irq/irqdomain.c
+++ b/kernel/irq/irqdomain.c
@@ -424,6 +424,18 @@ static int irq_setup_virq(struct irq_domain *domain, unsigned int virq,
424 return -1; 424 return -1;
425 } 425 }
426 426
427 switch (domain->revmap_type) {
428 case IRQ_DOMAIN_MAP_LINEAR:
429 if (hwirq < domain->revmap_data.linear.size)
430 domain->revmap_data.linear.revmap[hwirq] = virq;
431 break;
432 case IRQ_DOMAIN_MAP_TREE:
433 mutex_lock(&revmap_trees_mutex);
434 irq_radix_revmap_insert(domain, virq, hwirq);
435 mutex_unlock(&revmap_trees_mutex);
436 break;
437 }
438
427 irq_clear_status_flags(virq, IRQ_NOREQUEST); 439 irq_clear_status_flags(virq, IRQ_NOREQUEST);
428 440
429 return 0; 441 return 0;