summaryrefslogtreecommitdiffstats
path: root/drivers/fsi
diff options
context:
space:
mode:
authorBaokun Li <libaokun1@huawei.com>2023-06-30 19:08:22 +0800
committerSasha Levin <sashal@kernel.org>2024-03-26 18:22:39 -0400
commit248699a705f31211c0d7cc9e0d79cbbabbc9c791 (patch)
treedb0c0909ef0215433734f939a61892b7393f749a /drivers/fsi
parente87ed533e7a6167f4a5e1b0fdbf21784acf115cc (diff)
downloadlinux-stable-248699a705f31211c0d7cc9e0d79cbbabbc9c791.tar.gz
linux-stable-248699a705f31211c0d7cc9e0d79cbbabbc9c791.tar.bz2
linux-stable-248699a705f31211c0d7cc9e0d79cbbabbc9c791.zip
quota: simplify drop_dquot_ref()
[ Upstream commit 7bce48f0fec602b3b6c335963b26d9eefa417788 ] As Honza said, remove_inode_dquot_ref() currently does not release the last dquot reference but instead adds the dquot to tofree_head list. This is because dqput() can sleep while dropping of the last dquot reference (writing back the dquot and calling ->release_dquot()) and that must not happen under dq_list_lock. Now that dqput() queues the final dquot cleanup into a workqueue, remove_inode_dquot_ref() can call dqput() unconditionally and we can significantly simplify it. Here we open code the simplified code of remove_inode_dquot_ref() into remove_dquot_ref() and remove the function put_dquot_list() which is no longer used. Signed-off-by: Baokun Li <libaokun1@huawei.com> Signed-off-by: Jan Kara <jack@suse.cz> Message-Id: <20230630110822.3881712-6-libaokun1@huawei.com> Stable-dep-of: 179b8c97ebf6 ("quota: Fix rcu annotations of inode dquot pointers") Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'drivers/fsi')
0 files changed, 0 insertions, 0 deletions