ecryptfs: forbid opening files without mmap handler
This prevents users from triggering a stack overflow through a recursive invocation of pagefault handling that involves mapping procfs files into virtual memory. Change-Id: I84718f939090b564853f7d6a8662900f2af19ba0 Signed-off-by: Jann Horn <jannh@google.com> Acked-by: Tyler Hicks <tyhicks@canonical.com> Cc: stable@vger.kernel.org Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Git-repo: https://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git Git-commit: 2f36db71009304b3f0b95afacd8eba1f9f046b87 Signed-off-by: Dennis Cagle <d-cagle@codeaurora.org>
This commit is contained in:
parent
e97b6a0e02
commit
355ea21015
1 changed files with 11 additions and 2 deletions
|
@ -25,6 +25,7 @@
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/wait.h>
|
#include <linux/wait.h>
|
||||||
#include <linux/mount.h>
|
#include <linux/mount.h>
|
||||||
|
#include <linux/file.h>
|
||||||
#include "ecryptfs_kernel.h"
|
#include "ecryptfs_kernel.h"
|
||||||
|
|
||||||
struct ecryptfs_open_req {
|
struct ecryptfs_open_req {
|
||||||
|
@ -147,7 +148,7 @@ int ecryptfs_privileged_open(struct file **lower_file,
|
||||||
flags |= IS_RDONLY(d_inode(lower_dentry)) ? O_RDONLY : O_RDWR;
|
flags |= IS_RDONLY(d_inode(lower_dentry)) ? O_RDONLY : O_RDWR;
|
||||||
(*lower_file) = dentry_open(&req.path, flags, cred);
|
(*lower_file) = dentry_open(&req.path, flags, cred);
|
||||||
if (!IS_ERR(*lower_file))
|
if (!IS_ERR(*lower_file))
|
||||||
goto out;
|
goto have_file;
|
||||||
if ((flags & O_ACCMODE) == O_RDONLY) {
|
if ((flags & O_ACCMODE) == O_RDONLY) {
|
||||||
rc = PTR_ERR((*lower_file));
|
rc = PTR_ERR((*lower_file));
|
||||||
goto out;
|
goto out;
|
||||||
|
@ -165,8 +166,16 @@ int ecryptfs_privileged_open(struct file **lower_file,
|
||||||
mutex_unlock(&ecryptfs_kthread_ctl.mux);
|
mutex_unlock(&ecryptfs_kthread_ctl.mux);
|
||||||
wake_up(&ecryptfs_kthread_ctl.wait);
|
wake_up(&ecryptfs_kthread_ctl.wait);
|
||||||
wait_for_completion(&req.done);
|
wait_for_completion(&req.done);
|
||||||
if (IS_ERR(*lower_file))
|
if (IS_ERR(*lower_file)) {
|
||||||
rc = PTR_ERR(*lower_file);
|
rc = PTR_ERR(*lower_file);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
have_file:
|
||||||
|
if ((*lower_file)->f_op->mmap == NULL) {
|
||||||
|
fput(*lower_file);
|
||||||
|
*lower_file = NULL;
|
||||||
|
rc = -EMEDIUMTYPE;
|
||||||
|
}
|
||||||
out:
|
out:
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue