xen: do not map the same GSI twice in PVHVM guests.
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>
Mon, 21 May 2012 15:54:10 +0000 (16:54 +0100)
committerBen Hutchings <ben@decadent.org.uk>
Wed, 30 May 2012 23:44:01 +0000 (00:44 +0100)
commit482953eeea949295981474e179d37fd61258d3ca
treeb2d56e673e88c9b92516c5d1f78b2d8279557ccb
parent22d3eb7b84cfd93141ddde38fcbabcd190eb5f1f
xen: do not map the same GSI twice in PVHVM guests.

commit 68c2c39a76b094e9b2773e5846424ea674bf2c46 upstream.

PV on HVM guests map GSIs into event channels. At restore time the
event channels are resumed by restore_pirqs.

Device drivers might try to register the same GSI again through ACPI at
restore time, but the GSI has already been mapped and bound by
restore_pirqs. This patch detects these situations and avoids
 mapping the same GSI multiple times.

Without this patch we get:
(XEN) irq.c:2235: dom4: pirq 23 or emuirq 28 already mapped
and waste a pirq.

Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
arch/x86/pci/xen.c
drivers/xen/events.c
include/xen/events.h