summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1997-07-28 23:46:11 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1997-07-28 23:46:11 +0000
commit6a582a198d0dab12b717f6bb38cff2ea752922da (patch)
tree7a93100ae5a8bfa46a91cc4d7f0a3bb82b9fb17c
parent57ecfd692c2ea481e5992beb34158dc94d0b4cbf (diff)
do multipage pmap_pageable
-rw-r--r--sys/arch/i386/i386/pmap.c10
-rw-r--r--sys/arch/i386/i386/pmap.old.c10
2 files changed, 12 insertions, 8 deletions
diff --git a/sys/arch/i386/i386/pmap.c b/sys/arch/i386/i386/pmap.c
index 3e7d0d0db44..0192a847f51 100644
--- a/sys/arch/i386/i386/pmap.c
+++ b/sys/arch/i386/i386/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.16 1997/01/07 05:37:32 tholo Exp $ */
+/* $OpenBSD: pmap.c,v 1.17 1997/07/28 23:46:10 mickey Exp $ */
/* $NetBSD: pmap.c,v 1.36 1996/05/03 19:42:22 christos Exp $ */
/*
@@ -1555,11 +1555,13 @@ pmap_pageable(pmap, sva, eva, pageable)
* If we are making a PT page pageable then all valid
* mappings must be gone from that page. Hence it should
* be all zeros and there is no need to clean it.
- * Assumptions:
- * - we are called with only one page at a time
+ * Assumption:
* - PT pages have only one pv_table entry
*/
- if (pmap == pmap_kernel() && pageable && sva + NBPG == eva) {
+ if (pmap != pmap_kernel() || !pageable)
+ return;
+
+ for ( ; sva < eva; sva += NBPG) {
register vm_offset_t pa;
register pt_entry_t *pte;
diff --git a/sys/arch/i386/i386/pmap.old.c b/sys/arch/i386/i386/pmap.old.c
index 0aa7a5d478f..6ba2811f3dd 100644
--- a/sys/arch/i386/i386/pmap.old.c
+++ b/sys/arch/i386/i386/pmap.old.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.old.c,v 1.16 1997/01/07 05:37:32 tholo Exp $ */
+/* $OpenBSD: pmap.old.c,v 1.17 1997/07/28 23:46:10 mickey Exp $ */
/* $NetBSD: pmap.c,v 1.36 1996/05/03 19:42:22 christos Exp $ */
/*
@@ -1555,11 +1555,13 @@ pmap_pageable(pmap, sva, eva, pageable)
* If we are making a PT page pageable then all valid
* mappings must be gone from that page. Hence it should
* be all zeros and there is no need to clean it.
- * Assumptions:
- * - we are called with only one page at a time
+ * Assumption:
* - PT pages have only one pv_table entry
*/
- if (pmap == pmap_kernel() && pageable && sva + NBPG == eva) {
+ if (pmap != pmap_kernel() || !pageable)
+ return;
+
+ for ( ; sva < eva; sva += NBPG) {
register vm_offset_t pa;
register pt_entry_t *pte;