diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2019-04-10 14:04:34 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2019-04-10 14:04:34 -0400 |
commit | f51dcd0f621caac5380ce90fbbeafc32ce4517ae (patch) | |
tree | 294cee0590e9e27a93bc9fd6122c50b78da44b99 /security | |
parent | 46c874419652bbefdfed17420fd6e88d8a31d9ec (diff) |
apparmorfs: fix use-after-free on symlink traversal
symlink body shouldn't be freed without an RCU delay. Switch apparmorfs
to ->destroy_inode() and use of call_rcu(); free both the inode and symlink
body in the callback.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'security')
-rw-r--r-- | security/apparmor/apparmorfs.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/security/apparmor/apparmorfs.c b/security/apparmor/apparmorfs.c index fefee040bf79..b9298d2e8165 100644 --- a/security/apparmor/apparmorfs.c +++ b/security/apparmor/apparmorfs.c | |||
@@ -123,17 +123,22 @@ static int aafs_show_path(struct seq_file *seq, struct dentry *dentry) | |||
123 | return 0; | 123 | return 0; |
124 | } | 124 | } |
125 | 125 | ||
126 | static void aafs_evict_inode(struct inode *inode) | 126 | static void aafs_i_callback(struct rcu_head *head) |
127 | { | 127 | { |
128 | truncate_inode_pages_final(&inode->i_data); | 128 | struct inode *inode = container_of(head, struct inode, i_rcu); |
129 | clear_inode(inode); | ||
130 | if (S_ISLNK(inode->i_mode)) | 129 | if (S_ISLNK(inode->i_mode)) |
131 | kfree(inode->i_link); | 130 | kfree(inode->i_link); |
131 | free_inode_nonrcu(inode); | ||
132 | } | ||
133 | |||
134 | static void aafs_destroy_inode(struct inode *inode) | ||
135 | { | ||
136 | call_rcu(&inode->i_rcu, aafs_i_callback); | ||
132 | } | 137 | } |
133 | 138 | ||
134 | static const struct super_operations aafs_super_ops = { | 139 | static const struct super_operations aafs_super_ops = { |
135 | .statfs = simple_statfs, | 140 | .statfs = simple_statfs, |
136 | .evict_inode = aafs_evict_inode, | 141 | .destroy_inode = aafs_destroy_inode, |
137 | .show_path = aafs_show_path, | 142 | .show_path = aafs_show_path, |
138 | }; | 143 | }; |
139 | 144 | ||