summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sys/vm/vm_fault.c6
-rw-r--r--sys/vm/vm_map.c18
2 files changed, 16 insertions, 8 deletions
diff --git a/sys/vm/vm_fault.c b/sys/vm/vm_fault.c
index 63d804a..cd5de64 100644
--- a/sys/vm/vm_fault.c
+++ b/sys/vm/vm_fault.c
@@ -996,9 +996,9 @@ vm_fault_prefault(pmap_t pmap, vm_offset_t addra, vm_map_entry_t entry)
(m->flags & PG_FICTITIOUS) == 0) {
vm_page_lock_queues();
- if (VM_PAGE_INQUEUE1(m, PQ_CACHE))
- vm_page_deactivate(m);
- pmap_enter_quick(pmap, addr, m, entry->protection);
+ if (!VM_PAGE_INQUEUE1(m, PQ_CACHE))
+ pmap_enter_quick(pmap, addr, m,
+ entry->protection);
vm_page_unlock_queues();
}
VM_OBJECT_UNLOCK(lobject);
diff --git a/sys/vm/vm_map.c b/sys/vm/vm_map.c
index 9ffa896..8efcc29 100644
--- a/sys/vm/vm_map.c
+++ b/sys/vm/vm_map.c
@@ -1429,9 +1429,10 @@ vm_map_submap(
/*
* vm_map_pmap_enter:
*
- * Preload read-only mappings for the given object into the specified
- * map. This eliminates the soft faults on process startup and
- * immediately after an mmap(2).
+ * Preload read-only mappings for the given object's resident pages into
+ * the given map. This eliminates the soft faults on process startup and
+ * immediately after an mmap(2). Unless the given flags include
+ * MAP_PREFAULT_MADVISE, cached pages are not reactivated and mapped.
*/
void
vm_map_pmap_enter(vm_map_t map, vm_offset_t addr, vm_prot_t prot,
@@ -1502,8 +1503,15 @@ vm_map_pmap_enter(vm_map_t map, vm_offset_t addr, vm_prot_t prot,
are_queues_locked = TRUE;
vm_page_lock_queues();
}
- if (VM_PAGE_INQUEUE1(p, PQ_CACHE))
- vm_page_deactivate(p);
+ if (VM_PAGE_INQUEUE1(p, PQ_CACHE)) {
+ if ((flags & MAP_PREFAULT_MADVISE) != 0)
+ vm_page_deactivate(p);
+ else if (p_start != NULL) {
+ pmap_enter_object(map->pmap, start, addr +
+ ptoa(tmpidx), p_start, prot);
+ p_start = NULL;
+ }
+ }
} else if (p_start != NULL) {
pmap_enter_object(map->pmap, start, addr +
ptoa(tmpidx), p_start, prot);
OpenPOWER on IntegriCloud