diff options
Diffstat (limited to 'fs/ecryptfs/main.c')
| -rw-r--r-- | fs/ecryptfs/main.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/fs/ecryptfs/main.c b/fs/ecryptfs/main.c index 9f0aa9883c28..c6ac85d6c701 100644 --- a/fs/ecryptfs/main.c +++ b/fs/ecryptfs/main.c | |||
| @@ -35,6 +35,7 @@ | |||
| 35 | #include <linux/key.h> | 35 | #include <linux/key.h> |
| 36 | #include <linux/parser.h> | 36 | #include <linux/parser.h> |
| 37 | #include <linux/fs_stack.h> | 37 | #include <linux/fs_stack.h> |
| 38 | #include <linux/ima.h> | ||
| 38 | #include "ecryptfs_kernel.h" | 39 | #include "ecryptfs_kernel.h" |
| 39 | 40 | ||
| 40 | /** | 41 | /** |
| @@ -118,6 +119,7 @@ int ecryptfs_init_persistent_file(struct dentry *ecryptfs_dentry) | |||
| 118 | const struct cred *cred = current_cred(); | 119 | const struct cred *cred = current_cred(); |
| 119 | struct ecryptfs_inode_info *inode_info = | 120 | struct ecryptfs_inode_info *inode_info = |
| 120 | ecryptfs_inode_to_private(ecryptfs_dentry->d_inode); | 121 | ecryptfs_inode_to_private(ecryptfs_dentry->d_inode); |
| 122 | int opened_lower_file = 0; | ||
| 121 | int rc = 0; | 123 | int rc = 0; |
| 122 | 124 | ||
| 123 | mutex_lock(&inode_info->lower_file_mutex); | 125 | mutex_lock(&inode_info->lower_file_mutex); |
| @@ -129,15 +131,17 @@ int ecryptfs_init_persistent_file(struct dentry *ecryptfs_dentry) | |||
| 129 | lower_dentry = ecryptfs_dentry_to_lower(ecryptfs_dentry); | 131 | lower_dentry = ecryptfs_dentry_to_lower(ecryptfs_dentry); |
| 130 | rc = ecryptfs_privileged_open(&inode_info->lower_file, | 132 | rc = ecryptfs_privileged_open(&inode_info->lower_file, |
| 131 | lower_dentry, lower_mnt, cred); | 133 | lower_dentry, lower_mnt, cred); |
| 132 | if (rc || IS_ERR(inode_info->lower_file)) { | 134 | if (rc) { |
| 133 | printk(KERN_ERR "Error opening lower persistent file " | 135 | printk(KERN_ERR "Error opening lower persistent file " |
| 134 | "for lower_dentry [0x%p] and lower_mnt [0x%p]; " | 136 | "for lower_dentry [0x%p] and lower_mnt [0x%p]; " |
| 135 | "rc = [%d]\n", lower_dentry, lower_mnt, rc); | 137 | "rc = [%d]\n", lower_dentry, lower_mnt, rc); |
| 136 | rc = PTR_ERR(inode_info->lower_file); | ||
| 137 | inode_info->lower_file = NULL; | 138 | inode_info->lower_file = NULL; |
| 138 | } | 139 | } else |
| 140 | opened_lower_file = 1; | ||
| 139 | } | 141 | } |
| 140 | mutex_unlock(&inode_info->lower_file_mutex); | 142 | mutex_unlock(&inode_info->lower_file_mutex); |
| 143 | if (opened_lower_file) | ||
| 144 | ima_counts_get(inode_info->lower_file); | ||
| 141 | return rc; | 145 | return rc; |
| 142 | } | 146 | } |
| 143 | 147 | ||
