From a962cca390fed391ccf9bd0eb72617524470a970 Mon Sep 17 00:00:00 2001 From: Bert Belder Date: Tue, 2 Aug 2011 18:34:11 +0200 Subject: [PATCH] V8: Don't use mprotect on Cygwin as virtual memory is managed directly via WinAPI calls. Upstream fix: http://codereview.chromium.org/7549009 --- deps/v8/src/platform-cygwin.cc | 6 ++++++ deps/v8/src/platform-posix.cc | 2 ++ 2 files changed, 8 insertions(+) diff --git a/deps/v8/src/platform-cygwin.cc b/deps/v8/src/platform-cygwin.cc index 5f283c35715..7cb4fd9709e 100644 --- a/deps/v8/src/platform-cygwin.cc +++ b/deps/v8/src/platform-cygwin.cc @@ -166,6 +166,12 @@ void OS::Free(void* address, const size_t size) { } +void OS::Guard(void* address, const size_t size) { + DWORD oldprotect; + VirtualProtect(address, size, PAGE_READONLY | PAGE_GUARD, &oldprotect); +} + + void OS::Sleep(int milliseconds) { unsigned int ms = static_cast(milliseconds); usleep(1000 * ms); diff --git a/deps/v8/src/platform-posix.cc b/deps/v8/src/platform-posix.cc index deb4b756189..9727efeee02 100644 --- a/deps/v8/src/platform-posix.cc +++ b/deps/v8/src/platform-posix.cc @@ -70,10 +70,12 @@ intptr_t OS::MaxVirtualMemory() { } +#ifndef __CYGWIN__ // Create guard pages. void OS::Guard(void* address, const size_t size) { mprotect(address, size, PROT_NONE); } +#endif // __CYGWIN__ // ----------------------------------------------------------------------------