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

[Xen-devel] [PATCH 4/4] HVM save/restore clean up: enable 64 guest on 64 HV



[PATCH 4/4] HVM save/restore clean up: enable 64 guest on 64 HV

Signed-off-by: Zhai Edwin <edwin.zhai@xxxxxxxxx>

remove the assumption that sh_update_paging_modes only occur on current vcpu.
64b guest can be save/restored on 64b HV with this.
need reconsider it for security.

diff -r a4373c8e7e2d xen/arch/x86/mm/shadow/common.c
--- a/xen/arch/x86/mm/shadow/common.c   Fri Jan 19 19:40:12 2007 +0800
+++ b/xen/arch/x86/mm/shadow/common.c   Fri Jan 19 19:42:42 2007 +0800
@@ -2575,8 +2575,6 @@ static void sh_update_paging_modes(struc
                                   "this HVM vcpu's (d=%u v=%u) paging mode!\n",
                                   current->domain->domain_id, current->vcpu_id,
                                   v->domain->domain_id, v->vcpu_id);
-                    domain_crash(v->domain);
-                    return;
                 }
 
                 old_mfn = pagetable_get_mfn(v->arch.monitor_table);
@@ -2590,7 +2588,8 @@ static void sh_update_paging_modes(struc
                  * pull it down!  Switch CR3, and warn the HVM code that
                  * its host cr3 has changed. */
                 make_cr3(v, mfn_x(new_mfn));
-                write_ptbase(v);
+                if ( v == current )
+                    write_ptbase(v);
                 hvm_update_host_cr3(v);
                 old_mode->destroy_monitor_table(v, old_mfn);
             }

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


 


Rackspace

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