1. 12 4月, 2006 1 次提交
    • M
      [fuse] fix deadlock between fuse_put_super() and request_end() · 73ce8355
      Miklos Szeredi 提交于
      A deadlock was possible, when the last reference to the superblock was
      held due to a background request containing a file reference.
      
      Releasing the file would release the vfsmount which in turn would
      release the superblock.  Since sbput_sem is held during the fput() and
      fuse_put_super() tries to acquire this same semaphore, a deadlock
      results.
      
      The chosen soltuion is to get rid of sbput_sem, and instead use the
      spinlock to ensure the referenced inodes/file are released only once.
      Since the actual release may sleep, defer these outside the locked
      region, but using local variables instead of the structure members.
      
      This is a much more rubust solution.
      Signed-off-by: NMiklos Szeredi <miklos@szeredi.hu>
      73ce8355
  2. 11 4月, 2006 8 次提交
  3. 29 3月, 2006 1 次提交
  4. 18 2月, 2006 1 次提交
  5. 06 2月, 2006 1 次提交
  6. 17 1月, 2006 13 次提交
  7. 07 1月, 2006 3 次提交
  8. 07 11月, 2005 1 次提交
  9. 31 10月, 2005 1 次提交
  10. 10 9月, 2005 5 次提交