Commit b5fb8617 authored by Alexandre Ghiti's avatar Alexandre Ghiti Committed by Linus Torvalds
Browse files

mips: use STACK_TOP when computing mmap base address

mmap base address must be computed wrt stack top address, using TASK_SIZE
is wrong since STACK_TOP and TASK_SIZE are not equivalent.


Signed-off-by: default avatarAlexandre Ghiti <>
Acked-by: default avatarKees Cook <>
Acked-by: default avatarPaul Burton <>
Reviewed-by: default avatarLuis Chamberlain <>
Cc: Albert Ou <>
Cc: Alexander Viro <>
Cc: Catalin Marinas <>
Cc: Christoph Hellwig <>
Cc: Christoph Hellwig <>
Cc: James Hogan <>
Cc: Palmer Dabbelt <>
Cc: Ralf Baechle <>
Cc: Russell King <>
Cc: Will Deacon <>
Signed-off-by: default avatarAndrew Morton <>
Signed-off-by: default avatarLinus Torvalds <>
parent b1f61b5b
......@@ -22,7 +22,7 @@ EXPORT_SYMBOL(shm_align_mask);
/* gap between mmap and stack */
#define MIN_GAP (128*1024*1024UL)
#define MAX_GAP ((TASK_SIZE)/6*5)
#define MAX_GAP ((STACK_TOP)/6*5)
#define STACK_RND_MASK (0x7ff >> (PAGE_SHIFT - 12))
static int mmap_is_legacy(struct rlimit *rlim_stack)
......@@ -54,7 +54,7 @@ static unsigned long mmap_base(unsigned long rnd, struct rlimit *rlim_stack)
else if (gap > MAX_GAP)
gap = MAX_GAP;
return PAGE_ALIGN(TASK_SIZE - gap - rnd);
return PAGE_ALIGN(STACK_TOP - gap - rnd);
#define COLOUR_ALIGN(addr, pgoff) \
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment