Page MenuHomeFreeBSD

Define a unified pmap structure for i386.
ClosedPublic

Authored by markj on Dec 21 2019, 3:57 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 4:54 AM
Unknown Object (File)
Sat, Jan 4, 12:47 PM
Unknown Object (File)
Nov 18 2024, 3:42 AM
Unknown Object (File)
Nov 16 2024, 4:32 AM
Unknown Object (File)
Nov 2 2024, 12:53 PM
Unknown Object (File)
Oct 30 2024, 11:36 AM
Unknown Object (File)
Sep 30 2024, 11:25 PM
Unknown Object (File)
Sep 30 2024, 1:53 PM
Subscribers

Details

Summary

My aim is to fix the CTF type graph in the i386 kernel. The templating
of struct pmap results in three different definitions of struct pmap
among different compilation units. This means that any structure that
references struct pmap or pmap_t, such as vmspace or vm_map, gets
duplicated, and this results in a blow-up of the CTF type graph.

Re-unify the pmap definition using unions for fields that differ between
the PAE and non-PAE pmaps. This is not very pretty, but I think it is
easier to understand and removes the need to #define pmap.

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 28509
Build 26564: arc lint + arc unit

Event Timeline

A different approach would be to define pmap_cpu_t to represent the CPU-specific pmap type, and use pmap_cpu_t instead of pmap_t in pmap.c. The dispatch functions in pmap_base.c would convert from pmap_t to pmap_cpu_t and we would just to cast the return value of vmspace_pmap() in the pmap_activate() implementation. This would result in a lot of churn but is a bit cleaner IMO.

Can pm_pdpt define moved to pmap_[no]pae.c (and pm_pdir as well, of course) ?

I remember that anon unions are not in C99, I think you can provide both kinds of pdir/pdpt always, same as ptdpg.

In D22896#505270, @kib wrote:

Can pm_pdpt define moved to pmap_[no]pae.c (and pm_pdir as well, of course) ?

Sure.

I remember that anon unions are not in C99, I think you can provide both kinds of pdir/pdpt always, same as ptdpg.

I always assumed it was fine to use C99 features; struct mbuf has contained an anonymous union for a long time.

In D22896#505270, @kib wrote:

I remember that anon unions are not in C99, I think you can provide both kinds of pdir/pdpt always, same as ptdpg.

I always assumed it was fine to use C99 features; struct mbuf has contained an anonymous union for a long time.

C99 sure, but anon unions are C11 or gnu99 feature.

Provide field definitions in pmap_(no)pae.c.
Do not provide pm_pdpt in the non-PAE pmap.
Avoid anonymous unions.

This revision is now accepted and ready to land.Jan 7 2020, 11:42 AM
This revision was automatically updated to reflect the committed changes.