aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/xen
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/xen')
-rw-r--r--drivers/xen/events.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/xen/events.c b/drivers/xen/events.c
index 239b011ef56f..32269bcbd88c 100644
--- a/drivers/xen/events.c
+++ b/drivers/xen/events.c
@@ -623,7 +623,8 @@ int xen_map_pirq_gsi(unsigned pirq, unsigned gsi, int shareable, char *name)
623 623
624 /* If we are a PV guest, we don't have GSIs (no ACPI passed). Therefore 624 /* If we are a PV guest, we don't have GSIs (no ACPI passed). Therefore
625 * we are using the !xen_initial_domain() to drop in the function.*/ 625 * we are using the !xen_initial_domain() to drop in the function.*/
626 if (identity_mapped_irq(gsi) || !xen_initial_domain()) { 626 if (identity_mapped_irq(gsi) || (!xen_initial_domain() &&
627 xen_pv_domain())) {
627 irq = gsi; 628 irq = gsi;
628 irq_alloc_desc_at(irq, 0); 629 irq_alloc_desc_at(irq, 0);
629 } else 630 } else
@@ -1397,6 +1398,9 @@ void __init xen_init_IRQ(void)
1397 if (xen_hvm_domain()) { 1398 if (xen_hvm_domain()) {
1398 xen_callback_vector(); 1399 xen_callback_vector();
1399 native_init_IRQ(); 1400 native_init_IRQ();
1401 /* pci_xen_hvm_init must be called after native_init_IRQ so that
1402 * __acpi_register_gsi can point at the right function */
1403 pci_xen_hvm_init();
1400 } else { 1404 } else {
1401 irq_ctx_init(smp_processor_id()); 1405 irq_ctx_init(smp_processor_id());
1402 } 1406 }