From owner-svn-src-user@FreeBSD.ORG Thu Apr 29 22:42:19 2010 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 564211065670; Thu, 29 Apr 2010 22:42:19 +0000 (UTC) (envelope-from kmacy@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [69.147.83.44]) by mx1.freebsd.org (Postfix) with ESMTP id 453068FC13; Thu, 29 Apr 2010 22:42:19 +0000 (UTC) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id o3TMgJuG080534; Thu, 29 Apr 2010 22:42:19 GMT (envelope-from kmacy@svn.freebsd.org) Received: (from kmacy@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id o3TMgJeV080532; Thu, 29 Apr 2010 22:42:19 GMT (envelope-from kmacy@svn.freebsd.org) Message-Id: <201004292242.o3TMgJeV080532@svn.freebsd.org> From: Kip Macy Date: Thu, 29 Apr 2010 22:42:19 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r207398 - user/kmacy/head_page_lock_incr/sys/ia64/ia64 X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.5 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: Thu, 29 Apr 2010 22:42:19 -0000 Author: kmacy Date: Thu Apr 29 22:42:18 2010 New Revision: 207398 URL: http://svn.freebsd.org/changeset/base/207398 Log: add page lock hold support to ia64 Modified: user/kmacy/head_page_lock_incr/sys/ia64/ia64/pmap.c Modified: user/kmacy/head_page_lock_incr/sys/ia64/ia64/pmap.c ============================================================================== --- user/kmacy/head_page_lock_incr/sys/ia64/ia64/pmap.c Thu Apr 29 22:40:12 2010 (r207397) +++ user/kmacy/head_page_lock_incr/sys/ia64/ia64/pmap.c Thu Apr 29 22:42:18 2010 (r207398) @@ -1028,18 +1028,22 @@ pmap_extract_and_hold(pmap_t pmap, vm_of struct ia64_lpte *pte; pmap_t oldpmap; vm_page_t m; + vm_paddr_t pa; + pa = 0; m = NULL; - vm_page_lock_queues(); PMAP_LOCK(pmap); oldpmap = pmap_switch(pmap); +retry: pte = pmap_find_vhpt(va); if (pte != NULL && pmap_present(pte) && (pmap_prot(pte) & prot) == prot) { m = PHYS_TO_VM_PAGE(pmap_ppn(pte)); + if (vm_page_pa_tryrelock(pmap, pmap_ppn(pte), &pa)) + goto retry; vm_page_hold(m); } - vm_page_unlock_queues(); + PA_UNLOCK_COND(pa); pmap_switch(oldpmap); PMAP_UNLOCK(pmap); return (m);