[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-ia64-devel] Protection key support for PV domains
On Wed, Jul 11, 2007 at 03:52:15PM +0200, Dietmar Hahn wrote: > diff -r 87b0b6a08dbd -r 44ccb8aa58cc xen/include/public/arch-ia64.h > --- a/xen/include/public/arch-ia64.h Mon Jul 9 09:22:58 2007 -0600 > +++ b/xen/include/public/arch-ia64.h Wed Jul 11 15:37:09 2007 +0200 > @@ -236,7 +236,9 @@ struct mapped_regs { > int banknum; // 0 or 1, which virtual register bank is active > unsigned long rrs[8]; // region registers > unsigned long krs[8]; // kernel registers > +#if !defined(CONFIG_XEN_IA64_USE_PKR) > unsigned long pkrs[8]; // protection key registers > +#endif > unsigned long tmp[8]; // temp registers (e.g. for hyperprivops) > }; > }; struct mapped_regs is a part of ABI beween hypervisor and guest os so that the layout shouldn't be changed depending on configuration. Since there is no user of pkrs currently, eliminating pkrs[8]; or replacing pkrs[8];tmp[8]; with tmp[16]; or somethine like that would be fine. > A later step would be: > 8. extend the hyperprivops with setting protection key registers. I'm not sure how you want to update pkrs and its performance impact, though. If you want to paravirtualize pkrs related operation, would it be convinient to place pkrs[] in struct mapped_regs? Then guest OS can read/write the value without vmm intervention. Off course after updating those values it is necessary to call VMM to commit it. -- yamahata _______________________________________________ Xen-ia64-devel mailing list Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-ia64-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |