summaryrefslogtreecommitdiff
path: root/drivers/pci/intel-iommu.c
diff options
context:
space:
mode:
authorDavid Woodhouse <David.Woodhouse@intel.com>2009-06-29 22:06:43 +0100
committerDavid Woodhouse <David.Woodhouse@intel.com>2009-06-30 03:55:21 +0100
commit1bf20f0dc5629032ddd07617139d9fbca66c1642 (patch)
tree6911bea8e9333ea7ed36ad4bc7a2c6001000e41d /drivers/pci/intel-iommu.c
parent9051aa0268dc1c3e42cd79a802b0af1f2bfcadae (diff)
downloadlwn-1bf20f0dc5629032ddd07617139d9fbca66c1642.tar.gz
lwn-1bf20f0dc5629032ddd07617139d9fbca66c1642.zip
intel-iommu: dump mappings but don't die on pte already set
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Diffstat (limited to 'drivers/pci/intel-iommu.c')
-rw-r--r--drivers/pci/intel-iommu.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/drivers/pci/intel-iommu.c b/drivers/pci/intel-iommu.c
index 14308533b1cb..40ce5a03f18f 100644
--- a/drivers/pci/intel-iommu.c
+++ b/drivers/pci/intel-iommu.c
@@ -1673,7 +1673,16 @@ static int __domain_mapping(struct dmar_domain *domain, unsigned long iov_pfn,
/* We don't need lock here, nobody else
* touches the iova range
*/
- BUG_ON(dma_pte_addr(pte));
+ if (unlikely(dma_pte_addr(pte))) {
+ static int dumps = 5;
+ printk(KERN_CRIT "ERROR: DMA PTE for vPFN 0x%lx already set (to %llx)\n",
+ iov_pfn, pte->val);
+ if (dumps) {
+ dumps--;
+ debug_dma_dump_mappings(NULL);
+ }
+ WARN_ON(1);
+ }
pte->val = pteval;
pte++;
if (!nr_pages ||