diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2008-09-18 07:54:21 +0000 | 
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2008-09-18 07:54:21 +0000 | 
| commit | 5cc53c34c366fa8b6e389c7c1751c50c0f64041a (patch) | |
| tree | 00effcc2f02134686e78be25d8938c46d4ed3992 /llvm/lib/System | |
| parent | 933b392f657c6abcc6bca68bc14cf77301c6d4cc (diff) | |
| download | bcm5719-llvm-5cc53c34c366fa8b6e389c7c1751c50c0f64041a.tar.gz bcm5719-llvm-5cc53c34c366fa8b6e389c7c1751c50c0f64041a.zip  | |
Preliminary support for systems which require changing JIT memory regions privilege from read / write to read / executable.
llvm-svn: 56303
Diffstat (limited to 'llvm/lib/System')
| -rw-r--r-- | llvm/lib/System/Memory.cpp | 11 | ||||
| -rw-r--r-- | llvm/lib/System/Unix/Memory.inc | 29 | 
2 files changed, 40 insertions, 0 deletions
diff --git a/llvm/lib/System/Memory.cpp b/llvm/lib/System/Memory.cpp index 3660bcb1a4a..2fc6a23a3af 100644 --- a/llvm/lib/System/Memory.cpp +++ b/llvm/lib/System/Memory.cpp @@ -58,3 +58,14 @@ void llvm::sys::Memory::InvalidateInstructionCache(const void *Addr,  #endif  // end PPC  } + +bool llvm::sys::Memory::SetRXPrivilege(const void *Addr, size_t Size) { +#if defined(__APPLE__) && defined(__arm__) +  kern_return_t kr = vm_protect(mach_task_self(), (vm_address_t)Addr, +                                (vm_size_t)Size, 0, +                                VM_PROT_READ | VM_PROT_EXECUTE | VM_PROT_COPY); +  return KERN_SUCCESS == kr; +#else +  return true; +#endif +} diff --git a/llvm/lib/System/Unix/Memory.inc b/llvm/lib/System/Unix/Memory.inc index 621184e4260..cf0157d5778 100644 --- a/llvm/lib/System/Unix/Memory.inc +++ b/llvm/lib/System/Unix/Memory.inc @@ -18,6 +18,10 @@  #include <sys/mman.h>  #endif +#ifdef __APPLE__ +#include <mach/mach.h> +#endif +  /// AllocateRWX - Allocate a slab of memory with read/write/execute  /// permissions.  This is typically used for JIT applications where we want  /// to emit code to the memory then jump to it.  Getting this type of memory @@ -52,8 +56,13 @@ llvm::sys::Memory::AllocateRWX(unsigned NumBytes, const MemoryBlock* NearBlock,    void* start = NearBlock ? (unsigned char*)NearBlock->base() +                               NearBlock->size() : 0; +#if defined(__APPLE__) && defined(__arm__) +  void *pa = ::mmap(start, pageSize*NumPages, PROT_READ|PROT_EXEC, +                    flags, fd, 0); +#else    void *pa = ::mmap(start, pageSize*NumPages, PROT_READ|PROT_WRITE|PROT_EXEC,                      flags, fd, 0); +#endif    if (pa == MAP_FAILED) {      if (NearBlock) //Try again without a near hint        return AllocateRWX(NumBytes, 0); @@ -61,9 +70,29 @@ llvm::sys::Memory::AllocateRWX(unsigned NumBytes, const MemoryBlock* NearBlock,      MakeErrMsg(ErrMsg, "Can't allocate RWX Memory");      return MemoryBlock();    } + +#if defined(__APPLE__) && defined(__arm__) +  kern_return_t kr = vm_protect(mach_task_self(), (vm_address_t)pa, +                                (vm_size_t)(pageSize*NumPages), 0, +                                VM_PROT_READ | VM_PROT_EXECUTE | VM_PROT_COPY); +  if (KERN_SUCCESS != kr) { +    MakeErrMsg(ErrMsg, "vm_protect max RWX failed\n"); +    return sys::MemoryBlock(); +  } + +  kr = vm_protect(mach_task_self(), (vm_address_t)pa, +                  (vm_size_t)(pageSize*NumPages), 0, +                  VM_PROT_READ | VM_PROT_WRITE); +  if (KERN_SUCCESS != kr) { +    MakeErrMsg(ErrMsg, "vm_protect RW failed\n"); +    return sys::MemoryBlock(); +  } +#endif +    MemoryBlock result;    result.Address = pa;    result.Size = NumPages*pageSize; +    return result;  }  | 

