Virtual Memory map

Damian Tometzki damian.tometzki at icloud.com
Wed Dec 13 03:28:33 EST 2017


Hello,

On more question. The second example:

>> ffff800000000000 - ffff87ffffffffff (=43 bits) guard hole, reserved for hypervisor

What are the relation between the Bits (=43bits) and the Adresse Range ?

Is it possible to calculate the 43 Bits from the range ?  If yes, how ? 


Best regards
Damian 




> Am 13.12.2017 um 05:35 schrieb arshad hussain <arshad.super at gmail.com>:
> 
> On Wed, Dec 13, 2017 at 12:44 AM, Damian Tometzki
> <damian.tometzki at icloud.com> wrote:
>> Hello all,
>> 
>> i have a short question:
>> 
>> How are the bits (in brackets) calculated in the virtual memory map ?
>> 
>> for example the first line (=47 bits)
>> 
>> Virtual memory map with 4 level page tables:
>> 
>> 0000000000000000 - 00007fffffffffff (=47 bits) user space, different per mm
>> hole caused by [47:63] sign extension
>> ffff800000000000 - ffff87ffffffffff (=43 bits) guard hole, reserved for hypervisor
>> 
> 
> Presently for x86-64 kernel uses 4-level paging. Out of 64bit only 48 bit
> is enabled (Which boils down to Terabyte of address space). For case
> where getpagesize() is 4K the breakup is :-
> 
> CR3 -> Global(9 bits) -> Upper(9 bits) -> Middle(9 bits) -> Page
> table(9 bits) -> [12 bits for page or 4096 bytes] = (48 bits)
> 
> Thanks
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.kernelnewbies.org/pipermail/kernelnewbies/attachments/20171213/f0c5a54e/attachment.html 


More information about the Kernelnewbies mailing list