summaryrefslogtreecommitdiff
path: root/deps/v8/src
diff options
context:
space:
mode:
authorBryan Cantrill <bryan@joyent.com>2012-09-18 15:35:29 -0700
committerFedor Indutny <fedor.indutny@gmail.com>2013-02-06 13:30:59 +0400
commit202b5db4efd0beec788beb40ece205ce9aa79037 (patch)
treec50477af17284a4182f867abd12cb19827bcf3ee /deps/v8/src
parenta9c4a20331d123dc38dcc878af335d88e1933562 (diff)
downloadnode-new-202b5db4efd0beec788beb40ece205ce9aa79037.tar.gz
v8: loosen artificial mmap constraint
Fixes #4010.
Diffstat (limited to 'deps/v8/src')
-rw-r--r--deps/v8/src/platform-posix.cc17
1 files changed, 13 insertions, 4 deletions
diff --git a/deps/v8/src/platform-posix.cc b/deps/v8/src/platform-posix.cc
index 0016d59d3a..e652a083cd 100644
--- a/deps/v8/src/platform-posix.cc
+++ b/deps/v8/src/platform-posix.cc
@@ -109,11 +109,20 @@ void* OS::GetRandomMmapAddr() {
raw_addr &= V8_UINT64_C(0x3ffffffff000);
#else
uint32_t raw_addr = V8::RandomPrivate(isolate);
- // The range 0x20000000 - 0x60000000 is relatively unpopulated across a
- // variety of ASLR modes (PAE kernel, NX compat mode, etc) and on macos
- // 10.6 and 10.7.
+
+ // For our 32-bit mmap() hint, we pick a random address in the bottom
+ // half of the top half of the address space (that is, the third quarter).
+ // Because we do not MAP_FIXED, this will be treated only as a hint -- the
+ // system will not fail to mmap() because something else happens to already
+ // be mapped at our random address. We deliberately set the hint high enough
+ // to get well above the system's break (that is, the heap); systems will
+ // either try the hint and if that fails move higher (MacOS and other BSD
+ // derivatives) or try the hint and if that fails allocate as if there were
+ // no hint at all (Linux, Solaris, illumos and derivatives). The high hint
+ // prevents the break from getting hemmed in at low values, ceding half of
+ // the address space to the system heap.
raw_addr &= 0x3ffff000;
- raw_addr += 0x20000000;
+ raw_addr += 0x80000000;
#endif
return reinterpret_cast<void*>(raw_addr);
}