>From 3898ee02c07054af2867ed49cd7973016aab2132 Mon Sep 17 00:00:00 2001
From: Weidong Han <[EMAIL PROTECTED]>
Date: Mon, 23 Jun 2008 16:45:56 +0800
Subject: [PATCH] Check if context mapping succeed or not

If context mapping fails, return error. And also, don't need to restore
back host linux iommu domain for detached device in
kvm_iommu_unmap_guest().

Signed-off-by: Weidong Han <[EMAIL PROTECTED]>
---
 arch/x86/kvm/vtd.c |   18 +++++++-----------
 1 files changed, 7 insertions(+), 11 deletions(-)

diff --git a/arch/x86/kvm/vtd.c b/arch/x86/kvm/vtd.c
index be775cd..7bbd353 100644
--- a/arch/x86/kvm/vtd.c
+++ b/arch/x86/kvm/vtd.c
@@ -104,12 +104,17 @@ found:
                printk(KERN_ERR "kvm_iommu_map_guest: domain ==
NULL\n");
        else
                printk("kvm_iommu_map_guest: domain = %p\n",
kvm->arch.domain);
-               
+
        if (kvm_iommu_map_memslots(kvm)) {
                kvm_iommu_unmap_memslots(kvm);
                return -EFAULT;
        }
-       kvm_intel_iommu_context_mapping(kvm->arch.domain, pdev);
+
+       if (kvm_intel_iommu_context_mapping(kvm->arch.domain, pdev)) {
+               printk(KERN_ERR "Domain context map for %s failed",
+                      pci_name(pdev));
+               return -EFAULT;
+       }
        return 0;
 }
 EXPORT_SYMBOL_GPL(kvm_iommu_map_guest);
@@ -153,7 +158,6 @@ static int kvm_iommu_unmap_memslots(struct kvm *kvm)
 
 int kvm_iommu_unmap_guest(struct kvm *kvm)
 {
-       struct dmar_domain *domain;
        struct kvm_pci_pt_dev_list *entry;
        struct pci_dev *pdev = NULL;
 
@@ -181,14 +185,6 @@ found:
                /* detach kvm dmar domain */
                kvm_intel_iommu_detach_dev(kvm->arch.domain,
                                pdev->bus->number, pdev->devfn);
-
-               /* now restore back linux iommu domain */
-               domain = kvm_intel_iommu_find_domain(pdev);
-               if (domain)
-                       kvm_intel_iommu_context_mapping(domain, pdev);
-               else
-                       printk(KERN_DEBUG
-                               "kvm_iommu_unmap_guest: domain ==
NULL\n");
        }
        kvm_iommu_unmap_memslots(kvm);
        kvm_intel_iommu_domain_exit(kvm->arch.domain);
-- 
1.5.1
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to