| Index: runtime/vm/virtual_memory_linux.cc
|
| diff --git a/runtime/vm/virtual_memory_linux.cc b/runtime/vm/virtual_memory_linux.cc
|
| index 7a0d02b8078cfcf5964a0772583031727bfb269b..7c6cff8f6d05f9a16bcfb6b5cc0055d90f38426a 100644
|
| --- a/runtime/vm/virtual_memory_linux.cc
|
| +++ b/runtime/vm/virtual_memory_linux.cc
|
| @@ -13,6 +13,7 @@
|
|
|
| #include "platform/assert.h"
|
| #include "platform/utils.h"
|
| +// #include "vm/os.h"
|
|
|
| namespace dart {
|
|
|
| @@ -76,7 +77,10 @@ bool VirtualMemory::Commit(uword addr, intptr_t size, bool executable) {
|
| }
|
|
|
|
|
| -bool VirtualMemory::Protect(Protection mode) {
|
| +bool VirtualMemory::Protect(void* address, intptr_t size, Protection mode) {
|
| + uword start_address = reinterpret_cast<uword>(address);
|
| + uword end_address = start_address + size;
|
| + uword page_address = start_address & ~(PageSize() - 1);
|
| int prot = 0;
|
| switch (mode) {
|
| case kNoAccess:
|
| @@ -95,9 +99,12 @@ bool VirtualMemory::Protect(Protection mode) {
|
| prot = PROT_READ | PROT_WRITE | PROT_EXEC;
|
| break;
|
| }
|
| - return (mprotect(address(), size(), prot) == 0);
|
| + return (mprotect(reinterpret_cast<void*>(page_address),
|
| + end_address - page_address,
|
| + prot) == 0);
|
| }
|
|
|
| +
|
| } // namespace dart
|
|
|
| #endif // defined(TARGET_OS_LINUX)
|
|
|