cosmetics (typo, KNF etc.)
This commit is contained in:
parent
72a263b8f7
commit
f7312c690f
@ -1,4 +1,4 @@
|
||||
/* $NetBSD: pmap.c,v 1.25 2001/12/13 04:39:52 chs Exp $ */
|
||||
/* $NetBSD: pmap.c,v 1.26 2001/12/16 03:41:57 tsutsui Exp $ */
|
||||
|
||||
/*-
|
||||
* Copyright (c) 1999 The NetBSD Foundation, Inc.
|
||||
@ -159,11 +159,7 @@
|
||||
#define PDB_PVDUMP 0x8000
|
||||
|
||||
int debugmap = 0;
|
||||
#if 1
|
||||
int pmapdebug = PDB_PARANOIA;
|
||||
#else
|
||||
int pmapdebug = 0xffff;
|
||||
#endif
|
||||
|
||||
#define PMAP_DPRINTF(l, x) if (pmapdebug & (l)) printf x
|
||||
|
||||
@ -262,8 +258,10 @@ struct pv_entry *pv_table;
|
||||
char *pmap_attributes; /* reference and modify bits */
|
||||
TAILQ_HEAD(pv_page_list, pv_page) pv_page_freelist;
|
||||
int pv_nfree;
|
||||
int pmap_aliasmask; /* seperation at which VA aliasing ok */
|
||||
|
||||
#ifdef CACHE_HAVE_VAC
|
||||
int pmap_aliasmask; /* seperation at which VA aliasing ok */
|
||||
#endif
|
||||
#if defined(M68040)
|
||||
int protostfree; /* prototype (default) free ST map */
|
||||
#endif
|
||||
@ -398,15 +396,13 @@ pmap_init()
|
||||
intiotop_phys - intiobase_phys,
|
||||
NULL, UVM_UNKNOWN_OFFSET, 0,
|
||||
UVM_MAPFLAG(UVM_PROT_NONE, UVM_PROT_NONE,
|
||||
UVM_INH_NONE, UVM_ADV_RANDOM,
|
||||
UVM_FLAG_FIXED)) != 0)
|
||||
UVM_INH_NONE, UVM_ADV_RANDOM, UVM_FLAG_FIXED)) != 0)
|
||||
goto bogons;
|
||||
addr = (vaddr_t) Sysmap;
|
||||
if (uvm_map(kernel_map, &addr, MAX_PTSIZE,
|
||||
NULL, UVM_UNKNOWN_OFFSET, 0,
|
||||
UVM_MAPFLAG(UVM_PROT_NONE, UVM_PROT_NONE,
|
||||
UVM_INH_NONE, UVM_ADV_RANDOM,
|
||||
UVM_FLAG_FIXED)) != 0) {
|
||||
UVM_INH_NONE, UVM_ADV_RANDOM, UVM_FLAG_FIXED)) != 0) {
|
||||
/*
|
||||
* If this fails, it is probably because the static
|
||||
* portion of the kernel page table isn't big enough
|
||||
@ -469,7 +465,7 @@ pmap_init()
|
||||
* Allocate physical memory for kernel PT pages and their management.
|
||||
* We need 1 PT page per possible task plus some slop.
|
||||
*/
|
||||
npages = min(atop(MAX_KPTSIZE), maxproc+16);
|
||||
npages = min(atop(MAX_KPTSIZE), maxproc + 16);
|
||||
s = ptoa(npages) + round_page(npages * sizeof(struct kpt_page));
|
||||
|
||||
/*
|
||||
@ -707,7 +703,7 @@ pmap_map(va, spa, epa, prot)
|
||||
spa += NBPG;
|
||||
}
|
||||
pmap_update(pmap_kernel());
|
||||
return (va);
|
||||
return va;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -723,12 +719,12 @@ pmap_create()
|
||||
pmap_t pmap;
|
||||
|
||||
PMAP_DPRINTF(PDB_FOLLOW|PDB_CREATE,
|
||||
("pmap_create\n"));
|
||||
("pmap_create()\n"));
|
||||
|
||||
pmap = pool_get(&pmap_pmap_pool, PR_WAITOK);
|
||||
memset(pmap, 0, sizeof(*pmap));
|
||||
pmap_pinit(pmap);
|
||||
return (pmap);
|
||||
return pmap;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -811,8 +807,7 @@ pmap_release(pmap)
|
||||
(vaddr_t)pmap->pm_ptab + MAX_PTSIZE);
|
||||
uvm_km_pgremove(uvm.kernel_object, (vaddr_t)pmap->pm_ptab,
|
||||
(vaddr_t)pmap->pm_ptab + MAX_PTSIZE);
|
||||
uvm_km_free_wakeup(pt_map, (vaddr_t)pmap->pm_ptab,
|
||||
MAX_PTSIZE);
|
||||
uvm_km_free_wakeup(pt_map, (vaddr_t)pmap->pm_ptab, MAX_PTSIZE);
|
||||
}
|
||||
KASSERT(pmap->pm_stab == Segtabzero);
|
||||
}
|
||||
@ -826,8 +821,8 @@ void
|
||||
pmap_reference(pmap)
|
||||
pmap_t pmap;
|
||||
{
|
||||
PMAP_DPRINTF(PDB_FOLLOW, ("pmap_reference(%p)\n", pmap));
|
||||
|
||||
PMAP_DPRINTF(PDB_FOLLOW, ("pmap_reference(%p)\n", pmap));
|
||||
simple_lock(&pmap->pm_lock);
|
||||
pmap->pm_count++;
|
||||
simple_unlock(&pmap->pm_lock);
|
||||
@ -1035,11 +1030,12 @@ pmap_page_protect(pg, prot)
|
||||
pte, PRM_TFLUSH|PRM_CFLUSH);
|
||||
else {
|
||||
pv = pv->pv_next;
|
||||
#ifdef DEBUG
|
||||
if (pmapdebug & PDB_PARANOIA)
|
||||
printf("%s wired mapping for %lx not removed\n",
|
||||
"pmap_page_protect:", pa);
|
||||
#endif
|
||||
PMAP_DPRINTF(PDB_PARANOIA,
|
||||
("%s wired mapping for %lx not removed\n",
|
||||
"pmap_page_protect:", pa));
|
||||
PMAP_DPRINTF(PDB_PARANOIA,
|
||||
("vm wired count %d\n",
|
||||
PHYS_TO_VM_PAGE(pa)->wired_count));
|
||||
if (pv == NULL)
|
||||
break;
|
||||
}
|
||||
@ -1177,8 +1173,8 @@ pmap_enter(pmap, va, pa, prot, flags)
|
||||
* For user mapping, allocate kernel VM resources if necessary.
|
||||
*/
|
||||
if (pmap->pm_ptab == NULL)
|
||||
pmap->pm_ptab = (pt_entry_t *)
|
||||
uvm_km_valloc_wait(pt_map, MAX_PTSIZE);
|
||||
pmap->pm_ptab =
|
||||
(pt_entry_t *) uvm_km_valloc_wait(pt_map, MAX_PTSIZE);
|
||||
|
||||
/*
|
||||
* Segment table entry not valid, we need a new PT page
|
||||
@ -1425,6 +1421,14 @@ validate:
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* pmap_kenter_pa: [ INTERFACE ]
|
||||
*
|
||||
* Enter a va -> pa mapping into the kernel pmap without any
|
||||
* physical->virtual tracking.
|
||||
*
|
||||
* Note: no locking is necessary in this function.
|
||||
*/
|
||||
void
|
||||
pmap_kenter_pa(va, pa, prot)
|
||||
vaddr_t va;
|
||||
@ -1481,22 +1485,28 @@ pmap_kenter_pa(va, pa, prot)
|
||||
*pte = npte;
|
||||
}
|
||||
|
||||
/*
|
||||
* pmap_kremove: [ INTERFACE ]
|
||||
*
|
||||
* Remove a mapping entered with pmap_kenter_pa() starting at va,
|
||||
* for len bytes (assumed to be page rounded).
|
||||
*
|
||||
*/
|
||||
void
|
||||
pmap_kremove(va, len)
|
||||
vaddr_t va;
|
||||
vsize_t len;
|
||||
{
|
||||
struct pmap *pmap = pmap_kernel();
|
||||
vaddr_t sva, eva, nssva;
|
||||
vaddr_t eva, nssva;
|
||||
pt_entry_t *pte;
|
||||
|
||||
PMAP_DPRINTF(PDB_FOLLOW|PDB_REMOVE|PDB_PROTECT,
|
||||
("pmap_kremove(%lx, %lx)\n", va, len));
|
||||
|
||||
sva = va;
|
||||
eva = va + len;
|
||||
while (sva < eva) {
|
||||
nssva = m68k_trunc_seg(sva) + NBSEG;
|
||||
while (va < eva) {
|
||||
nssva = m68k_trunc_seg(va) + NBSEG;
|
||||
if (nssva == 0 || nssva > eva)
|
||||
nssva = eva;
|
||||
|
||||
@ -1505,8 +1515,8 @@ pmap_kremove(va, len)
|
||||
* skip to the next segment boundary.
|
||||
*/
|
||||
|
||||
if (!pmap_ste_v(pmap, sva)) {
|
||||
sva = nssva;
|
||||
if (!pmap_ste_v(pmap, va)) {
|
||||
va = nssva;
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -1514,8 +1524,8 @@ pmap_kremove(va, len)
|
||||
* Invalidate every valid mapping within this segment.
|
||||
*/
|
||||
|
||||
pte = pmap_pte(pmap, sva);
|
||||
while (sva < nssva) {
|
||||
pte = pmap_pte(pmap, va);
|
||||
while (va < nssva) {
|
||||
if (pmap_pte_v(pte)) {
|
||||
#ifdef DEBUG
|
||||
struct pv_entry *pv;
|
||||
@ -1525,7 +1535,7 @@ pmap_kremove(va, len)
|
||||
s = splvm();
|
||||
while (pv->pv_pmap != NULL) {
|
||||
KASSERT(pv->pv_pmap != pmap_kernel() ||
|
||||
pv->pv_va != sva);
|
||||
pv->pv_va != va);
|
||||
pv = pv->pv_next;
|
||||
if (pv == NULL) {
|
||||
break;
|
||||
@ -1545,10 +1555,10 @@ pmap_kremove(va, len)
|
||||
*/
|
||||
|
||||
*pte = PG_NV;
|
||||
TBIS(sva);
|
||||
TBIS(va);
|
||||
}
|
||||
pte++;
|
||||
sva += NBPG;
|
||||
va += NBPG;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1578,8 +1588,8 @@ pmap_unwire(pmap, va)
|
||||
* we don't want to force allocation of unnecessary PTE pages.
|
||||
*/
|
||||
if (!pmap_ste_v(pmap, va)) {
|
||||
if (pmapdebug & PDB_PARANOIA)
|
||||
printf("pmap_unwire: invalid STE for %lx\n", va);
|
||||
PMAP_DPRINTF(PDB_PARANOIA,
|
||||
("pmap_unwire: invalid STE for %lx\n", va));
|
||||
return;
|
||||
}
|
||||
/*
|
||||
@ -1587,8 +1597,8 @@ pmap_unwire(pmap, va)
|
||||
* Just continue and change wiring anyway.
|
||||
*/
|
||||
if (!pmap_pte_v(pte)) {
|
||||
if (pmapdebug & PDB_PARANOIA)
|
||||
printf("pmap_unwire: invalid PTE for %lx\n", va);
|
||||
PMAP_DPRINTF(PDB_PARANOIA,
|
||||
("pmap_unwire: invalid PTE for %lx\n", va));
|
||||
}
|
||||
#endif
|
||||
/*
|
||||
@ -1627,7 +1637,7 @@ pmap_extract(pmap, va, pap)
|
||||
PMAP_DPRINTF(PDB_FOLLOW,
|
||||
("pmap_extract(%p, %lx) -> ", pmap, va));
|
||||
|
||||
if (pmap && pmap_ste_v(pmap, va)) {
|
||||
if (pmap_ste_v(pmap, va)) {
|
||||
pte = *(u_int *)pmap_pte(pmap, va);
|
||||
if (pte) {
|
||||
pa = (pte & PG_FRAME) | (va & ~PG_FRAME);
|
||||
@ -1645,7 +1655,7 @@ pmap_extract(pmap, va, pap)
|
||||
}
|
||||
#endif
|
||||
|
||||
return (rv);
|
||||
return rv;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -1765,7 +1775,7 @@ pmap_collect1(pmap, startpa, endpa)
|
||||
goto ok;
|
||||
pmap_pvdump(pa);
|
||||
continue;
|
||||
ok:
|
||||
ok:
|
||||
#endif
|
||||
pte = (pt_entry_t *)(pv->pv_va + NBPG);
|
||||
while (--pte >= (pt_entry_t *)pv->pv_va && *pte == PG_NV)
|
||||
@ -1788,7 +1798,7 @@ ok:
|
||||
* We call pmap_remove_entry to take care of invalidating
|
||||
* ST and Sysptmap entries.
|
||||
*/
|
||||
(void) pmap_extract(pmap, pv->pv_va, (paddr_t *)&kpa);
|
||||
(void) pmap_extract(pmap, pv->pv_va, &kpa);
|
||||
pmap_remove_mapping(pmap, pv->pv_va, PT_ENTRY_NULL,
|
||||
PRM_TFLUSH|PRM_CFLUSH);
|
||||
/*
|
||||
@ -1804,9 +1814,8 @@ ok:
|
||||
#ifdef DEBUG
|
||||
if (kpt == NULL)
|
||||
panic("pmap_collect: lost a KPT page");
|
||||
if (pmapdebug & (PDB_PTPAGE|PDB_COLLECT))
|
||||
printf("collect: %lx (%lx) to free list\n",
|
||||
kpt->kpt_va, kpa);
|
||||
PMAP_DPRINTF(PDB_PTPAGE|PDB_COLLECT,
|
||||
("collect: %lx (%lx) to free list\n", kpt->kpt_va, kpa));
|
||||
#endif
|
||||
*pkpt = kpt->kpt_next;
|
||||
kpt->kpt_next = kpt_free_list;
|
||||
@ -1885,7 +1894,7 @@ pmap_zero_page(phys)
|
||||
/*
|
||||
* pmap_zero_page_uncached:
|
||||
*
|
||||
* Same as above, except uncached. Used in uvm_pageidolezero,
|
||||
* Same as above, except uncached. Used in uvm_pageidlezero,
|
||||
* through PMAP_PAGEIDLEZERO macro. Returns TRUE if the page
|
||||
* was zero'd, FALSE if we aborted.
|
||||
*/
|
||||
@ -1919,7 +1928,7 @@ pmap_zero_page_uncached(phys)
|
||||
|
||||
splx(s);
|
||||
|
||||
return (TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -1999,7 +2008,7 @@ pmap_clear_modify(pg)
|
||||
paddr_t pa = VM_PAGE_TO_PHYS(pg);
|
||||
boolean_t rv;
|
||||
|
||||
PMAP_DPRINTF(PDB_FOLLOW, ("pmap_clear_modify(%lx)\n", pa));
|
||||
PMAP_DPRINTF(PDB_FOLLOW, ("pmap_clear_modify(%p)\n", pg));
|
||||
|
||||
rv = pmap_testbit(pa, PG_M);
|
||||
pmap_changebit(pa, 0, ~PG_M);
|
||||
@ -2041,10 +2050,10 @@ pmap_is_referenced(pg)
|
||||
if (pmapdebug & PDB_FOLLOW) {
|
||||
boolean_t rv = pmap_testbit(pa, PG_U);
|
||||
printf("pmap_is_referenced(%lx) -> %c\n", pa, "FT"[rv]);
|
||||
return(rv);
|
||||
return rv;
|
||||
}
|
||||
#endif
|
||||
return(pmap_testbit(pa, PG_U));
|
||||
return pmap_testbit(pa, PG_U);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -2062,11 +2071,11 @@ pmap_is_modified(pg)
|
||||
#ifdef DEBUG
|
||||
if (pmapdebug & PDB_FOLLOW) {
|
||||
boolean_t rv = pmap_testbit(pa, PG_M);
|
||||
printf("pmap_is_modified(%lx) -> %c\n", pa, "FT"[rv]);
|
||||
return(rv);
|
||||
printf("pmap_is_modified(%p) -> %c\n", pg, "FT"[rv]);
|
||||
return rv;
|
||||
}
|
||||
#endif
|
||||
return(pmap_testbit(pa, PG_M));
|
||||
return pmap_testbit(pa, PG_M);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -2082,7 +2091,8 @@ paddr_t
|
||||
pmap_phys_address(ppn)
|
||||
int ppn;
|
||||
{
|
||||
return(m68k_ptob(ppn));
|
||||
|
||||
return m68k_ptob(ppn);
|
||||
}
|
||||
|
||||
#ifdef CACHE_HAVE_VAC
|
||||
@ -2099,8 +2109,7 @@ pmap_prefer(foff, vap)
|
||||
vaddr_t va;
|
||||
vsize_t d;
|
||||
|
||||
if (pmap_aliasmask)
|
||||
{
|
||||
if (pmap_aliasmask) {
|
||||
va = *vap;
|
||||
d = foff - va;
|
||||
d &= pmap_aliasmask;
|
||||
@ -2377,11 +2386,10 @@ pmap_remove_mapping(pmap, va, pte, flags)
|
||||
pmap_remove(pmap_kernel(),
|
||||
(vaddr_t)ptpmap->pm_stab,
|
||||
(vaddr_t)ptpmap->pm_stab + STSIZE);
|
||||
uvm_pagefree(PHYS_TO_VM_PAGE((paddr_t)
|
||||
ptpmap->pm_stpa));
|
||||
uvm_pagefree(PHYS_TO_VM_PAGE(
|
||||
(paddr_t)ptpmap->pm_stpa));
|
||||
uvm_km_free_wakeup(st_map,
|
||||
(vaddr_t)ptpmap->pm_stab,
|
||||
STSIZE);
|
||||
(vaddr_t)ptpmap->pm_stab, STSIZE);
|
||||
ptpmap->pm_stab = Segtabzero;
|
||||
ptpmap->pm_stpa = Segtabzeropa;
|
||||
#if defined(M68040)
|
||||
@ -2445,7 +2453,7 @@ pmap_testbit(pa, bit)
|
||||
|
||||
if (*pa_to_attribute(pa) & bit) {
|
||||
splx(s);
|
||||
return(TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
#ifdef CACHE_HAVE_VAC
|
||||
/*
|
||||
@ -2464,12 +2472,12 @@ pmap_testbit(pa, bit)
|
||||
if (*pte & bit) {
|
||||
*pa_to_attribute(pa) |= bit;
|
||||
splx(s);
|
||||
return(TRUE);
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
splx(s);
|
||||
return(FALSE);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -2586,8 +2594,7 @@ pmap_enter_ptpage(pmap, va)
|
||||
* reference count drops to zero.
|
||||
*/
|
||||
if (pmap->pm_stab == Segtabzero) {
|
||||
pmap->pm_stab = (st_entry_t *)
|
||||
uvm_km_zalloc(st_map, STSIZE);
|
||||
pmap->pm_stab = (st_entry_t *) uvm_km_zalloc(st_map, STSIZE);
|
||||
(void) pmap_extract(pmap_kernel(), (vaddr_t)pmap->pm_stab,
|
||||
(paddr_t *)&pmap->pm_stpa);
|
||||
#if defined(M68040)
|
||||
@ -2642,7 +2649,7 @@ pmap_enter_ptpage(pmap, va)
|
||||
* to the first entry of that chunk which is validated in its
|
||||
* entirety below.
|
||||
*/
|
||||
ste = (st_entry_t *)((int)ste & ~(NBPG/SG4_LEV3SIZE-1));
|
||||
ste = (st_entry_t *)((int)ste & ~(NBPG / SG4_LEV3SIZE - 1));
|
||||
|
||||
PMAP_DPRINTF(PDB_ENTER|PDB_PTPAGE|PDB_SEGTAB,
|
||||
("enter: ste2 %p (%p)\n", pmap_ste2(pmap, va), ste));
|
||||
@ -2827,7 +2834,7 @@ pmap_ptpage_delref(ptpva)
|
||||
pg = uvm_pagelookup(uvm.kernel_object, ptpva - vm_map_min(kernel_map));
|
||||
rv = --pg->wire_count;
|
||||
simple_unlock(&uvm.kernel_object->vmobjlock);
|
||||
return (rv);
|
||||
return rv;
|
||||
}
|
||||
|
||||
#ifdef DEBUG
|
||||
|
Loading…
Reference in New Issue
Block a user