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:
parent
f9a8aac036
commit
010cfb7d67
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user