Skip to content

Commit 6b609e3

Browse files
committed
Merge branch 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs fixes from Al Viro. * 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: gfs2_meta: ->mount() can get NULL dev_name ecryptfs_rename(): verify that lower dentries are still OK after lock_rename() cachefiles: fix the race between cachefiles_bury_object() and rmdir(2)
2 parents deba28b + 3df629d commit 6b609e3

File tree

2 files changed

+11
-3
lines changed

2 files changed

+11
-3
lines changed

fs/ecryptfs/inode.c

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -593,11 +593,16 @@ ecryptfs_rename(struct inode *old_dir, struct dentry *old_dentry,
593593
lower_new_dir_dentry = dget_parent(lower_new_dentry);
594594
target_inode = d_inode(new_dentry);
595595
trap = lock_rename(lower_old_dir_dentry, lower_new_dir_dentry);
596+
rc = -EINVAL;
597+
if (lower_old_dentry->d_parent != lower_old_dir_dentry)
598+
goto out_lock;
599+
if (lower_new_dentry->d_parent != lower_new_dir_dentry)
600+
goto out_lock;
601+
if (d_unhashed(lower_old_dentry) || d_unhashed(lower_new_dentry))
602+
goto out_lock;
596603
/* source should not be ancestor of target */
597-
if (trap == lower_old_dentry) {
598-
rc = -EINVAL;
604+
if (trap == lower_old_dentry)
599605
goto out_lock;
600-
}
601606
/* target should not be ancestor of source */
602607
if (trap == lower_new_dentry) {
603608
rc = -ENOTEMPTY;

fs/gfs2/ops_fstype.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1333,6 +1333,9 @@ static struct dentry *gfs2_mount_meta(struct file_system_type *fs_type,
13331333
struct path path;
13341334
int error;
13351335

1336+
if (!dev_name || !*dev_name)
1337+
return ERR_PTR(-EINVAL);
1338+
13361339
error = kern_path(dev_name, LOOKUP_FOLLOW, &path);
13371340
if (error) {
13381341
pr_warn("path_lookup on %s returned error %d\n",

0 commit comments

Comments
 (0)