]> xenbits.xensource.com Git - people/royger/xen.git/commitdiff
x86/HVM: make hvmemul_map_linear_addr() honor p2m_ioreq_server
authorJan Beulich <jbeulich@suse.com>
Thu, 15 Nov 2018 12:36:10 +0000 (13:36 +0100)
committerJan Beulich <jbeulich@suse.com>
Thu, 15 Nov 2018 12:36:10 +0000 (13:36 +0100)
Write accesses to p2m_ioreq_server pages should get redirected to the
emulator also when using the mapping approach. Extend the
p2m_is_discard_write() check there, and restrict both to the write
access case (this is just a latent bug as currently we go this route
only for write accesses).

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Paul Durrant <paul.durrant@citrix.com>
xen/arch/x86/hvm/emulate.c

index 9e7deaa6cd02f4e736aa677d3c52fa474d99bd82..e08524be49fc9c2d023e3d31c491d504e0b2e756 100644 (file)
@@ -613,10 +613,21 @@ static void *hvmemul_map_linear_addr(
 
         *mfn++ = page_to_mfn(page);
 
-        if ( p2m_is_discard_write(p2mt) )
+        if ( pfec & PFEC_write_access )
         {
-            err = ERR_PTR(~X86EMUL_OKAY);
-            goto out;
+            if ( p2m_is_discard_write(p2mt) )
+            {
+                err = ERR_PTR(~X86EMUL_OKAY);
+                goto out;
+            }
+
+            if ( p2mt == p2m_ioreq_server )
+            {
+                err = NULL;
+                goto out;
+            }
+
+            ASSERT(p2mt == p2m_ram_logdirty || !p2m_is_readonly(p2mt));
         }
     }