Make sure parent block is not in importing queue when importing ancient blocks (#10138)

* Make sure parent block is not in importing queue when importing ancient blocks

* Clear queue when an ancient import fails

* Lock only once in clear

* Add comments why queued check is needed

* Should push the value back to the queue

* Directly check in chain.read()

* Remove extra empty line

* Revert unused verification change
This commit is contained in:
Wei Tang 2019-01-09 14:47:14 +01:00 committed by Andronik Ordian
parent f9a8aac036
commit 010cfb7d67

View File

@ -2165,13 +2165,10 @@ impl IoClient for Client {
// NOTE To prevent race condition with import, make sure to check queued blocks first // NOTE To prevent race condition with import, make sure to check queued blocks first
// (and attempt to acquire lock) // (and attempt to acquire lock)
let is_parent_pending = self.queued_ancient_blocks.read().0.contains(&parent_hash); let is_parent_pending = self.queued_ancient_blocks.read().0.contains(&parent_hash);
if !is_parent_pending { if !is_parent_pending && !self.chain.read().is_known(&parent_hash) {
let status = self.block_status(BlockId::Hash(parent_hash));
if status == BlockStatus::Unknown {
bail!(EthcoreErrorKind::Block(BlockError::UnknownParent(parent_hash))); bail!(EthcoreErrorKind::Block(BlockError::UnknownParent(parent_hash)));
} }
} }
}
// we queue blocks here and trigger an IO message. // we queue blocks here and trigger an IO message.
{ {
@ -2199,6 +2196,10 @@ impl IoClient for Client {
); );
if let Err(e) = result { if let Err(e) = result {
error!(target: "client", "Error importing ancient block: {}", e); error!(target: "client", "Error importing ancient block: {}", e);
let mut queued = queued.write();
queued.0.clear();
queued.1.clear();
} }
// remove from pending // remove from pending
queued.write().0.remove(&hash); queued.write().0.remove(&hash);