Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(157)

Side by Side Diff: runtime/vm/virtual_memory_linux.cc

Issue 10830045: - Add the ability to protect VirtualMemory. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « runtime/vm/virtual_memory.h ('k') | runtime/vm/virtual_memory_macos.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "vm/virtual_memory.h" 5 #include "vm/virtual_memory.h"
6 6
7 #include <sys/mman.h> 7 #include <sys/mman.h>
8 #include <sys/unistd.h> 8 #include <sys/unistd.h>
9 #include <unistd.h> 9 #include <unistd.h>
10 10
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
65 int prot = PROT_READ | PROT_WRITE | (executable ? PROT_EXEC : 0); 65 int prot = PROT_READ | PROT_WRITE | (executable ? PROT_EXEC : 0);
66 void* address = mmap(reinterpret_cast<void*>(addr), size, prot, 66 void* address = mmap(reinterpret_cast<void*>(addr), size, prot,
67 MAP_PRIVATE | MAP_ANON | MAP_FIXED, 67 MAP_PRIVATE | MAP_ANON | MAP_FIXED,
68 -1, 0); 68 -1, 0);
69 if (address == MAP_FAILED) { 69 if (address == MAP_FAILED) {
70 return false; 70 return false;
71 } 71 }
72 return true; 72 return true;
73 } 73 }
74 74
75
76 bool VirtualMemory::Protect(Protection mode) {
77 int prot = 0;
78 switch (mode) {
79 case kNoAccess:
80 prot = PROT_NONE;
81 break;
82 case kReadOnly:
83 prot = PROT_READ;
84 break;
85 case kReadWrite:
86 prot = PROT_READ | PROT_WRITE;
87 break;
88 case kReadExecute:
89 prot = PROT_READ | PROT_EXEC;
90 break;
91 case kReadWriteExecute:
92 prot = PROT_READ | PROT_WRITE | PROT_EXEC;
93 break;
94 }
95 return (mprotect(address(), size(), prot) == 0);
96 }
97
75 } // namespace dart 98 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/virtual_memory.h ('k') | runtime/vm/virtual_memory_macos.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698