mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-17 15:27:36 +00:00
Make sure that the pages being 'pre-faulted' are currently on a queue.
This commit is contained in:
parent
1cf5e3a68b
commit
3edf89fe83
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=5914
@ -39,7 +39,7 @@
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* from: @(#)pmap.c 7.7 (Berkeley) 5/12/91
|
||||
* $Id: pmap.c,v 1.43 1995/01/24 09:56:32 davidg Exp $
|
||||
* $Id: pmap.c,v 1.44 1995/01/25 22:06:23 davidg Exp $
|
||||
*/
|
||||
|
||||
/*
|
||||
@ -1520,6 +1520,7 @@ pmap_object_init_pt(pmap, addr, object, offset, size)
|
||||
if ((p->bmapped == 0) &&
|
||||
(p->busy == 0) &&
|
||||
((p->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((p->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(p->flags & (PG_BUSY | PG_FICTITIOUS | PG_CACHE)) == 0) {
|
||||
vm_page_hold(p);
|
||||
pmap_enter_quick(pmap, addr + tmpoff, VM_PAGE_TO_PHYS(p));
|
||||
@ -1536,6 +1537,7 @@ pmap_object_init_pt(pmap, addr, object, offset, size)
|
||||
if (p && (p->bmapped == 0) &&
|
||||
(p->busy == 0) &&
|
||||
((p->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((p->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(p->flags & (PG_BUSY | PG_FICTITIOUS | PG_CACHE)) == 0) {
|
||||
vm_page_hold(p);
|
||||
pmap_enter_quick(pmap, addr + tmpoff, VM_PAGE_TO_PHYS(p));
|
||||
@ -1620,6 +1622,7 @@ pmap_prefault(pmap, addra, entry, object)
|
||||
if ((m->bmapped == 0) &&
|
||||
(m->busy == 0) &&
|
||||
((m->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((m->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(m->flags & (PG_CACHE | PG_BUSY | PG_FICTITIOUS)) == 0) {
|
||||
/*
|
||||
* test results show that the system is faster when
|
||||
|
@ -39,7 +39,7 @@
|
||||
* SUCH DAMAGE.
|
||||
*
|
||||
* from: @(#)pmap.c 7.7 (Berkeley) 5/12/91
|
||||
* $Id: pmap.c,v 1.43 1995/01/24 09:56:32 davidg Exp $
|
||||
* $Id: pmap.c,v 1.44 1995/01/25 22:06:23 davidg Exp $
|
||||
*/
|
||||
|
||||
/*
|
||||
@ -1520,6 +1520,7 @@ pmap_object_init_pt(pmap, addr, object, offset, size)
|
||||
if ((p->bmapped == 0) &&
|
||||
(p->busy == 0) &&
|
||||
((p->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((p->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(p->flags & (PG_BUSY | PG_FICTITIOUS | PG_CACHE)) == 0) {
|
||||
vm_page_hold(p);
|
||||
pmap_enter_quick(pmap, addr + tmpoff, VM_PAGE_TO_PHYS(p));
|
||||
@ -1536,6 +1537,7 @@ pmap_object_init_pt(pmap, addr, object, offset, size)
|
||||
if (p && (p->bmapped == 0) &&
|
||||
(p->busy == 0) &&
|
||||
((p->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((p->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(p->flags & (PG_BUSY | PG_FICTITIOUS | PG_CACHE)) == 0) {
|
||||
vm_page_hold(p);
|
||||
pmap_enter_quick(pmap, addr + tmpoff, VM_PAGE_TO_PHYS(p));
|
||||
@ -1620,6 +1622,7 @@ pmap_prefault(pmap, addra, entry, object)
|
||||
if ((m->bmapped == 0) &&
|
||||
(m->busy == 0) &&
|
||||
((m->valid & VM_PAGE_BITS_ALL) == VM_PAGE_BITS_ALL) &&
|
||||
((m->flags & (PG_ACTIVE | PG_INACTIVE)) != 0) &&
|
||||
(m->flags & (PG_CACHE | PG_BUSY | PG_FICTITIOUS)) == 0) {
|
||||
/*
|
||||
* test results show that the system is faster when
|
||||
|
Loading…
Reference in New Issue
Block a user