![]() |
BSHA3
0.17.99
P2P Blockchain, based on Bitcoin
|
LockedPageAllocator specialized for OSes that don't try to be special snowflakes. More...
Public Member Functions | |
PosixLockedPageAllocator () | |
void * | AllocateLocked (size_t len, bool *lockingSuccess) override |
Allocate and lock memory pages. More... | |
void | FreeLocked (void *addr, size_t len) override |
Unlock and free memory pages. More... | |
size_t | GetLimit () override |
Get the total limit on the amount of memory that may be locked by this process, in bytes. More... | |
![]() | |
virtual | ~LockedPageAllocator () |
Private Attributes | |
size_t | page_size |
LockedPageAllocator specialized for OSes that don't try to be special snowflakes.
Definition at line 219 of file lockedpool.cpp.
PosixLockedPageAllocator::PosixLockedPageAllocator | ( | ) |
Definition at line 230 of file lockedpool.cpp.
|
overridevirtual |
Allocate and lock memory pages.
If len is not a multiple of the system page size, it is rounded up. Returns 0 in case of allocation failure.
If locking the memory pages could not be accomplished it will still return the memory, however the lockingSuccess flag will be false. lockingSuccess is undefined if the allocation fails.
Implements LockedPageAllocator.
Definition at line 246 of file lockedpool.cpp.
|
overridevirtual |
Unlock and free memory pages.
Clear the memory before unlocking.
Implements LockedPageAllocator.
Definition at line 256 of file lockedpool.cpp.
|
overridevirtual |
Get the total limit on the amount of memory that may be locked by this process, in bytes.
Return size_t max if there is no limit or the limit is unknown. Return 0 if no memory can be locked at all.
Implements LockedPageAllocator.
Definition at line 263 of file lockedpool.cpp.
|
private |
Definition at line 227 of file lockedpool.cpp.