Skip to content

Commit 91cdeb0

Browse files
bharathsm-msgregkh
authored andcommitted
cifs: defer close file handles having RH lease
[ Upstream commit dc52877 ] Previously we only deferred closing file handles with RHW lease. To enhance performance benefits from deferred closes, we now include handles with RH leases as well. Signed-off-by: Bharath SM <[email protected]> Signed-off-by: Steve French <[email protected]> Signed-off-by: Sasha Levin <[email protected]>
1 parent 8df4bcd commit 91cdeb0

File tree

1 file changed

+15
-4
lines changed

1 file changed

+15
-4
lines changed

fs/smb/client/file.c

Lines changed: 15 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1152,6 +1152,19 @@ void smb2_deferred_work_close(struct work_struct *work)
11521152
_cifsFileInfo_put(cfile, true, false);
11531153
}
11541154

1155+
static bool
1156+
smb2_can_defer_close(struct inode *inode, struct cifs_deferred_close *dclose)
1157+
{
1158+
struct cifs_sb_info *cifs_sb = CIFS_SB(inode->i_sb);
1159+
struct cifsInodeInfo *cinode = CIFS_I(inode);
1160+
1161+
return (cifs_sb->ctx->closetimeo && cinode->lease_granted && dclose &&
1162+
(cinode->oplock == CIFS_CACHE_RHW_FLG ||
1163+
cinode->oplock == CIFS_CACHE_RH_FLG) &&
1164+
!test_bit(CIFS_INO_CLOSE_ON_LOCK, &cinode->flags));
1165+
1166+
}
1167+
11551168
int cifs_close(struct inode *inode, struct file *file)
11561169
{
11571170
struct cifsFileInfo *cfile;
@@ -1165,10 +1178,8 @@ int cifs_close(struct inode *inode, struct file *file)
11651178
cfile = file->private_data;
11661179
file->private_data = NULL;
11671180
dclose = kmalloc(sizeof(struct cifs_deferred_close), GFP_KERNEL);
1168-
if ((cifs_sb->ctx->closetimeo && cinode->oplock == CIFS_CACHE_RHW_FLG)
1169-
&& cinode->lease_granted &&
1170-
!test_bit(CIFS_INO_CLOSE_ON_LOCK, &cinode->flags) &&
1171-
dclose && !(cfile->status_file_deleted)) {
1181+
if ((cfile->status_file_deleted == false) &&
1182+
(smb2_can_defer_close(inode, dclose))) {
11721183
if (test_and_clear_bit(CIFS_INO_MODIFIED_ATTR, &cinode->flags)) {
11731184
inode_set_mtime_to_ts(inode,
11741185
inode_set_ctime_current(inode));

0 commit comments

Comments
 (0)