pmap of amd64

Yonghong Yan noah.yan at gmail.com
Fri Oct 12 16:32:43 PDT 2007


yes, what is the recursive mapping and i canot find no where to point
to from google

On 10/12/07, Thomas E. Spanjaard <tgen at netphreax.net> wrote:
> Yonghong Yan wrote:
> > below is the amd64 long mode 4k page VA structure.
> >
> > 63           48             39               30              21
> >        12                 0
> > ----------------------------------------------------------------------------------------
> > |      Ext       |     PML4   |    PDP        |      PD      |      PT
> >        |     offset     |
> > ----------------------------------------------------------------------------------------
> >                            9it              9bit            9bit
> >      9bit             12bit
>
> I don't see it in this graph, but you do know you only (on current
> x86-64 processors) have 48bits of VA space, one half is on the top end
> of a true 64bit VA space, and the other half on the lower end?
>
> > some issues for discussions:
> >
> > 1. 4K page or 2M page for kernel?
>
> Afaik FreeBSD maps code+data as 4Kibyte pages first, then remaps the PD
> entries as 2Mibyte pages covering the same memory.
>
> > 2. how many PML4/PDP entry for kernel/user?
>
> You could dedicate the lower half of your PML4 table to user PDP tables,
> and the upper half to the kernel. There's also some crap with stupid
> recursive mappings or some shit to do (no, I don't like them).
>
> > 3. how to do with the per-cpu data, should a PML4/PDP entry for each CPU?
>
> A per-CPU PML4 entry would be wildly inefficient, also limiting the
> scalability of DragonFly/x86-64 on current CPUs to, say, 254 processors
> tops. As there's not a lot of per-CPU data pages, I think it's safe to
> go with the same number we have on pc32.
>
> > hopefully there are relevant. others issues that I may not know,
> > please raise them. answers to them may have do with the
> > machine-independent VM management and the specificities of dfly kernel
> > thread/messaging system.
>
> Abstracting from the horror which is paging on IA32 (and derived)
> processors would be nice :).
>
> Cheers,
> --
>          Thomas E. Spanjaard
>          tgen at netphreax.net
>
>





More information about the Kernel mailing list