aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/xen
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2011-01-10 11:48:46 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2011-01-10 11:48:46 -0500
commit9f99a2f0e44663517b99b69a3e4a499d0ba877df (patch)
tree92bbe9f9c9c6687a49e13e4e1bfe2a29bc736476 /drivers/xen
parent8c8ae4e8cd5a67467192f3361eeec463694f8ed8 (diff)
parent110e7c7e4f8a61a34e0ab88fc9bdf4d5c6d220b2 (diff)
Merge branch 'stable/bug-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen
* 'stable/bug-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/xen: xen/event: validate irq before get evtchn by irq xen/fb: fix potential memory leak xen/fb: fix xenfb suspend/resume race. xen: disable ACPI NUMA for PV guests xen/irq: Cleanup the find_unbound_irq
Diffstat (limited to 'drivers/xen')
-rw-r--r--drivers/xen/events.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/drivers/xen/events.c b/drivers/xen/events.c
index 65f8637d13c..74681478100 100644
--- a/drivers/xen/events.c
+++ b/drivers/xen/events.c
@@ -170,6 +170,9 @@ static struct irq_info *info_for_irq(unsigned irq)
170 170
171static unsigned int evtchn_from_irq(unsigned irq) 171static unsigned int evtchn_from_irq(unsigned irq)
172{ 172{
173 if (unlikely(WARN(irq < 0 || irq >= nr_irqs, "Invalid irq %d!\n", irq)))
174 return 0;
175
173 return info_for_irq(irq)->evtchn; 176 return info_for_irq(irq)->evtchn;
174} 177}
175 178
@@ -405,15 +408,21 @@ static int find_unbound_irq(void)
405{ 408{
406 struct irq_data *data; 409 struct irq_data *data;
407 int irq, res; 410 int irq, res;
408 int start = get_nr_hw_irqs(); 411 int bottom = get_nr_hw_irqs();
412 int top = nr_irqs-1;
409 413
410 if (start == nr_irqs) 414 if (bottom == nr_irqs)
411 goto no_irqs; 415 goto no_irqs;
412 416
413 /* nr_irqs is a magic value. Must not use it.*/ 417 /* This loop starts from the top of IRQ space and goes down.
414 for (irq = nr_irqs-1; irq > start; irq--) { 418 * We need this b/c if we have a PCI device in a Xen PV guest
419 * we do not have an IO-APIC (though the backend might have them)
420 * mapped in. To not have a collision of physical IRQs with the Xen
421 * event channels start at the top of the IRQ space for virtual IRQs.
422 */
423 for (irq = top; irq > bottom; irq--) {
415 data = irq_get_irq_data(irq); 424 data = irq_get_irq_data(irq);
416 /* only 0->15 have init'd desc; handle irq > 16 */ 425 /* only 15->0 have init'd desc; handle irq > 16 */
417 if (!data) 426 if (!data)
418 break; 427 break;
419 if (data->chip == &no_irq_chip) 428 if (data->chip == &no_irq_chip)
@@ -424,7 +433,7 @@ static int find_unbound_irq(void)
424 return irq; 433 return irq;
425 } 434 }
426 435
427 if (irq == start) 436 if (irq == bottom)
428 goto no_irqs; 437 goto no_irqs;
429 438
430 res = irq_alloc_desc_at(irq, -1); 439 res = irq_alloc_desc_at(irq, -1);