[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.2] IOMMU: generalize and correct softirq processing during Dom0 device setup
commit 83a20cab51bbedf48d45ca662cbde0a63f57fbb7 Author: Jan Beulich <jbeulich@xxxxxxxx> AuthorDate: Fri Mar 14 17:50:03 2014 +0100 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Fri Mar 14 17:50:03 2014 +0100 IOMMU: generalize and correct softirq processing during Dom0 device setup c/s 21039:95f5a4ce8f24 ("VT-d: reduce default verbosity") having put a call to process_pending_softirqs() in VT-d's domain_context_mapping() was wrong in two ways: For one we shouldn't be doing this when setting up a device during DomU assignment. And then - I didn't check whether that was the case already back then - we shouldn't call that function with the pcidevs_lock (or in fact any spin lock) held. Move the "preemption" into generic code, at once dealing with further actual (too much output elsewhere - particularly on systems with very many host bridge like devices - having been observed to still cause the watchdog to trigger when enabled) and potential (other IOMMU code may also end up being too verbose) issues. Do the "preemption" once per device actually being set up when in verbose mode, and once per bus otherwise. Note that dropping pcidevs_lock around the process_pending_softirqs() invocation is specifically not a problem here: We're in an __init function and aren't racing with potential additions/removals of PCI devices. Not acquiring the lock in setup_dom0_pci_devices() otoh is not an option, as there are too many places that assert the lock being held. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> Acked-by: Xiantao Zhang <xiantao.zhang@xxxxxxxxx> master commit: 9ef5aa944a6a0df7f5938983043c7e46f158bbc6 master date: 2014-03-04 10:52:20 +0100 --- xen/drivers/passthrough/pci.c | 15 +++++++++++++++ xen/drivers/passthrough/vtd/iommu.c | 4 ---- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/xen/drivers/passthrough/pci.c b/xen/drivers/passthrough/pci.c index 30515a9..00a7129 100644 --- a/xen/drivers/passthrough/pci.c +++ b/xen/drivers/passthrough/pci.c @@ -27,6 +27,7 @@ #include <xen/delay.h> #include <xen/keyhandler.h> #include <xen/radix-tree.h> +#include <xen/softirq.h> #include <xen/tasklet.h> #include <xsm/xsm.h> #ifdef CONFIG_X86 @@ -705,6 +706,20 @@ static int __init _setup_dom0_pci_devices(struct pci_seg *pseg, void *arg) pdev->domain = ctxt->d; list_add(&pdev->domain_list, &ctxt->d->arch.pdev_list); ctxt->handler(pdev); + + if ( iommu_verbose ) + { + spin_unlock(&pcidevs_lock); + process_pending_softirqs(); + spin_lock(&pcidevs_lock); + } + } + + if ( !iommu_verbose ) + { + spin_unlock(&pcidevs_lock); + process_pending_softirqs(); + spin_lock(&pcidevs_lock); } } diff --git a/xen/drivers/passthrough/vtd/iommu.c b/xen/drivers/passthrough/vtd/iommu.c index 709778b..8052a25 100644 --- a/xen/drivers/passthrough/vtd/iommu.c +++ b/xen/drivers/passthrough/vtd/iommu.c @@ -31,7 +31,6 @@ #include <xen/pci.h> #include <xen/pci_regs.h> #include <xen/keyhandler.h> -#include <xen/softirq.h> #include <asm/msi.h> #include <asm/irq.h> #if defined(__i386__) || defined(__x86_64__) @@ -1524,9 +1523,6 @@ static int domain_context_mapping( break; } - if ( iommu_verbose ) - process_pending_softirqs(); - return ret; } -- generated by git-patchbot for /home/xen/git/xen.git#stable-4.2 _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |