Fix PMAP_NEW and make it the default.
This commit is contained in:
parent
52ac5e203e
commit
50d1442817
@ -1,4 +1,4 @@
|
|||||||
# $NetBSD: GENERIC,v 1.34 1998/06/26 01:54:13 lukem Exp $
|
# $NetBSD: GENERIC,v 1.35 1998/07/18 20:35:14 ragge Exp $
|
||||||
#
|
#
|
||||||
# GENERIC VAX configuration file; all supported devices.
|
# GENERIC VAX configuration file; all supported devices.
|
||||||
#
|
#
|
||||||
@ -48,6 +48,7 @@ options NFSSERVER
|
|||||||
options NFS_BOOT_BOOTPARAM # Use the Sun way for netbooting.
|
options NFS_BOOT_BOOTPARAM # Use the Sun way for netbooting.
|
||||||
|
|
||||||
options UVM
|
options UVM
|
||||||
|
options PMAP_NEW
|
||||||
|
|
||||||
# WS console uses SUN terminal emulation
|
# WS console uses SUN terminal emulation
|
||||||
options WSEMUL_SUN
|
options WSEMUL_SUN
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: pmap.c,v 1.51 1998/07/08 04:43:23 thorpej Exp $ */
|
/* $NetBSD: pmap.c,v 1.52 1998/07/18 20:35:14 ragge Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
|
* Copyright (c) 1994 Ludd, University of Lule}, Sweden.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
@ -306,7 +306,6 @@ pmap_init(start, end)
|
|||||||
vm_offset_t start, end;
|
vm_offset_t start, end;
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
|
|
||||||
/* reserve place on SPT for UPT */
|
/* reserve place on SPT for UPT */
|
||||||
#if !defined(UVM)
|
#if !defined(UVM)
|
||||||
pte_map = kmem_suballoc(kernel_map, &ptemapstart, &ptemapend,
|
pte_map = kmem_suballoc(kernel_map, &ptemapstart, &ptemapend,
|
||||||
@ -377,9 +376,9 @@ pmap_pinit(pmap)
|
|||||||
pmap->pm_p1lr = (0x200000 - btoc(MAXSSIZ));
|
pmap->pm_p1lr = (0x200000 - btoc(MAXSSIZ));
|
||||||
|
|
||||||
#ifdef PMAPDEBUG
|
#ifdef PMAPDEBUG
|
||||||
if(startpmapdebug)
|
if (startpmapdebug)
|
||||||
printf("pmap_pinit(%p): p0br=%p p0lr=0x%lx p1br=%p p1lr=0x%lx\n",
|
printf("pmap_pinit(%p): p0br=%p p0lr=0x%lx p1br=%p p1lr=0x%lx\n",
|
||||||
pmap, pmap->pm_p0br, pmap->pm_p0lr, pmap->pm_p1br, pmap->pm_p1lr);
|
pmap, pmap->pm_p0br, pmap->pm_p0lr, pmap->pm_p1br, pmap->pm_p1lr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
pmap->ref_count = 1;
|
pmap->ref_count = 1;
|
||||||
@ -438,6 +437,36 @@ if(startpmapdebug)printf("pmap_destroy: pmap %p\n",pmap);
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Rensa is a help routine to remove a pv_entry from the pv list.
|
||||||
|
* Arguments are physical clustering page and page table entry pointer.
|
||||||
|
*/
|
||||||
|
static inline void
|
||||||
|
rensa(clp, ptp)
|
||||||
|
int clp;
|
||||||
|
struct pte *ptp;
|
||||||
|
{
|
||||||
|
struct pv_entry *pf, *pv = pv_table + clp;
|
||||||
|
int s;
|
||||||
|
|
||||||
|
s = splimp();
|
||||||
|
if (pv->pv_pte == ptp) {
|
||||||
|
pv->pv_pte = 0;
|
||||||
|
splx(s);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (; pv->pv_next; pv = pv->pv_next) {
|
||||||
|
if (pv->pv_next->pv_pte == ptp) {
|
||||||
|
pf = pv->pv_next;
|
||||||
|
pv->pv_next = pv->pv_next->pv_next;
|
||||||
|
FREE(pf, M_VMPVENT);
|
||||||
|
splx(s);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
panic("rensa");
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef PMAP_NEW
|
#ifdef PMAP_NEW
|
||||||
/*
|
/*
|
||||||
* New (real nice!) function that allocates memory in kernel space
|
* New (real nice!) function that allocates memory in kernel space
|
||||||
@ -448,6 +477,9 @@ pmap_kenter_pa(va, pa, prot)
|
|||||||
vm_offset_t va, pa;
|
vm_offset_t va, pa;
|
||||||
vm_prot_t prot;
|
vm_prot_t prot;
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
|
pmap_enter(pmap_kernel(), va, pa, prot, 0);
|
||||||
|
#endif
|
||||||
int *ptp;
|
int *ptp;
|
||||||
|
|
||||||
ptp = (int *)kvtopte(va);
|
ptp = (int *)kvtopte(va);
|
||||||
@ -467,21 +499,32 @@ pmap_kremove(va, len)
|
|||||||
vm_offset_t va;
|
vm_offset_t va;
|
||||||
vm_size_t len;
|
vm_size_t len;
|
||||||
{
|
{
|
||||||
|
struct pte *pte;
|
||||||
|
int i;
|
||||||
|
|
||||||
#ifdef PMAPDEBUG
|
#ifdef PMAPDEBUG
|
||||||
if(startpmapdebug)
|
if(startpmapdebug)
|
||||||
printf("pmap_kremove: va: %lx, len %lx, ptp %p\n", va, len, kvtopte(va));
|
printf("pmap_kremove: va: %lx, len %lx, ptp %p\n", va, len, kvtopte(va));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Unfortunately we must check if any page may be on the
|
* Unfortunately we must check if any page may be on the pv list.
|
||||||
* pv list. Call the slow routine.
|
|
||||||
*/
|
*/
|
||||||
#ifdef notyet
|
pte = kvtopte(va);
|
||||||
bzero((caddr_t)ptp, ptecount * sizeof(struct pte));
|
len >>= CLSHIFT;
|
||||||
mtpr(0, PR_TBIA);
|
|
||||||
#else
|
for (i = 0; i < len; i++) {
|
||||||
pmap_protect(pmap_kernel(), va, va + len, 0);
|
if (pte->pg_pfn == 0)
|
||||||
|
continue;
|
||||||
|
if (pte->pg_sref == 0)
|
||||||
|
rensa(pte->pg_pfn >> CLSIZELOG2, pte);
|
||||||
|
*(long long *)pte = 0;
|
||||||
|
#ifdef notdef
|
||||||
|
bzero(pte, CLSIZE * sizeof(struct pte));
|
||||||
#endif
|
#endif
|
||||||
|
pte += CLSIZE;
|
||||||
|
}
|
||||||
|
mtpr(0, PR_TBIA);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -491,16 +534,25 @@ pmap_kenter_pgs(va, pgs, npgs)
|
|||||||
int npgs;
|
int npgs;
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
int *ptp;
|
||||||
|
|
||||||
#ifdef PMAPDEBUG
|
#ifdef PMAPDEBUG
|
||||||
if(startpmapdebug)
|
if(startpmapdebug)
|
||||||
printf("pmap_kenter_pgs: va: %lx, pgs %p, npgs %x\n", va, pgs, npgs);
|
printf("pmap_kenter_pgs: va: %lx, pgs %p, npgs %x\n", va, pgs, npgs);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* May this routine affect page tables?
|
||||||
|
* We assume that, and uses TBIA.
|
||||||
|
*/
|
||||||
|
ptp = (int *)kvtopte(va);
|
||||||
for (i = 0 ; i < npgs ; i++) {
|
for (i = 0 ; i < npgs ; i++) {
|
||||||
pmap_kenter_pa(va + CLBYTES * i,
|
ptp[0] = PG_V | PG_KW |
|
||||||
(VM_PAGE_TO_PHYS(pgs[i])) + CLBYTES * i,
|
PG_PFNUM(VM_PAGE_TO_PHYS(pgs[i])) | PG_SREF;
|
||||||
VM_PROT_READ|VM_PROT_WRITE);
|
ptp[1] = ptp[0] + 1;
|
||||||
|
ptp += 2;
|
||||||
}
|
}
|
||||||
|
mtpr(0, PR_TBIA);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -552,8 +604,8 @@ printf("pmap_enter: pmap: %p,virt %lx, phys %lx, prot %x w %x\n",
|
|||||||
((patch[i] & PG_FRAME) != (nypte & PG_FRAME)))
|
((patch[i] & PG_FRAME) != (nypte & PG_FRAME)))
|
||||||
#if defined(UVM)
|
#if defined(UVM)
|
||||||
#ifdef PMAP_NEW
|
#ifdef PMAP_NEW
|
||||||
pmap_page_protect(&vm_physmem[0].pgs[(patch[i] & PG_FRAME) <<
|
pmap_page_protect(PHYS_TO_VM_PAGE((patch[i] & PG_FRAME)
|
||||||
(CLSHIFT - PGSHIFT)], 0);
|
<< PGSHIFT), 0);
|
||||||
#else
|
#else
|
||||||
pmap_page_protect((patch[i] & PG_FRAME) << PGSHIFT, 0);
|
pmap_page_protect((patch[i] & PG_FRAME) << PGSHIFT, 0);
|
||||||
#endif
|
#endif
|
||||||
@ -670,36 +722,6 @@ if(startpmapdebug)printf("pmap_extract: pmap %p, va %lx\n",pmap, va);
|
|||||||
return (pte[POFF(va)].pg_pfn << PGSHIFT);
|
return (pte[POFF(va)].pg_pfn << PGSHIFT);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Rensa is a help routine to remove a pv_entry from the pv list.
|
|
||||||
* Arguments are physical clustering page and page table entry pointer.
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
rensa(clp, ptp)
|
|
||||||
int clp;
|
|
||||||
struct pte *ptp;
|
|
||||||
{
|
|
||||||
struct pv_entry *pf, *pv = pv_table + clp;
|
|
||||||
int s;
|
|
||||||
|
|
||||||
s = splimp();
|
|
||||||
if (pv->pv_pte == ptp) {
|
|
||||||
pv->pv_pte = 0;
|
|
||||||
splx(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (; pv->pv_next; pv = pv->pv_next) {
|
|
||||||
if (pv->pv_next->pv_pte == ptp) {
|
|
||||||
pf = pv->pv_next;
|
|
||||||
pv->pv_next = pv->pv_next->pv_next;
|
|
||||||
FREE(pf, M_VMPVENT);
|
|
||||||
splx(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
panic("rensa");
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Sets protection for a given region to prot. If prot == none then
|
* Sets protection for a given region to prot. If prot == none then
|
||||||
* unmap region. pmap_remove is implemented as pmap_protect with
|
* unmap region. pmap_remove is implemented as pmap_protect with
|
||||||
@ -794,7 +816,7 @@ boolean_t
|
|||||||
pmap_is_referenced(pg)
|
pmap_is_referenced(pg)
|
||||||
struct vm_page *pg;
|
struct vm_page *pg;
|
||||||
{
|
{
|
||||||
vm_offset_t pa = pg->phys_addr;
|
vm_offset_t pa = VM_PAGE_TO_PHYS(pg);
|
||||||
#else
|
#else
|
||||||
boolean_t
|
boolean_t
|
||||||
pmap_is_referenced(pa)
|
pmap_is_referenced(pa)
|
||||||
@ -824,7 +846,7 @@ boolean_t
|
|||||||
pmap_clear_reference(pg)
|
pmap_clear_reference(pg)
|
||||||
struct vm_page *pg;
|
struct vm_page *pg;
|
||||||
{
|
{
|
||||||
vm_offset_t pa = pg->phys_addr;
|
vm_offset_t pa = VM_PAGE_TO_PHYS(pg);
|
||||||
#else
|
#else
|
||||||
void
|
void
|
||||||
pmap_clear_reference(pa)
|
pmap_clear_reference(pa)
|
||||||
@ -853,7 +875,7 @@ boolean_t
|
|||||||
pmap_is_modified(pg)
|
pmap_is_modified(pg)
|
||||||
struct vm_page *pg;
|
struct vm_page *pg;
|
||||||
{
|
{
|
||||||
vm_offset_t pa = pg->phys_addr;
|
vm_offset_t pa = VM_PAGE_TO_PHYS(pg);
|
||||||
#else
|
#else
|
||||||
boolean_t
|
boolean_t
|
||||||
pmap_is_modified(pa)
|
pmap_is_modified(pa)
|
||||||
@ -863,6 +885,10 @@ pmap_is_modified(pa)
|
|||||||
struct pv_entry *pv;
|
struct pv_entry *pv;
|
||||||
|
|
||||||
pv = pv_table + (pa >> CLSHIFT);
|
pv = pv_table + (pa >> CLSHIFT);
|
||||||
|
#ifdef PMAPDEBUG
|
||||||
|
if (startpmapdebug)
|
||||||
|
printf("pmap_is_modified: pa %lx pv_entry %p\n", pa, pv);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (pv->pv_pte)
|
if (pv->pv_pte)
|
||||||
if ((pv->pv_pte[0].pg_m | pv->pv_pte[1].pg_m))
|
if ((pv->pv_pte[0].pg_m | pv->pv_pte[1].pg_m))
|
||||||
@ -883,7 +909,7 @@ boolean_t
|
|||||||
pmap_clear_modify(pg)
|
pmap_clear_modify(pg)
|
||||||
struct vm_page *pg;
|
struct vm_page *pg;
|
||||||
{
|
{
|
||||||
vm_offset_t pa = pg->phys_addr;
|
vm_offset_t pa = VM_PAGE_TO_PHYS(pg);
|
||||||
#else
|
#else
|
||||||
void
|
void
|
||||||
pmap_clear_modify(pa)
|
pmap_clear_modify(pa)
|
||||||
@ -894,6 +920,10 @@ pmap_clear_modify(pa)
|
|||||||
|
|
||||||
pv = pv_table + (pa >> CLSHIFT);
|
pv = pv_table + (pa >> CLSHIFT);
|
||||||
|
|
||||||
|
#ifdef PMAPDEBUG
|
||||||
|
if (startpmapdebug)
|
||||||
|
printf("pmap_clear_modify: pa %lx pv_entry %p\n", pa, pv);
|
||||||
|
#endif
|
||||||
if (pv->pv_pte)
|
if (pv->pv_pte)
|
||||||
pv->pv_pte[0].pg_m = pv->pv_pte[1].pg_m = 0;
|
pv->pv_pte[0].pg_m = pv->pv_pte[1].pg_m = 0;
|
||||||
|
|
||||||
@ -915,7 +945,7 @@ pmap_page_protect(pg, prot)
|
|||||||
struct vm_page *pg;
|
struct vm_page *pg;
|
||||||
vm_prot_t prot;
|
vm_prot_t prot;
|
||||||
{
|
{
|
||||||
vm_offset_t pa = pg->phys_addr;
|
vm_offset_t pa = VM_PAGE_TO_PHYS(pg);
|
||||||
#else
|
#else
|
||||||
void
|
void
|
||||||
pmap_page_protect(pa, prot)
|
pmap_page_protect(pa, prot)
|
||||||
|
Loading…
Reference in New Issue
Block a user