From owner-svn-src-user@FreeBSD.ORG Tue May 21 17:40:23 2013 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.FreeBSD.org [8.8.178.115]) by hub.freebsd.org (Postfix) with ESMTP id 3BE905AE; Tue, 21 May 2013 17:40:23 +0000 (UTC) (envelope-from attilio@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) by mx1.freebsd.org (Postfix) with ESMTP id 2F056EE; Tue, 21 May 2013 17:40:23 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.6/8.14.6) with ESMTP id r4LHeNKU085281; Tue, 21 May 2013 17:40:23 GMT (envelope-from attilio@svn.freebsd.org) Received: (from attilio@localhost) by svn.freebsd.org (8.14.6/8.14.5/Submit) id r4LHeMYV085277; Tue, 21 May 2013 17:40:22 GMT (envelope-from attilio@svn.freebsd.org) Message-Id: <201305211740.r4LHeMYV085277@svn.freebsd.org> From: Attilio Rao Date: Tue, 21 May 2013 17:40:22 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r250862 - user/attilio/vmobj-readlock/sys/vm X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 21 May 2013 17:40:23 -0000 Author: attilio Date: Tue May 21 17:40:22 2013 New Revision: 250862 URL: http://svnweb.freebsd.org/changeset/base/250862 Log: Reinsert VM_OBJECT_LOCK_DOWNGRADE(). Sponsored by: EMC / Isilon storage division Requested by: alc Modified: user/attilio/vmobj-readlock/sys/vm/vm_map.c user/attilio/vmobj-readlock/sys/vm/vm_object.h Modified: user/attilio/vmobj-readlock/sys/vm/vm_map.c ============================================================================== --- user/attilio/vmobj-readlock/sys/vm/vm_map.c Tue May 21 17:30:27 2013 (r250861) +++ user/attilio/vmobj-readlock/sys/vm/vm_map.c Tue May 21 17:40:22 2013 (r250862) @@ -1806,7 +1806,6 @@ vm_map_pmap_enter(vm_map_t map, vm_offse if ((prot & (VM_PROT_READ | VM_PROT_EXECUTE)) == 0 || object == NULL) return; -relock: VM_OBJECT_RLOCK(object); if (object->type == OBJT_DEVICE || object->type == OBJT_SG) { VM_OBJECT_RUNLOCK(object); @@ -1817,8 +1816,7 @@ relock: VM_OBJECT_WUNLOCK(object); return; } - VM_OBJECT_WUNLOCK(object); - goto relock; + VM_OBJECT_LOCK_DOWNGRADE(object); } psize = atop(size); Modified: user/attilio/vmobj-readlock/sys/vm/vm_object.h ============================================================================== --- user/attilio/vmobj-readlock/sys/vm/vm_object.h Tue May 21 17:30:27 2013 (r250861) +++ user/attilio/vmobj-readlock/sys/vm/vm_object.h Tue May 21 17:40:22 2013 (r250862) @@ -223,6 +223,8 @@ extern struct vm_object kmem_object_stor rw_assert(&(object)->lock, RA_RLOCKED) #define VM_OBJECT_ASSERT_WLOCKED(object) \ rw_assert(&(object)->lock, RA_WLOCKED) +#define VM_OBJECT_LOCK_DOWNGRADE(object) \ + rw_downgrade(&(object)->lock) #define VM_OBJECT_RLOCK(object) \ rw_rlock(&(object)->lock) #define VM_OBJECT_RUNLOCK(object) \