mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-01-18 22:35:39 +01:00
Merge pull request #2657 from gmaxwell/its_after_may15_forever
It's after 2013-05-15 forever now, so remove the code for the May 15 fork
This commit is contained in:
23
src/main.cpp
23
src/main.cpp
@@ -2073,25 +2073,6 @@ bool CBlock::CheckBlock(CValidationState &state, bool fCheckPOW, bool fCheckMerk
|
||||
if (vtx.empty() || vtx.size() > MAX_BLOCK_SIZE || ::GetSerializeSize(*this, SER_NETWORK, PROTOCOL_VERSION) > MAX_BLOCK_SIZE)
|
||||
return state.DoS(100, error("CheckBlock() : size limits failed"));
|
||||
|
||||
// Special short-term limits to avoid 10,000 BDB lock limit:
|
||||
if (GetBlockTime() >= 1363867200 && // start enforcing 21 March 2013, noon GMT
|
||||
GetBlockTime() < 1368576000) // stop enforcing 15 May 2013 00:00:00
|
||||
{
|
||||
// Rule is: #unique txids referenced <= 4,500
|
||||
// ... to prevent 10,000 BDB lock exhaustion on old clients
|
||||
set<uint256> setTxIn;
|
||||
for (size_t i = 0; i < vtx.size(); i++)
|
||||
{
|
||||
setTxIn.insert(vtx[i].GetHash());
|
||||
if (i == 0) continue; // skip coinbase txin
|
||||
BOOST_FOREACH(const CTxIn& txin, vtx[i].vin)
|
||||
setTxIn.insert(txin.prevout.hash);
|
||||
}
|
||||
size_t nTxids = setTxIn.size();
|
||||
if (nTxids > 4500)
|
||||
return error("CheckBlock() : 15 May maxlocks violation");
|
||||
}
|
||||
|
||||
// Check proof of work matches claimed amount
|
||||
if (fCheckPOW && !CheckProofOfWork(GetHash(), nBits))
|
||||
return state.DoS(50, error("CheckBlock() : proof of work failed"));
|
||||
@@ -4188,10 +4169,6 @@ CBlockTemplate* CreateNewBlock(CReserveKey& reservekey)
|
||||
// Limit to betweeen 1K and MAX_BLOCK_SIZE-1K for sanity:
|
||||
nBlockMaxSize = std::max((unsigned int)1000, std::min((unsigned int)(MAX_BLOCK_SIZE-1000), nBlockMaxSize));
|
||||
|
||||
// Special compatibility rule before 15 May: limit size to 500,000 bytes:
|
||||
if (GetAdjustedTime() < 1368576000)
|
||||
nBlockMaxSize = std::min(nBlockMaxSize, (unsigned int)(MAX_BLOCK_SIZE_GEN));
|
||||
|
||||
// How much of the block should be dedicated to high-priority transactions,
|
||||
// included regardless of the fees they pay
|
||||
unsigned int nBlockPrioritySize = GetArg("-blockprioritysize", 27000);
|
||||
|
||||
Reference in New Issue
Block a user