aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/xen
diff options
context:
space:
mode:
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>2010-06-24 12:50:18 -0400
committerStefano Stabellini <stefano.stabellini@eu.citrix.com>2010-10-22 16:25:42 -0400
commit3942b740e5183caad47a4a3fcb37a4509ce7af83 (patch)
tree7051ecaaca2eadbc68743b4697add53f64d9401d /drivers/xen
parent90f6881e6430ea7b38b9e0f9837719b1935616e0 (diff)
xen: support GSI -> pirq remapping in PV on HVM guests
Disable pcifront when running on HVM: it is meant to be used with pv guests that don't have PCI bus. Use acpi_register_gsi_xen_hvm to remap GSIs into pirqs. Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> Reviewed-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
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 }