Browse Source

Merge #9777: Handle unusual maxsigcachesize gracefully

55c403b Ensure `-maxsigcachesize` is in valid range (John Newbery)
0.14
Wladimir J. van der Laan 8 years ago
parent
commit
8dee822177
No known key found for this signature in database
GPG Key ID: 74810B012346C9A6
  1. 5
      src/script/sigcache.cpp
  2. 2
      src/script/sigcache.h

5
src/script/sigcache.cpp

@ -93,8 +93,9 @@ static CSignatureCache signatureCache;
// To be called once in AppInit2/TestingSetup to initialize the signatureCache // To be called once in AppInit2/TestingSetup to initialize the signatureCache
void InitSignatureCache() void InitSignatureCache()
{ {
size_t nMaxCacheSize = GetArg("-maxsigcachesize", DEFAULT_MAX_SIG_CACHE_SIZE) * ((size_t) 1 << 20); // nMaxCacheSize is unsigned. If -maxsigcachesize is set to zero,
if (nMaxCacheSize <= 0) return; // setup_bytes creates the minimum possible cache (2 elements).
size_t nMaxCacheSize = std::min(std::max((int64_t)0, GetArg("-maxsigcachesize", DEFAULT_MAX_SIG_CACHE_SIZE)), MAX_MAX_SIG_CACHE_SIZE) * ((size_t) 1 << 20);
size_t nElems = signatureCache.setup_bytes(nMaxCacheSize); size_t nElems = signatureCache.setup_bytes(nMaxCacheSize);
LogPrintf("Using %zu MiB out of %zu requested for signature cache, able to store %zu elements\n", LogPrintf("Using %zu MiB out of %zu requested for signature cache, able to store %zu elements\n",
(nElems*sizeof(uint256)) >>20, nMaxCacheSize>>20, nElems); (nElems*sizeof(uint256)) >>20, nMaxCacheSize>>20, nElems);

2
src/script/sigcache.h

@ -14,6 +14,8 @@
// systems). Due to how we count cache size, actual memory usage is slightly // systems). Due to how we count cache size, actual memory usage is slightly
// more (~32.25 MB) // more (~32.25 MB)
static const unsigned int DEFAULT_MAX_SIG_CACHE_SIZE = 32; static const unsigned int DEFAULT_MAX_SIG_CACHE_SIZE = 32;
// Maximum sig cache size allowed
static const int64_t MAX_MAX_SIG_CACHE_SIZE = 16384;
class CPubKey; class CPubKey;

Loading…
Cancel
Save