diff options
author | Alan Cox <alc@FreeBSD.org> | 2014-02-09 01:59:52 +0000 |
---|---|---|
committer | Alan Cox <alc@FreeBSD.org> | 2014-02-09 01:59:52 +0000 |
commit | 7b9b301c6b23cecd1e705ccd6fcd046016ab4267 (patch) | |
tree | 46d3a03eec54f381cf2193378ccdd26e14def626 /sys | |
parent | ca3eec15c06e2e3838ac93497cf0283c7b9252df (diff) | |
download | src-7b9b301c6b23cecd1e705ccd6fcd046016ab4267.tar.gz src-7b9b301c6b23cecd1e705ccd6fcd046016ab4267.zip |
Don't call vm_fault_prefault() on zero-fill faults. It's a waste of time.
Successful prefaults after a zero-fill fault are extremely rare.
Notes
Notes:
svn path=/head/; revision=261647
Diffstat (limited to 'sys')
-rw-r--r-- | sys/vm/vm_fault.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sys/vm/vm_fault.c b/sys/vm/vm_fault.c index f8e3c3f8b7e5..4a6495f58ad4 100644 --- a/sys/vm/vm_fault.c +++ b/sys/vm/vm_fault.c @@ -652,6 +652,8 @@ vnode_locked: } PCPU_INC(cnt.v_zfod); fs.m->valid = VM_PAGE_BITS_ALL; + /* Don't try to prefault neighboring pages. */ + faultcount = 1; break; /* break to PAGE HAS BEEN FOUND */ } else { KASSERT(fs.object != next_object, @@ -897,7 +899,8 @@ vnode_locked: * won't find it (yet). */ pmap_enter(fs.map->pmap, vaddr, fault_type, fs.m, prot, wired); - if ((fault_flags & VM_FAULT_CHANGE_WIRING) == 0 && wired == 0) + if (faultcount != 1 && (fault_flags & VM_FAULT_CHANGE_WIRING) == 0 && + wired == 0) vm_fault_prefault(&fs, vaddr, faultcount, reqpage); VM_OBJECT_WLOCK(fs.object); vm_page_lock(fs.m); |