Merge pull request #6007
eb63bf8
Fix missing lock in submitblock (Matt Corallo)
This commit is contained in:
commit
d3eb5ae46a
1 changed files with 14 additions and 9 deletions
|
@ -629,14 +629,19 @@ Value submitblock(const Array& params, bool fHelp)
|
||||||
throw JSONRPCError(RPC_DESERIALIZATION_ERROR, "Block decode failed");
|
throw JSONRPCError(RPC_DESERIALIZATION_ERROR, "Block decode failed");
|
||||||
|
|
||||||
uint256 hash = block.GetHash();
|
uint256 hash = block.GetHash();
|
||||||
BlockMap::iterator mi = mapBlockIndex.find(hash);
|
bool fBlockPresent = false;
|
||||||
if (mi != mapBlockIndex.end()) {
|
{
|
||||||
CBlockIndex *pindex = mi->second;
|
LOCK(cs_main);
|
||||||
if (pindex->IsValid(BLOCK_VALID_SCRIPTS))
|
BlockMap::iterator mi = mapBlockIndex.find(hash);
|
||||||
return "duplicate";
|
if (mi != mapBlockIndex.end()) {
|
||||||
if (pindex->nStatus & BLOCK_FAILED_MASK)
|
CBlockIndex *pindex = mi->second;
|
||||||
return "duplicate-invalid";
|
if (pindex->IsValid(BLOCK_VALID_SCRIPTS))
|
||||||
// Otherwise, we might only have the header - process the block before returning
|
return "duplicate";
|
||||||
|
if (pindex->nStatus & BLOCK_FAILED_MASK)
|
||||||
|
return "duplicate-invalid";
|
||||||
|
// Otherwise, we might only have the header - process the block before returning
|
||||||
|
fBlockPresent = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CValidationState state;
|
CValidationState state;
|
||||||
|
@ -644,7 +649,7 @@ Value submitblock(const Array& params, bool fHelp)
|
||||||
RegisterValidationInterface(&sc);
|
RegisterValidationInterface(&sc);
|
||||||
bool fAccepted = ProcessNewBlock(state, NULL, &block);
|
bool fAccepted = ProcessNewBlock(state, NULL, &block);
|
||||||
UnregisterValidationInterface(&sc);
|
UnregisterValidationInterface(&sc);
|
||||||
if (mi != mapBlockIndex.end())
|
if (fBlockPresent)
|
||||||
{
|
{
|
||||||
if (fAccepted && !sc.found)
|
if (fAccepted && !sc.found)
|
||||||
return "duplicate-inconclusive";
|
return "duplicate-inconclusive";
|
||||||
|
|
Loading…
Reference in a new issue