diff options
Diffstat (limited to 'fs/ecryptfs')
| -rw-r--r-- | fs/ecryptfs/dentry.c | 6 | ||||
| -rw-r--r-- | fs/ecryptfs/inode.c | 5 |
2 files changed, 10 insertions, 1 deletions
diff --git a/fs/ecryptfs/dentry.c b/fs/ecryptfs/dentry.c index 0b9992ab990f..52d1e36dc746 100644 --- a/fs/ecryptfs/dentry.c +++ b/fs/ecryptfs/dentry.c | |||
| @@ -57,6 +57,12 @@ static int ecryptfs_d_revalidate(struct dentry *dentry, struct nameidata *nd) | |||
| 57 | rc = lower_dentry->d_op->d_revalidate(lower_dentry, nd); | 57 | rc = lower_dentry->d_op->d_revalidate(lower_dentry, nd); |
| 58 | nd->dentry = dentry_save; | 58 | nd->dentry = dentry_save; |
| 59 | nd->mnt = vfsmount_save; | 59 | nd->mnt = vfsmount_save; |
| 60 | if (dentry->d_inode) { | ||
| 61 | struct inode *lower_inode = | ||
| 62 | ecryptfs_inode_to_lower(dentry->d_inode); | ||
| 63 | |||
| 64 | ecryptfs_copy_attr_all(dentry->d_inode, lower_inode); | ||
| 65 | } | ||
| 60 | out: | 66 | out: |
| 61 | return rc; | 67 | return rc; |
| 62 | } | 68 | } |
diff --git a/fs/ecryptfs/inode.c b/fs/ecryptfs/inode.c index ff4865d24f0f..dfcc68484f47 100644 --- a/fs/ecryptfs/inode.c +++ b/fs/ecryptfs/inode.c | |||
| @@ -470,6 +470,7 @@ out_lock: | |||
| 470 | unlock_dir(lower_dir_dentry); | 470 | unlock_dir(lower_dir_dentry); |
| 471 | dput(lower_new_dentry); | 471 | dput(lower_new_dentry); |
| 472 | dput(lower_old_dentry); | 472 | dput(lower_old_dentry); |
| 473 | d_drop(lower_old_dentry); | ||
| 473 | d_drop(new_dentry); | 474 | d_drop(new_dentry); |
| 474 | d_drop(old_dentry); | 475 | d_drop(old_dentry); |
| 475 | return rc; | 476 | return rc; |
| @@ -484,7 +485,7 @@ static int ecryptfs_unlink(struct inode *dir, struct dentry *dentry) | |||
| 484 | lock_parent(lower_dentry); | 485 | lock_parent(lower_dentry); |
| 485 | rc = vfs_unlink(lower_dir_inode, lower_dentry); | 486 | rc = vfs_unlink(lower_dir_inode, lower_dentry); |
| 486 | if (rc) { | 487 | if (rc) { |
| 487 | ecryptfs_printk(KERN_ERR, "Error in vfs_unlink\n"); | 488 | printk(KERN_ERR "Error in vfs_unlink; rc = [%d]\n", rc); |
| 488 | goto out_unlock; | 489 | goto out_unlock; |
| 489 | } | 490 | } |
| 490 | ecryptfs_copy_attr_times(dir, lower_dir_inode); | 491 | ecryptfs_copy_attr_times(dir, lower_dir_inode); |
| @@ -630,6 +631,8 @@ ecryptfs_rename(struct inode *old_dir, struct dentry *old_dentry, | |||
| 630 | ecryptfs_copy_attr_all(old_dir, lower_old_dir_dentry->d_inode); | 631 | ecryptfs_copy_attr_all(old_dir, lower_old_dir_dentry->d_inode); |
| 631 | out_lock: | 632 | out_lock: |
| 632 | unlock_rename(lower_old_dir_dentry, lower_new_dir_dentry); | 633 | unlock_rename(lower_old_dir_dentry, lower_new_dir_dentry); |
| 634 | dput(lower_new_dentry->d_parent); | ||
| 635 | dput(lower_old_dentry->d_parent); | ||
| 633 | dput(lower_new_dentry); | 636 | dput(lower_new_dentry); |
| 634 | dput(lower_old_dentry); | 637 | dput(lower_old_dentry); |
| 635 | return rc; | 638 | return rc; |
