diff options
author | Amir Goldstein <amir73il@gmail.com> | 2017-06-05 15:44:49 -0400 |
---|---|---|
committer | Miklos Szeredi <mszeredi@redhat.com> | 2017-07-04 16:03:15 -0400 |
commit | f681eb1d5c02c9e79775e10363057d034c720efc (patch) | |
tree | ea4f2c8b94ba19eacdd56a912a59187d3122ae17 | |
parent | 7f53b7d047d221b9fe38b9f2203bd4499135be88 (diff) |
ovl: fix nlink leak in ovl_rename()
This patch fixes an overlay inode nlink leak in the case where
ovl_rename() renames over a non-dir.
This is not so critical, because overlay inode doesn't rely on
nlink dropping to zero for inode deletion.
Signed-off-by: Amir Goldstein <amir73il@gmail.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
-rw-r--r-- | fs/overlayfs/dir.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/fs/overlayfs/dir.c b/fs/overlayfs/dir.c index a63a71656e9b..fcfa7de12ad5 100644 --- a/fs/overlayfs/dir.c +++ b/fs/overlayfs/dir.c | |||
@@ -1046,6 +1046,13 @@ static int ovl_rename(struct inode *olddir, struct dentry *old, | |||
1046 | if (cleanup_whiteout) | 1046 | if (cleanup_whiteout) |
1047 | ovl_cleanup(old_upperdir->d_inode, newdentry); | 1047 | ovl_cleanup(old_upperdir->d_inode, newdentry); |
1048 | 1048 | ||
1049 | if (overwrite && d_inode(new)) { | ||
1050 | if (new_is_dir) | ||
1051 | clear_nlink(d_inode(new)); | ||
1052 | else | ||
1053 | drop_nlink(d_inode(new)); | ||
1054 | } | ||
1055 | |||
1049 | ovl_dentry_version_inc(old->d_parent); | 1056 | ovl_dentry_version_inc(old->d_parent); |
1050 | ovl_dentry_version_inc(new->d_parent); | 1057 | ovl_dentry_version_inc(new->d_parent); |
1051 | 1058 | ||