]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commitdiff
mm: enforce min addr even if capable() in expand_downwards()
authorJann Horn <jannh@google.com>
Thu, 7 Mar 2019 02:36:00 +0000 (03:36 +0100)
committerKleber Sacilotto de Souza <kleber.souza@canonical.com>
Tue, 12 Mar 2019 12:21:12 +0000 (13:21 +0100)
security_mmap_addr() does a capability check with current_cred(), but
we can reach this code from contexts like a VFS write handler where
current_cred() must not be used.

This can be abused on systems without SMAP to make NULL pointer
dereferences exploitable again.

Fixes: 8869477a49c3 ("security: protect from stack expansion into low vm addresses")
Cc: stable@kernel.org
Signed-off-by: Jann Horn <jannh@google.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
CVE-2019-9213

(cherry picked from commit 0a1d52994d440e21def1c2174932410b4f2a98a1)
Signed-off-by: Tyler Hicks <tyhicks@canonical.com>
Acked-By: You-Sheng Yang <vicamo.yang@canonical.com>
Acked-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
Signed-off-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
mm/mmap.c

index 3618e09e1d9b6ffcc1c3bbc50d9c7b4444460261..619d4ef9a8b7dc8276ed49a07d5fe6301d665eaf 100644 (file)
--- a/mm/mmap.c
+++ b/mm/mmap.c
@@ -2372,12 +2372,11 @@ int expand_downwards(struct vm_area_struct *vma,
 {
        struct mm_struct *mm = vma->vm_mm;
        struct vm_area_struct *prev;
-       int error;
+       int error = 0;
 
        address &= PAGE_MASK;
-       error = security_mmap_addr(address);
-       if (error)
-               return error;
+       if (address < mmap_min_addr)
+               return -EPERM;
 
        /* Enforce stack_guard_gap */
        prev = vma->vm_prev;