| Hi, 
At 17:38 -0400 on 20 Oct (1224524336), Emre Can Sezer wrote:
> For each LKM (guest kernel), I have a list of pages that belong to the
> LKM.  I pass this information to Xen with the pfn's of the pages.  So in
> Xen context these should be gfn's I guess. Is there an easy way to find
> the pte in the shadow page table associated with this guest page and
> modify it?
In general, no.  The shadow code uses some heuristics to guess at the
locations of PTEs for similar reasons but:
 - they are mostly based on the virtual address of a page fault; and
 - even if they work they only find _one_ such PTE. 
You would probably need to add some further mechanism for tracking these 
frames, because the fallback (brute-force search of all shadow L1
tables) is expensive. 
In addition, unless you modify the typecounting mechanism or add some
other reference count, you can't tell how many executable mappings there
are (except that the total number of all mappings is an upper bound).
Isn't this something that could be done more easily inside the guest
kernel, where you have more information available?
> Is there an easy way to tell whether a virtual address is in guest kernel
> or user space?  It seems like guest_kernel_mode(v,r) in
> include/asm-x86/x86_64/regs.h is meant for PV guests and not for HVM.
guest_kernel_mode() doesn't even take an address. :)  The easiest way in
the shadow code is probably to call guest_walk_tables() with a pfec
argument of PFEC_page_present|PFEC_user_mode.
> Is it possible to change permissions at lvl 2 page tables while keeping
> the lvl 1's intact? 
> 
> Do the permissions propagate from lvl 2 to lvl 1? 
> 
> Finally, what's the lowest level I can set permissions on?  Does the
> hardware check for permissions at lvl 4 or lvl 3?
Yes; yes; only in 64 bit mode.  You should probably read the relevant
bits of the Intel PRMs (vol 3A, chapters 3 and 4) or the AMD APMs (vol
2, chaper 5) before delving too deep into shadow pagetables.
Cheers,
Tim.
-- 
Tim Deegan <Tim.Deegan@xxxxxxxxxx>
Principal Software Engineer, Citrix Systems (R&D) Ltd.
[Company #02300071, SL9 0DZ, UK.]
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel
 |