* [PATCH] x86/p2m-ept: Don't unmap the EPT pagetable while it is still in use
@ 2015-06-30 17:09 Andrew Cooper
2015-07-02 10:07 ` George Dunlap
0 siblings, 1 reply; 2+ messages in thread
From: Andrew Cooper @ 2015-06-30 17:09 UTC (permalink / raw)
To: Xen-devel
Cc: Kevin Tian, Jan Beulich, George Dunlap, Andrew Cooper, Eddie Dong,
Jun Nakajima
The call to iommu_pte_flush() between the two hunks uses &ept_entry->epte
which is a pointer into the mapped page.
It is eventually passed to `clflush` instruction which will suffer a pagefault
if the virtual mapping has fallen out of the TLB.
(XEN) ----[ Xen-4.5.0-xs102594-d x86_64 debug=y Not tainted ]----
(XEN) CPU: 7
(XEN) RIP: e008:[<ffff82d0801572f0>] cacheline_flush+0x4/0x9
<snip>
(XEN) Xen call trace:
(XEN) [<ffff82d0801572f0>] cacheline_flush+0x4/0x9
(XEN) [<ffff82d08014ffff>] __iommu_flush_cache+0x4a/0x6a
(XEN) [<ffff82d0801532e2>] iommu_pte_flush+0x2b/0xd5
(XEN) [<ffff82d0801f909a>] ept_set_entry+0x4bc/0x61f
(XEN) [<ffff82d0801f0c25>] p2m_set_entry+0xd1/0x112
(XEN) [<ffff82d0801f25b1>] clear_mmio_p2m_entry+0x1a0/0x200
(XEN) [<ffff82d0801f4aac>] unmap_mmio_regions+0x49/0x73
(XEN) [<ffff82d080106292>] do_domctl+0x15bd/0x1edb
(XEN) [<ffff82d080234fcb>] syscall_enter+0xeb/0x145
(XEN)
(XEN) Pagetable walk from ffff820040004ae0:
(XEN) L4[0x104] = 00000008668a5063 ffffffffffffffff
(XEN) L3[0x001] = 00000008668a3063 ffffffffffffffff
(XEN) L2[0x000] = 000000086689c063 ffffffffffffffff
(XEN) L1[0x004] = 000000056f078063 000000000007f678
(XEN)
(XEN) ****************************************
(XEN) Panic on CPU 7:
(XEN) FATAL PAGE FAULT
(XEN) [error_code=0000]
(XEN) Faulting linear address: ffff820040004ae0
(XEN) ****************************************
Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>
CC: Jan Beulich <JBeulich@suse.com>
CC: George Dunlap <george.dunlap@eu.citrix.com>
CC: Jun Nakajima <jun.nakajima@intel.com>
CC: Eddie Dong <eddie.dong@intel.com>
CC: Kevin Tian <kevin.tian@intel.com>
---
This needs backporting to all versions of Xen. ept_set_entry() has had this
bug since the very introduction of the EPT code (c/s e90bc46 in 2008)
---
xen/arch/x86/mm/p2m-ept.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/xen/arch/x86/mm/p2m-ept.c b/xen/arch/x86/mm/p2m-ept.c
index a28c6eb..a8737be 100644
--- a/xen/arch/x86/mm/p2m-ept.c
+++ b/xen/arch/x86/mm/p2m-ept.c
@@ -801,8 +801,6 @@ bool_t ept_handle_misconfig(uint64_t gpa)
p2m->max_mapped_pfn = gfn + (1UL << order) - 1;
out:
- unmap_domain_page(table);
-
if ( needs_sync != sync_off )
ept_sync_domain(p2m);
@@ -825,6 +823,8 @@ bool_t ept_handle_misconfig(uint64_t gpa)
}
}
+ unmap_domain_page(table);
+
/* Release the old intermediate tables, if any. This has to be the
last thing we do, after the ept_sync_domain() and removal
from the iommu tables, so as to avoid a potential
--
1.7.10.4
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH] x86/p2m-ept: Don't unmap the EPT pagetable while it is still in use
2015-06-30 17:09 [PATCH] x86/p2m-ept: Don't unmap the EPT pagetable while it is still in use Andrew Cooper
@ 2015-07-02 10:07 ` George Dunlap
0 siblings, 0 replies; 2+ messages in thread
From: George Dunlap @ 2015-07-02 10:07 UTC (permalink / raw)
To: Andrew Cooper, Xen-devel
Cc: Kevin Tian, Eddie Dong, Jun Nakajima, Jan Beulich
On 06/30/2015 06:09 PM, Andrew Cooper wrote:
> The call to iommu_pte_flush() between the two hunks uses &ept_entry->epte
> which is a pointer into the mapped page.
>
> It is eventually passed to `clflush` instruction which will suffer a pagefault
> if the virtual mapping has fallen out of the TLB.
>
> (XEN) ----[ Xen-4.5.0-xs102594-d x86_64 debug=y Not tainted ]----
> (XEN) CPU: 7
> (XEN) RIP: e008:[<ffff82d0801572f0>] cacheline_flush+0x4/0x9
> <snip>
> (XEN) Xen call trace:
> (XEN) [<ffff82d0801572f0>] cacheline_flush+0x4/0x9
> (XEN) [<ffff82d08014ffff>] __iommu_flush_cache+0x4a/0x6a
> (XEN) [<ffff82d0801532e2>] iommu_pte_flush+0x2b/0xd5
> (XEN) [<ffff82d0801f909a>] ept_set_entry+0x4bc/0x61f
> (XEN) [<ffff82d0801f0c25>] p2m_set_entry+0xd1/0x112
> (XEN) [<ffff82d0801f25b1>] clear_mmio_p2m_entry+0x1a0/0x200
> (XEN) [<ffff82d0801f4aac>] unmap_mmio_regions+0x49/0x73
> (XEN) [<ffff82d080106292>] do_domctl+0x15bd/0x1edb
> (XEN) [<ffff82d080234fcb>] syscall_enter+0xeb/0x145
> (XEN)
> (XEN) Pagetable walk from ffff820040004ae0:
> (XEN) L4[0x104] = 00000008668a5063 ffffffffffffffff
> (XEN) L3[0x001] = 00000008668a3063 ffffffffffffffff
> (XEN) L2[0x000] = 000000086689c063 ffffffffffffffff
> (XEN) L1[0x004] = 000000056f078063 000000000007f678
> (XEN)
> (XEN) ****************************************
> (XEN) Panic on CPU 7:
> (XEN) FATAL PAGE FAULT
> (XEN) [error_code=0000]
> (XEN) Faulting linear address: ffff820040004ae0
> (XEN) ****************************************
>
> Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>
> CC: Jan Beulich <JBeulich@suse.com>
> CC: George Dunlap <george.dunlap@eu.citrix.com>
> CC: Jun Nakajima <jun.nakajima@intel.com>
> CC: Eddie Dong <eddie.dong@intel.com>
> CC: Kevin Tian <kevin.tian@intel.com>
Reviewed-by: George Dunlap <george.dunlap@eu.citrix.com>
-George
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2015-07-02 10:07 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-06-30 17:09 [PATCH] x86/p2m-ept: Don't unmap the EPT pagetable while it is still in use Andrew Cooper
2015-07-02 10:07 ` George Dunlap
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.