Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 30 Jul 2008 18:16:06 +0000 (UTC)
From:      Konstantin Belousov <kib@FreeBSD.org>
To:        src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org
Subject:   cvs commit: src/sys/vm vnode_pager.c
Message-ID:  <200807301819.m6UIJmY4004034@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
kib         2008-07-30 18:16:06 UTC

  FreeBSD src repository

  Modified files:
    sys/vm               vnode_pager.c 
  Log:
  SVN rev 181004 on 2008-07-30 18:16:06Z by kib
  
  The behaviour of the lockmgr going back at least to the 4.4BSD-Lite2 was
  to downgrade the exclusive lock to shared one when exclusive lock owner
  requested shared lock. New lockmgr panics instead.
  
  The vnode_pager_lock function requests shared lock on the vnode backing
  the OBJT_VNODE, and can be called when the current thread already holds
  an exlcusive lock on the vnode. For instance, it happens when handling
  page fault from the VOP_WRITE() uiomove that writes to the file, with
  the faulted in page fetched from the vm object backed by the same file.
  We then get the situation described above.
  
  Verify whether the vnode is already exclusively locked by the curthread
  and request recursed exclusive vnode lock instead of shared, if true.
  
  Reported by:    gallatin
  Discussed with: attilio
  
  Revision  Changes    Path
  1.243     +9 -2      src/sys/vm/vnode_pager.c



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200807301819.m6UIJmY4004034>