mirror of
https://github.com/monero-project/monero.git
synced 2026-01-12 21:13:55 -08:00
tx_pool: full tx revalidation on fork boundaries
avoids mining txes after a fork that are invalid by this fork's rules, but were valid by the previous fork rules at the time they were verified and added to the txpool.
This commit is contained in:
@@ -588,6 +588,7 @@ block Blockchain::pop_block_from_blockchain()
|
||||
|
||||
CHECK_AND_ASSERT_THROW_MES(m_db->height() > 1, "Cannot pop the genesis block");
|
||||
|
||||
const uint8_t previous_hf_version = get_current_hard_fork_version();
|
||||
try
|
||||
{
|
||||
m_db->pop_block(popped_block, popped_txs);
|
||||
@@ -650,6 +651,13 @@ block Blockchain::pop_block_from_blockchain()
|
||||
m_tx_pool.on_blockchain_dec(top_block_height, top_block_hash);
|
||||
invalidate_block_template_cache();
|
||||
|
||||
const uint8_t new_hf_version = get_current_hard_fork_version();
|
||||
if (new_hf_version != previous_hf_version)
|
||||
{
|
||||
MINFO("Validating txpool for v" << (unsigned)new_hf_version);
|
||||
m_tx_pool.validate(new_hf_version);
|
||||
}
|
||||
|
||||
return popped_block;
|
||||
}
|
||||
//------------------------------------------------------------------
|
||||
@@ -4392,6 +4400,19 @@ leave:
|
||||
get_difficulty_for_next_block(); // just to cache it
|
||||
invalidate_block_template_cache();
|
||||
|
||||
const uint8_t new_hf_version = get_current_hard_fork_version();
|
||||
if (new_hf_version != hf_version)
|
||||
{
|
||||
// the genesis block is added before everything's setup, and the txpool is empty
|
||||
// when we start from scratch, so we skip this
|
||||
const bool is_genesis_block = new_height == 1;
|
||||
if (!is_genesis_block)
|
||||
{
|
||||
MGINFO("Validating txpool for v" << (unsigned)new_hf_version);
|
||||
m_tx_pool.validate(new_hf_version);
|
||||
}
|
||||
}
|
||||
|
||||
send_miner_notifications(id, already_generated_coins);
|
||||
|
||||
for (const auto& notifier: m_block_notifiers)
|
||||
|
||||
Reference in New Issue
Block a user