-
Notifications
You must be signed in to change notification settings - Fork 413
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Investigate use of 1GB or 2MB EPT mappings for MMIO #29
Comments
One idea is to map all 512GB (or whatever Windows supports) PA ranges except for ones backed by RAM with 1GB and 2MB mappings where possible. This, unfortunately, still requires fairly a large number of EPT entries. For example, to fill non-RAM-backed memory ranges on my laptop with 8GB of RAM, it needs the following number of entries.
This is clearly much bigger than the current number of pre-allocated entries (which is 50), and not so small in general sense. @ionescu007 let me know your thoughts. |
246 entries if my count is right. That's more than the pre-allocated entries, but not that much more... and it avoids all the logic needed to handle pre-allocated entries and it doesn't kill the system if 50 is reached (or whatever hard-coded limit is set). I don't know -- I think the approach is cleaner this way. Or another option would be for the OS Driver and Hypervisor to communicate between each others and pass physical memory from OS to hypervisor -- perhaps a large chunk initially (Hypervisor Heap) and then with a mechanism for the hypervisor to request more as needed (based on say a timer event)... this is how I believe Hyper-V does it. But that's a lot of code, potentially :) One thing that I realized... right now, are you setting MMIO to "WriteBack"? Shouldn't such regions be Uncacheable, right? Not sure about this. |
I thought 250+ entries are a a lot, on second thought, it may be not as bad as I initially felt, especially because code architecture can be simpler and allocation failure just leads to load failure. On "WriteBack", good question. I am not sure neither but will check it at #31. Thanks for your keen eyes! |
Description
HyperPlatform pre-allocates and assigned 4KB EPT entries for physical addresses (PA) used for memory mapped I/O. This design leads to two major disadvantages: complexity in code, and limited support for access to such PA ranges.
#19 identified a way to enumerate such PA ranges (NB: not idea is tested yet) so that HyperPlatform could allocate EPT entries for those PA ranges and get rid of the pre-allocation code. PA ranges reported in the way explained in #19 are too large to allocate EPT entries for them if only 4KB mapping is used, however.
This issue report is to analyze a way to utilize 1GB or 2MB EPT mappings to over come the challenge and simplify code.
Note that use of 1GB or 1MB mappings for normal PA pages is not aimed since we would like to have an ability to control PA access rights with fine (ie, 4KB) granularity for VMI. 2MB mapping can be used for reducing a number of EPT entries to manipulate, but it would introduce non negligible complexity.
The text was updated successfully, but these errors were encountered: