svn commit: r199869 - head/sys/vm

Alan Cox alc at FreeBSD.org
Fri Nov 27 22:08:29 UTC 2009


Author: alc
Date: Fri Nov 27 22:08:29 2009
New Revision: 199869
URL: http://svn.freebsd.org/changeset/base/199869

Log:
  Support the new VM_PROT_COPY option on wired pages.  The effect of which
  is that a debugger can now set a breakpoint in a program that uses mlock(2)
  on its text segment or mlockall(2) on its entire address space.

Modified:
  head/sys/vm/vm_fault.c

Modified: head/sys/vm/vm_fault.c
==============================================================================
--- head/sys/vm/vm_fault.c	Fri Nov 27 20:24:11 2009	(r199868)
+++ head/sys/vm/vm_fault.c	Fri Nov 27 22:08:29 2009	(r199869)
@@ -273,7 +273,7 @@ RetryFault:;
 	fs.lookup_still_valid = TRUE;
 
 	if (wired)
-		fault_type = prot;
+		fault_type = prot | (fault_type & VM_PROT_COPY);
 
 	fs.first_m = NULL;
 
@@ -759,8 +759,11 @@ vnode_locked:
 				 */
 				pmap_copy_page(fs.m, fs.first_m);
 				fs.first_m->valid = VM_PAGE_BITS_ALL;
-			}
-			if (fs.m) {
+				if (wired && (fault_flags &
+				    VM_FAULT_CHANGE_WIRING) == 0) {
+					vm_page_wire(fs.first_m);
+					vm_page_unwire(fs.m, FALSE);
+				}
 				/*
 				 * We no longer need the old page or object.
 				 */


More information about the svn-src-head mailing list