Home
last modified time | relevance | path

Searched refs:i_rwsem (Results 1 – 25 of 27) sorted by relevance

12

/Linux-v6.1/fs/ceph/
Dio.c24 lockdep_assert_held_write(&inode->i_rwsem); in ceph_block_o_direct()
56 down_read(&inode->i_rwsem); in ceph_start_io_read()
59 up_read(&inode->i_rwsem); in ceph_start_io_read()
61 down_write(&inode->i_rwsem); in ceph_start_io_read()
63 downgrade_write(&inode->i_rwsem); in ceph_start_io_read()
76 up_read(&inode->i_rwsem); in ceph_end_io_read()
89 down_write(&inode->i_rwsem); in ceph_start_io_write()
103 up_write(&inode->i_rwsem); in ceph_end_io_write()
109 lockdep_assert_held_write(&inode->i_rwsem); in ceph_block_buffered()
142 down_read(&inode->i_rwsem); in ceph_start_io_direct()
[all …]
/Linux-v6.1/fs/nfs/
Dio.c47 down_read(&inode->i_rwsem); in nfs_start_io_read()
50 up_read(&inode->i_rwsem); in nfs_start_io_read()
52 down_write(&inode->i_rwsem); in nfs_start_io_read()
54 downgrade_write(&inode->i_rwsem); in nfs_start_io_read()
67 up_read(&inode->i_rwsem); in nfs_end_io_read()
80 down_write(&inode->i_rwsem); in nfs_start_io_write()
94 up_write(&inode->i_rwsem); in nfs_end_io_write()
127 down_read(&inode->i_rwsem); in nfs_start_io_direct()
130 up_read(&inode->i_rwsem); in nfs_start_io_direct()
132 down_write(&inode->i_rwsem); in nfs_start_io_direct()
[all …]
/Linux-v6.1/Documentation/filesystems/
Ddirectory-locking.rst7 kinds of locks - per-inode (->i_rwsem) and per-filesystem
10 When taking the i_rwsem on multiple non-directory objects, we
58 All ->i_rwsem are taken exclusive. Again, we might get away with locking
94 Thus all processes are blocked on ->i_rwsem.
Dlocking.rst92 ops i_rwsem(inode)
119 Additionally, ->rmdir(), ->unlink() and ->rename() have ->i_rwsem
144 ops i_rwsem(inode)
269 ops folio locked i_rwsem invalidate_lock
554 ->iterate() is called with i_rwsem exclusive.
556 ->iterate_shared() is called with i_rwsem at least shared.
590 blocking changes through write(2) and similar operations inode->i_rwsem can be
Dpath-lookup.rst246 inode->i_rwsem
249 ``i_rwsem`` is a read/write semaphore that serializes all changes to a particular
256 This has a complementary role to that of ``d_lock``: ``i_rwsem`` on a
259 dcache hold ``i_rwsem`` on the relevant directory inode and briefly take
262 memory pressure. This uses ``d_lock``, but ``i_rwsem`` plays no role.
268 falls back to ``lookup_slow()`` which takes a shared lock on ``i_rwsem``, checks again that
274 sometimes need to take an exclusive lock on ``i_rwsem`` before performing the last lookup so
276 to take, or not take, ``i_rwsem`` is one of the
280 name that is not yet in the dcache - the shared lock on ``i_rwsem`` will
287 ``i_rwsem``, a thread must call ``d_alloc_parallel()``. This allocates a
[all …]
Dgfs2-glocks.rst116 1. i_rwsem (if required)
Dvfs.rst603 (in this case with i_rwsem locked exclusive). If unset, then
609 i_rwsem exclusive. If unset, then fall back to f_op->ioctl().
Dporting.rst675 ->i_mutex is replaced with ->i_rwsem now. inode_lock() et.al. work as
/Linux-v6.1/fs/xfs/
Dxfs_inode.c195 down_write_nested(&VFS_I(ip)->i_rwsem, in xfs_ilock()
198 down_read_nested(&VFS_I(ip)->i_rwsem, in xfs_ilock()
238 if (!down_write_trylock(&VFS_I(ip)->i_rwsem)) in xfs_ilock_nowait()
241 if (!down_read_trylock(&VFS_I(ip)->i_rwsem)) in xfs_ilock_nowait()
269 up_write(&VFS_I(ip)->i_rwsem); in xfs_ilock_nowait()
271 up_read(&VFS_I(ip)->i_rwsem); in xfs_ilock_nowait()
296 up_write(&VFS_I(ip)->i_rwsem); in xfs_iunlock()
298 up_read(&VFS_I(ip)->i_rwsem); in xfs_iunlock()
331 downgrade_write(&VFS_I(ip)->i_rwsem); in xfs_ilock_demote()
374 return __xfs_rwsem_islocked(&VFS_I(ip)->i_rwsem, in xfs_isilocked()
Dxfs_iops.c1279 lockdep_set_class(&inode->i_rwsem, in xfs_setup_inode()
Dxfs_icache.c356 ASSERT(!rwsem_is_locked(&inode->i_rwsem)); in xfs_iget_recycle()
Dxfs_super.c647 ASSERT(!rwsem_is_locked(&inode->i_rwsem)); in xfs_fs_destroy_inode()
/Linux-v6.1/fs/orangefs/
Dfile.c329 down_read(&file_inode(iocb->ki_filp)->i_rwsem); in orangefs_file_read_iter()
336 up_read(&file_inode(iocb->ki_filp)->i_rwsem); in orangefs_file_read_iter()
/Linux-v6.1/include/linux/
Dfs.h643 struct rw_semaphore i_rwsem; member
756 down_write(&inode->i_rwsem); in inode_lock()
761 up_write(&inode->i_rwsem); in inode_unlock()
766 down_read(&inode->i_rwsem); in inode_lock_shared()
771 up_read(&inode->i_rwsem); in inode_unlock_shared()
776 return down_write_trylock(&inode->i_rwsem); in inode_trylock()
781 return down_read_trylock(&inode->i_rwsem); in inode_trylock_shared()
786 return rwsem_is_locked(&inode->i_rwsem); in inode_is_locked()
791 down_write_nested(&inode->i_rwsem, subclass); in inode_lock_nested()
796 down_read_nested(&inode->i_rwsem, subclass); in inode_lock_shared_nested()
/Linux-v6.1/fs/configfs/
Dinode.c135 lockdep_set_class(&inode->i_rwsem, in configfs_set_inode_lock_class()
/Linux-v6.1/fs/
Dreaddir.c55 res = down_read_killable(&inode->i_rwsem); in iterate_dir()
57 res = down_write_killable(&inode->i_rwsem); in iterate_dir()
Dinode.c198 init_rwsem(&inode->i_rwsem); in inode_init_always()
199 lockdep_set_class(&inode->i_rwsem, &sb->s_type->i_mutex_key); in inode_init_always()
1060 if (lockdep_match_class(&inode->i_rwsem, &type->i_mutex_key)) { in lockdep_annotate_inode_mutex_key()
1065 init_rwsem(&inode->i_rwsem); in lockdep_annotate_inode_mutex_key()
1066 lockdep_set_class(&inode->i_rwsem, in lockdep_annotate_inode_mutex_key()
Ddax.c1452 lockdep_assert_held_write(&iomi.inode->i_rwsem); in dax_iomap_rw()
1455 lockdep_assert_held(&iomi.inode->i_rwsem); in dax_iomap_rw()
/Linux-v6.1/lib/
Dtest_lockup.c548 lock_rwsem_ptr = (unsigned long)&test_inode->i_rwsem; in test_lockup_init()
/Linux-v6.1/fs/overlayfs/
Dinode.c804 lockdep_set_class(&inode->i_rwsem, &ovl_i_mutex_dir_key[depth]); in ovl_lockdep_annotate_inode_mutex_key()
806 lockdep_set_class(&inode->i_rwsem, &ovl_i_mutex_key[depth]); in ovl_lockdep_annotate_inode_mutex_key()
Dreaddir.c276 err = down_write_killable(&dir->d_inode->i_rwsem); in ovl_check_whiteouts()
/Linux-v6.1/fs/ocfs2/
Dinode.c245 lockdep_set_class(&inode->i_rwsem, in ocfs2_init_locked_inode()
/Linux-v6.1/fs/gfs2/
Dops_fstype.c914 lockdep_set_class(&sdp->sd_quota_inode->i_rwsem, in init_inodes()
/Linux-v6.1/fs/btrfs/
Ddelayed-inode.c1698 downgrade_write(&inode->i_rwsem); in btrfs_readdir_put_delayed_items()
Dioctl.c954 error = down_write_killable_nested(&dir->i_rwsem, I_MUTEX_PARENT); in btrfs_mksubvol()
3362 err = down_write_killable_nested(&dir->i_rwsem, I_MUTEX_PARENT); in btrfs_ioctl_snap_destroy()

12