[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-changelog] [xen-unstable] x86: Fix fatal page fault when vram dirty logic handles MMIO of passthrough devices.



# HG changeset patch
# User Keir Fraser <keir.fraser@xxxxxxxxxx>
# Date 1210582861 -3600
# Node ID 14d362d5fa5913a2e917cdd0ca90cf3b898a45d7
# Parent  810d8c3ac992e8979abb2e60cac5cef5ed6ccb36
x86: Fix fatal page fault when vram dirty logic handles MMIO of passthrough 
devices.

Signed-off-by: Qing He <qing.he@xxxxxxxxx>
---
 xen/arch/x86/mm/shadow/multi.c |    6 ++++++
 1 files changed, 6 insertions(+)

diff -r 810d8c3ac992 -r 14d362d5fa59 xen/arch/x86/mm/shadow/multi.c
--- a/xen/arch/x86/mm/shadow/multi.c    Thu May 08 16:58:33 2008 +0100
+++ b/xen/arch/x86/mm/shadow/multi.c    Mon May 12 10:01:01 2008 +0100
@@ -1268,6 +1268,9 @@ static inline void shadow_vram_get_l1e(s
     if ( !d->dirty_vram ) return;
 
     mfn = shadow_l1e_get_mfn(new_sl1e);
+
+    if ( !mfn_valid(mfn) ) return; /* m2p for mmio_direct may not exist */
+
     gfn = mfn_to_gfn(d, mfn);
 
     if ( (gfn >= d->dirty_vram->begin_pfn) && (gfn < d->dirty_vram->end_pfn) ) 
{
@@ -1293,6 +1296,9 @@ static inline void shadow_vram_put_l1e(s
     if ( !d->dirty_vram ) return;
 
     mfn = shadow_l1e_get_mfn(old_sl1e);
+
+    if ( !mfn_valid(mfn) ) return;
+
     gfn = mfn_to_gfn(d, mfn);
 
     if ( (gfn >= d->dirty_vram->begin_pfn) && (gfn < d->dirty_vram->end_pfn) ) 
{

_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.