diff options
author | Ben Noordhuis <info@bnoordhuis.nl> | 2013-04-08 20:34:11 +0200 |
---|---|---|
committer | isaacs <i@izs.me> | 2013-04-19 10:51:01 -0700 |
commit | 2efb6cf0cfb4ef6ea87a7c16dfe1b8540fd19ea2 (patch) | |
tree | 148e95de28d5f7a31dbd95232c77ad83156c8b9b | |
parent | 50624a50ee484b8a53cd4f1155e4e53f19c803be (diff) | |
download | node-2efb6cf0cfb4ef6ea87a7c16dfe1b8540fd19ea2.tar.gz |
v8: reapply floating patches
-rw-r--r-- | deps/v8/build/common.gypi | 9 | ||||
-rw-r--r-- | deps/v8/src/platform-posix.cc | 17 |
2 files changed, 16 insertions, 10 deletions
diff --git a/deps/v8/build/common.gypi b/deps/v8/build/common.gypi index 0b1f39726..8028b3eec 100644 --- a/deps/v8/build/common.gypi +++ b/deps/v8/build/common.gypi @@ -454,15 +454,6 @@ }], ['OS=="linux" or OS=="freebsd" or OS=="openbsd" or OS=="netbsd" \ or OS=="android"', { - 'cflags!': [ - '-O2', - '-Os', - ], - 'cflags': [ - '-fdata-sections', - '-ffunction-sections', - '-O3', - ], 'conditions': [ [ 'gcc_version==44 and clang==0', { 'cflags': [ diff --git a/deps/v8/src/platform-posix.cc b/deps/v8/src/platform-posix.cc index 48898ed9a..2cf898dd6 100644 --- a/deps/v8/src/platform-posix.cc +++ b/deps/v8/src/platform-posix.cc @@ -115,11 +115,26 @@ void* OS::GetRandomMmapAddr() { raw_addr &= V8_UINT64_C(0x3ffffffff000); #else uint32_t raw_addr = V8::RandomPrivate(isolate); + + raw_addr &= 0x3ffff000; + +# ifdef __sun + // For our Solaris/illumos 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); Solaris and + // illumos will try the hint and if that fails allocate as if there were + // no hint at all. 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 += 0x80000000; +# else // 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. - raw_addr &= 0x3ffff000; raw_addr += 0x20000000; +# endif #endif return reinterpret_cast<void*>(raw_addr); } |