diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2004-09-13 22:38:11 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2004-09-13 22:38:11 +0000 |
commit | f7948483d2dccb64f0d7afa820273946429e3304 (patch) | |
tree | eccee279ddbcf7b5c58936b53cecc2ebc3d18f39 /llvm/lib/System/FreeBSD/Memory.cpp | |
parent | 07369430c4be24444d55a48ca31d01538a680263 (diff) | |
download | bcm5719-llvm-f7948483d2dccb64f0d7afa820273946429e3304.tar.gz bcm5719-llvm-f7948483d2dccb64f0d7afa820273946429e3304.zip |
Simplify the sys::Memory interface per Chris' request.
llvm-svn: 16318
Diffstat (limited to 'llvm/lib/System/FreeBSD/Memory.cpp')
-rw-r--r-- | llvm/lib/System/FreeBSD/Memory.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/llvm/lib/System/FreeBSD/Memory.cpp b/llvm/lib/System/FreeBSD/Memory.cpp index eeb22e910bf..4ab1a5dcc15 100644 --- a/llvm/lib/System/FreeBSD/Memory.cpp +++ b/llvm/lib/System/FreeBSD/Memory.cpp @@ -25,8 +25,8 @@ using namespace sys; //=== and must not be generic UNIX code (see ../Unix/Memory.cpp) //===----------------------------------------------------------------------===// -void* Memory::AllocateRWX(Memory& M, unsigned NumBytes) { - if (NumBytes == 0) return 0; +MemoryBlock Memory::AllocateRWX(unsigned NumBytes) { + if (NumBytes == 0) return MemoryBlock(); static const long pageSize = Process::GetPageSize(); unsigned NumPages = (NumBytes+pageSize-1)/pageSize; @@ -36,14 +36,16 @@ void* Memory::AllocateRWX(Memory& M, unsigned NumBytes) { if (pa == (void*)-1) { throw std::string("Can't allocate RWX Memory: ") + strerror(errno); } - M.Address = pa; - M.AllocSize = NumPages*pageSize; - return pa; + + MemoryBlock result; + result.Address = pa; + result.Size = NumPages*pageSize; + return result; } void Memory::ReleaseRWX(Memory& M) { - if (M.Address == 0 || M.AllocSize == 0) return; - if (0 != munmap(M.Address, M.AllocSize)) { + if (M.Address == 0 || M.Size == 0) return; + if (0 != munmap(M.Address, M.Size)) { throw std::string("Can't release RWX Memory: ") + strerror(errno); } } |