i386: reduce differences in source between PAE and non-PAE pmaps ...

by defining pg_nx as zero for non-PAE and correspondingly simplifying
some expressions.

Suggested and reviewed by:	markj
Sponsored by:	The FreeBSD Foundation
MFC after:	1 week
Differential revision:	https://reviews.freebsd.org/D21757
This commit is contained in:
kib 2019-09-22 19:59:10 +00:00
parent a902246fd5
commit b4d009417b

View File

@ -227,6 +227,8 @@ static int nkpt = NKPT;
#ifdef PMAP_PAE_COMP #ifdef PMAP_PAE_COMP
pt_entry_t pg_nx; pt_entry_t pg_nx;
static uma_zone_t pdptzone; static uma_zone_t pdptzone;
#else
#define pg_nx 0
#endif #endif
_Static_assert(VM_MAXUSER_ADDRESS == VADDR(TRPTDI, 0), "VM_MAXUSER_ADDRESS"); _Static_assert(VM_MAXUSER_ADDRESS == VADDR(TRPTDI, 0), "VM_MAXUSER_ADDRESS");
@ -1871,11 +1873,7 @@ __CONCAT(PMTYPE, qenter)(vm_offset_t sva, vm_page_t *ma, int count)
m->md.pat_mode, 0); m->md.pat_mode, 0);
if ((*pte & (PG_FRAME | PG_PTE_CACHE)) != pa) { if ((*pte & (PG_FRAME | PG_PTE_CACHE)) != pa) {
oldpte |= *pte; oldpte |= *pte;
#ifdef PMAP_PAE_COMP
pte_store(pte, pa | pg_nx | PG_RW | PG_V); pte_store(pte, pa | pg_nx | PG_RW | PG_V);
#else
pte_store(pte, pa | PG_RW | PG_V);
#endif
} }
pte++; pte++;
} }
@ -6168,11 +6166,7 @@ sysctl_kmaps_dump(struct sbuf *sb, struct pmap_kernel_map_range *range,
sbuf_printf(sb, "0x%08x-0x%08x r%c%c%c%c %s %d %d %d\n", sbuf_printf(sb, "0x%08x-0x%08x r%c%c%c%c %s %d %d %d\n",
range->sva, eva, range->sva, eva,
(range->attrs & PG_RW) != 0 ? 'w' : '-', (range->attrs & PG_RW) != 0 ? 'w' : '-',
#ifdef PMAP_PAE_COMP
(range->attrs & pg_nx) != 0 ? '-' : 'x', (range->attrs & pg_nx) != 0 ? '-' : 'x',
#else
'-',
#endif
(range->attrs & PG_U) != 0 ? 'u' : 's', (range->attrs & PG_U) != 0 ? 'u' : 's',
(range->attrs & PG_G) != 0 ? 'g' : '-', (range->attrs & PG_G) != 0 ? 'g' : '-',
mode, range->pdpes, range->pdes, range->ptes); mode, range->pdpes, range->pdes, range->ptes);
@ -6191,10 +6185,7 @@ sysctl_kmaps_match(struct pmap_kernel_map_range *range, pt_entry_t attrs)
{ {
pt_entry_t diff, mask; pt_entry_t diff, mask;
mask = PG_G | PG_RW | PG_U | PG_PDE_CACHE; mask = pg_nx | PG_G | PG_RW | PG_U | PG_PDE_CACHE;
#ifdef PMAP_PAE_COMP
mask |= pg_nx;
#endif
diff = (range->attrs ^ attrs) & mask; diff = (range->attrs ^ attrs) & mask;
if (diff == 0) if (diff == 0)
return (true); return (true);
@ -6224,21 +6215,15 @@ static void
sysctl_kmaps_check(struct sbuf *sb, struct pmap_kernel_map_range *range, sysctl_kmaps_check(struct sbuf *sb, struct pmap_kernel_map_range *range,
vm_offset_t va, pd_entry_t pde, pt_entry_t pte) vm_offset_t va, pd_entry_t pde, pt_entry_t pte)
{ {
pt_entry_t attrs, mask; pt_entry_t attrs;
attrs = pde & (PG_RW | PG_U); attrs = pde & (PG_RW | PG_U | pg_nx);
#ifdef PMAP_PAE_COMP
attrs |= pde & pg_nx;
#endif
if ((pde & PG_PS) != 0) { if ((pde & PG_PS) != 0) {
attrs |= pde & (PG_G | PG_PDE_CACHE); attrs |= pde & (PG_G | PG_PDE_CACHE);
} else if (pte != 0) { } else if (pte != 0) {
mask = pte & (PG_RW | PG_U); attrs |= pte & pg_nx;
#ifdef PMAP_PAE_COMP attrs &= pg_nx | (pte & (PG_RW | PG_U));
mask |= pg_nx;
#endif
attrs &= mask;
attrs |= pte & (PG_G | PG_PTE_CACHE); attrs |= pte & (PG_G | PG_PTE_CACHE);
/* Canonicalize by always using the PDE PAT bit. */ /* Canonicalize by always using the PDE PAT bit. */