diff options
author | Darrick J. Wong <djwong@kernel.org> | 2021-01-27 12:07:57 -0800 |
---|---|---|
committer | Darrick J. Wong <djwong@kernel.org> | 2021-02-03 09:18:49 -0800 |
commit | f2f7b9ff62a28928f6fe2bd55cdb4d4b02ab7477 (patch) | |
tree | f6fbded8c9f4b87453a546dbcbecc26a942ca9b4 /fs/cifs | |
parent | f273387b048543f2b8b2d809cc65fca28e7788a1 (diff) | |
download | linux-stable-f2f7b9ff62a28928f6fe2bd55cdb4d4b02ab7477.tar.gz linux-stable-f2f7b9ff62a28928f6fe2bd55cdb4d4b02ab7477.tar.bz2 linux-stable-f2f7b9ff62a28928f6fe2bd55cdb4d4b02ab7477.zip |
xfs: refactor inode creation transaction/inode/quota allocation idiom
For file creation, create a new helper xfs_trans_alloc_icreate that
allocates a transaction and reserves the appropriate amount of quota
against that transction. Replace all the open-coded idioms with a
single call to this helper so that we can contain the retry loops in the
next patchset.
This changes the locking behavior for non-tempfile creation slightly, in
that we now make the quota reservation without holding the directory
ILOCK. While the dquots chosen for inode creation are based on the
directory state at a given point in time, the directory ILOCK was
released as soon as the dquot references are picked up. Hence it was
never necessary to hold the directory ILOCK for the quota reservation.
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'fs/cifs')
0 files changed, 0 insertions, 0 deletions