2013-10-09 08:45:59 +02:00
|
|
|
// Copyright (c) 2009-2013 The Bitcoin developers
|
2014-12-13 05:09:33 +01:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
2013-10-09 08:45:59 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#include "allocators.h"
|
|
|
|
|
|
|
|
#ifdef WIN32
|
|
|
|
#ifdef _WIN32_WINNT
|
|
|
|
#undef _WIN32_WINNT
|
|
|
|
#endif
|
|
|
|
#define _WIN32_WINNT 0x0501
|
|
|
|
#define WIN32_LEAN_AND_MEAN 1
|
|
|
|
#ifndef NOMINMAX
|
|
|
|
#define NOMINMAX
|
|
|
|
#endif
|
|
|
|
#include <windows.h>
|
|
|
|
// This is used to attempt to keep keying material out of swap
|
|
|
|
// Note that VirtualLock does not provide this as a guarantee on Windows,
|
|
|
|
// but, in practice, memory that has been VirtualLock'd almost never gets written to
|
|
|
|
// the pagefile except in rare circumstances where memory is extremely low.
|
|
|
|
#else
|
|
|
|
#include <sys/mman.h>
|
|
|
|
#include <limits.h> // for PAGESIZE
|
|
|
|
#include <unistd.h> // for sysconf
|
|
|
|
#endif
|
|
|
|
|
2013-10-01 12:23:17 +02:00
|
|
|
LockedPageManager* LockedPageManager::_instance = NULL;
|
|
|
|
boost::once_flag LockedPageManager::init_flag = BOOST_ONCE_INIT;
|
|
|
|
|
2013-10-09 08:45:59 +02:00
|
|
|
/** Determine system page size in bytes */
|
|
|
|
static inline size_t GetSystemPageSize()
|
|
|
|
{
|
|
|
|
size_t page_size;
|
|
|
|
#if defined(WIN32)
|
|
|
|
SYSTEM_INFO sSysInfo;
|
|
|
|
GetSystemInfo(&sSysInfo);
|
|
|
|
page_size = sSysInfo.dwPageSize;
|
|
|
|
#elif defined(PAGESIZE) // defined in limits.h
|
|
|
|
page_size = PAGESIZE;
|
2014-09-19 19:21:46 +02:00
|
|
|
#else // assume some POSIX OS
|
2013-10-09 08:45:59 +02:00
|
|
|
page_size = sysconf(_SC_PAGESIZE);
|
|
|
|
#endif
|
|
|
|
return page_size;
|
|
|
|
}
|
|
|
|
|
2014-09-19 19:21:46 +02:00
|
|
|
bool MemoryPageLocker::Lock(const void* addr, size_t len)
|
2013-10-09 08:45:59 +02:00
|
|
|
{
|
|
|
|
#ifdef WIN32
|
2014-09-06 21:59:59 +02:00
|
|
|
return VirtualLock(const_cast<void*>(addr), len) != 0;
|
2013-10-09 08:45:59 +02:00
|
|
|
#else
|
|
|
|
return mlock(addr, len) == 0;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2014-09-19 19:21:46 +02:00
|
|
|
bool MemoryPageLocker::Unlock(const void* addr, size_t len)
|
2013-10-09 08:45:59 +02:00
|
|
|
{
|
|
|
|
#ifdef WIN32
|
2014-09-06 21:59:59 +02:00
|
|
|
return VirtualUnlock(const_cast<void*>(addr), len) != 0;
|
2013-10-09 08:45:59 +02:00
|
|
|
#else
|
|
|
|
return munlock(addr, len) == 0;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
LockedPageManager::LockedPageManager() : LockedPageManagerBase<MemoryPageLocker>(GetSystemPageSize())
|
|
|
|
{
|
|
|
|
}
|