]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
sparc: Fix mmap VA span checking.
authorDavid S. Miller <davem@davemloft.net>
Wed, 7 May 2008 09:24:28 +0000 (02:24 -0700)
committerGreg Kroah-Hartman <gregkh@suse.de>
Sat, 10 May 2008 04:40:53 +0000 (21:40 -0700)
[ Upstream commit: 5816339310b2d9623cf413d33e538b45e815da5d ]

We should not conditionalize VA range checks on MAP_FIXED.

Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
arch/sparc/kernel/sys_sparc.c
arch/sparc64/kernel/sys_sparc.c

index 42bf09db9a81ffaa11972289daffcb884fa22225..9f8c8e101e9d62cbf5707d09f1214e6e669a2b9f 100644 (file)
@@ -224,8 +224,7 @@ int sparc_mmap_check(unsigned long addr, unsigned long len, unsigned long flags)
 {
        if (ARCH_SUN4C_SUN4 &&
            (len > 0x20000000 ||
-            ((flags & MAP_FIXED) &&
-             addr < 0xe0000000 && addr + len > 0x20000000)))
+            (addr < 0xe0000000 && addr + len > 0x20000000)))
                return -EINVAL;
 
        /* See asm-sparc/uaccess.h */
index f952745d0f3d964605e6008f6f567de72a49855e..cc3793644a6aaf53721150a8ce88e01b6b754270 100644 (file)
@@ -549,13 +549,13 @@ int sparc64_mmap_check(unsigned long addr, unsigned long len,
                if (len >= STACK_TOP32)
                        return -EINVAL;
 
-               if ((flags & MAP_FIXED) && addr > STACK_TOP32 - len)
+               if (addr > STACK_TOP32 - len)
                        return -EINVAL;
        } else {
                if (len >= VA_EXCLUDE_START)
                        return -EINVAL;
 
-               if ((flags & MAP_FIXED) && invalid_64bit_range(addr, len))
+               if (invalid_64bit_range(addr, len))
                        return -EINVAL;
        }