mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2024-10-01 01:35:54 -04:00
60 lines
1.7 KiB
Diff
60 lines
1.7 KiB
Diff
|
From 2f36db71009304b3f0b95afacd8eba1f9f046b87 Mon Sep 17 00:00:00 2001
|
||
|
From: Jann Horn <jannh@google.com>
|
||
|
Date: Wed, 1 Jun 2016 11:55:06 +0200
|
||
|
Subject: 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.
|
||
|
|
||
|
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>
|
||
|
---
|
||
|
fs/ecryptfs/kthread.c | 13 +++++++++++--
|
||
|
1 file changed, 11 insertions(+), 2 deletions(-)
|
||
|
|
||
|
diff --git a/fs/ecryptfs/kthread.c b/fs/ecryptfs/kthread.c
|
||
|
index 866bb18..e818f5a 100644
|
||
|
--- a/fs/ecryptfs/kthread.c
|
||
|
+++ b/fs/ecryptfs/kthread.c
|
||
|
@@ -25,6 +25,7 @@
|
||
|
#include <linux/slab.h>
|
||
|
#include <linux/wait.h>
|
||
|
#include <linux/mount.h>
|
||
|
+#include <linux/file.h>
|
||
|
#include "ecryptfs_kernel.h"
|
||
|
|
||
|
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;
|
||
|
(*lower_file) = dentry_open(&req.path, flags, cred);
|
||
|
if (!IS_ERR(*lower_file))
|
||
|
- goto out;
|
||
|
+ goto have_file;
|
||
|
if ((flags & O_ACCMODE) == O_RDONLY) {
|
||
|
rc = PTR_ERR((*lower_file));
|
||
|
goto out;
|
||
|
@@ -165,8 +166,16 @@ int ecryptfs_privileged_open(struct file **lower_file,
|
||
|
mutex_unlock(&ecryptfs_kthread_ctl.mux);
|
||
|
wake_up(&ecryptfs_kthread_ctl.wait);
|
||
|
wait_for_completion(&req.done);
|
||
|
- if (IS_ERR(*lower_file))
|
||
|
+ if (IS_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:
|
||
|
return rc;
|
||
|
}
|
||
|
--
|
||
|
cgit v1.1
|
||
|
|