Module Name:    src
Committed By:   rmind
Date:           Fri Jun 24 01:39:22 UTC 2011

Modified Files:
        src/sys/uvm: uvm_amap.c uvm_anon.c uvm_anon.h uvm_fault.c

Log Message:
Fix uvmplock regression - a lock against oneself case in amap_swap_off().
Happens since amap is NULL in uvmfault_anonget(), so uvmfault_unlockall()
keeps anon locked, when it should unlock it.


To generate a diff of this commit:
cvs rdiff -u -r1.97 -r1.98 src/sys/uvm/uvm_amap.c
cvs rdiff -u -r1.56 -r1.57 src/sys/uvm/uvm_anon.c
cvs rdiff -u -r1.28 -r1.29 src/sys/uvm/uvm_anon.h
cvs rdiff -u -r1.187 -r1.188 src/sys/uvm/uvm_fault.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/uvm/uvm_amap.c
diff -u src/sys/uvm/uvm_amap.c:1.97 src/sys/uvm/uvm_amap.c:1.98
--- src/sys/uvm/uvm_amap.c:1.97	Fri Jun 24 01:03:08 2011
+++ src/sys/uvm/uvm_amap.c	Fri Jun 24 01:39:22 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: uvm_amap.c,v 1.97 2011/06/24 01:03:08 rmind Exp $	*/
+/*	$NetBSD: uvm_amap.c,v 1.98 2011/06/24 01:39:22 rmind Exp $	*/
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -35,7 +35,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_amap.c,v 1.97 2011/06/24 01:03:08 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_amap.c,v 1.98 2011/06/24 01:39:22 rmind Exp $");
 
 #include "opt_uvmhist.h"
 
@@ -1358,7 +1358,7 @@
 
 			am->am_flags |= AMAP_SWAPOFF;
 
-			rv = uvm_anon_pagein(anon);
+			rv = uvm_anon_pagein(am, anon);
 			amap_lock(am);
 
 			am->am_flags &= ~AMAP_SWAPOFF;

Index: src/sys/uvm/uvm_anon.c
diff -u src/sys/uvm/uvm_anon.c:1.56 src/sys/uvm/uvm_anon.c:1.57
--- src/sys/uvm/uvm_anon.c:1.56	Fri Jun 24 01:23:05 2011
+++ src/sys/uvm/uvm_anon.c	Fri Jun 24 01:39:22 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: uvm_anon.c,v 1.56 2011/06/24 01:23:05 yamt Exp $	*/
+/*	$NetBSD: uvm_anon.c,v 1.57 2011/06/24 01:39:22 rmind Exp $	*/
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_anon.c,v 1.56 2011/06/24 01:23:05 yamt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_anon.c,v 1.57 2011/06/24 01:39:22 rmind Exp $");
 
 #include "opt_uvmhist.h"
 
@@ -311,18 +311,19 @@
  */
 
 bool
-uvm_anon_pagein(struct vm_anon *anon)
+uvm_anon_pagein(struct vm_amap *amap, struct vm_anon *anon)
 {
 	struct vm_page *pg;
 	struct uvm_object *uobj;
 
 	KASSERT(mutex_owned(anon->an_lock));
+	KASSERT(anon->an_lock == amap->am_lock);
 
 	/*
 	 * Get the page of the anon.
 	 */
 
-	switch (uvmfault_anonget(NULL, NULL, anon)) {
+	switch (uvmfault_anonget(NULL, amap, anon)) {
 	case 0:
 		/* Success - we have the page. */
 		KASSERT(mutex_owned(anon->an_lock));

Index: src/sys/uvm/uvm_anon.h
diff -u src/sys/uvm/uvm_anon.h:1.28 src/sys/uvm/uvm_anon.h:1.29
--- src/sys/uvm/uvm_anon.h:1.28	Sun Jun 12 03:36:02 2011
+++ src/sys/uvm/uvm_anon.h	Fri Jun 24 01:39:22 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: uvm_anon.h,v 1.28 2011/06/12 03:36:02 rmind Exp $	*/
+/*	$NetBSD: uvm_anon.h,v 1.29 2011/06/24 01:39:22 rmind Exp $	*/
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -109,7 +109,7 @@
 #define	uvm_anon_dropswap(a)	/* nothing */
 #endif /* defined(VMSWAP) */
 void uvm_anon_release(struct vm_anon *);
-bool uvm_anon_pagein(struct vm_anon *);
+bool uvm_anon_pagein(struct vm_amap *, struct vm_anon *);
 #endif /* _KERNEL */
 
 #endif /* _UVM_UVM_ANON_H_ */

Index: src/sys/uvm/uvm_fault.c
diff -u src/sys/uvm/uvm_fault.c:1.187 src/sys/uvm/uvm_fault.c:1.188
--- src/sys/uvm/uvm_fault.c:1.187	Thu Jun 23 17:36:59 2011
+++ src/sys/uvm/uvm_fault.c	Fri Jun 24 01:39:22 2011
@@ -1,4 +1,4 @@
-/*	$NetBSD: uvm_fault.c,v 1.187 2011/06/23 17:36:59 rmind Exp $	*/
+/*	$NetBSD: uvm_fault.c,v 1.188 2011/06/24 01:39:22 rmind Exp $	*/
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_fault.c,v 1.187 2011/06/23 17:36:59 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_fault.c,v 1.188 2011/06/24 01:39:22 rmind Exp $");
 
 #include "opt_uvmhist.h"
 
@@ -275,7 +275,7 @@
 
 	UVMHIST_FUNC("uvmfault_anonget"); UVMHIST_CALLED(maphist);
 	KASSERT(mutex_owned(anon->an_lock));
-	KASSERT(amap == NULL || anon->an_lock == amap->am_lock);
+	KASSERT(anon->an_lock == amap->am_lock);
 
 	/* Increment the counters.*/
 	uvmexp.fltanget++;

Reply via email to