Fixed BLOCK_FOUND detection

This commit is contained in:
SChernykh 2023-12-22 11:50:08 +01:00
parent 18e5e6ab0f
commit ae233bbf0b
5 changed files with 36 additions and 17 deletions

View file

@ -810,7 +810,6 @@ void P2PServer::broadcast(const PoolBlock& block, const PoolBlock* parent)
writeVarint(total_reward, data->pruned_blob); writeVarint(total_reward, data->pruned_blob);
writeVarint(outputs_blob_size, data->pruned_blob); writeVarint(outputs_blob_size, data->pruned_blob);
data->pruned_blob.insert(data->pruned_blob.end(), block.m_sidechainId.h, block.m_sidechainId.h + HASH_SIZE);
data->pruned_blob.insert(data->pruned_blob.end(), mainchain_data.begin() + outputs_offset + outputs_blob_size, mainchain_data.end()); data->pruned_blob.insert(data->pruned_blob.end(), mainchain_data.begin() + outputs_offset + outputs_blob_size, mainchain_data.end());

View file

@ -456,7 +456,7 @@ void p2pool::handle_chain_main(ChainMain& data, const char* extra)
} }
update_median_timestamp(); update_median_timestamp();
hash sidechain_id; hash merkle_root;
if (extra) { if (extra) {
const size_t n = strlen(extra); const size_t n = strlen(extra);
if (n >= HASH_SIZE * 2) { if (n >= HASH_SIZE * 2) {
@ -464,10 +464,10 @@ void p2pool::handle_chain_main(ChainMain& data, const char* extra)
for (size_t i = 0; i < HASH_SIZE; ++i) { for (size_t i = 0; i < HASH_SIZE; ++i) {
uint8_t d[2]; uint8_t d[2];
if (!from_hex(s[i * 2], d[0]) || !from_hex(s[i * 2 + 1], d[1])) { if (!from_hex(s[i * 2], d[0]) || !from_hex(s[i * 2 + 1], d[1])) {
sidechain_id = {}; merkle_root = {};
break; break;
} }
sidechain_id.h[i] = (d[0] << 4) | d[1]; merkle_root.h[i] = (d[0] << 4) | d[1];
} }
} }
} }
@ -477,8 +477,8 @@ void p2pool::handle_chain_main(ChainMain& data, const char* extra)
", timestamp = " << log::Gray() << data.timestamp << log::NoColor() << ", timestamp = " << log::Gray() << data.timestamp << log::NoColor() <<
", reward = " << log::Gray() << log::XMRAmount(data.reward)); ", reward = " << log::Gray() << log::XMRAmount(data.reward));
if (!sidechain_id.empty()) { if (!merkle_root.empty()) {
const PoolBlock* block = side_chain().find_block(sidechain_id); const PoolBlock* block = side_chain().find_block_by_merkle_root(merkle_root);
if (block) { if (block) {
const Wallet& w = params().m_wallet; const Wallet& w = params().m_wallet;
@ -496,7 +496,7 @@ void p2pool::handle_chain_main(ChainMain& data, const char* extra)
api_update_block_found(&data, block); api_update_block_found(&data, block);
} }
else { else {
side_chain().watch_mainchain_block(data, sidechain_id); side_chain().watch_mainchain_block(data, merkle_root);
} }
} }

View file

@ -129,8 +129,6 @@ int PoolBlock::deserialize(const uint8_t* data, size_t size, const SideChain& si
outputs_blob_size = static_cast<int>(data - data_begin) - outputs_offset; outputs_blob_size = static_cast<int>(data - data_begin) - outputs_offset;
outputs_blob.assign(data_begin + outputs_offset, data); outputs_blob.assign(data_begin + outputs_offset, data);
m_sidechainId.clear();
} }
else { else {
// Outputs are not in the buffer and must be calculated from sidechain data // Outputs are not in the buffer and must be calculated from sidechain data
@ -146,8 +144,6 @@ int PoolBlock::deserialize(const uint8_t* data, size_t size, const SideChain& si
} }
outputs_blob_size = static_cast<int>(tmp); outputs_blob_size = static_cast<int>(tmp);
READ_BUF(m_sidechainId.h, HASH_SIZE);
} }
// Technically some p2pool node could keep stuffing block with transactions until reward is less than 0.6 XMR // Technically some p2pool node could keep stuffing block with transactions until reward is less than 0.6 XMR

View file

@ -636,13 +636,13 @@ bool SideChain::add_external_block(PoolBlock& block, std::vector<hash>& missing_
} }
} }
if (block.m_sidechainId == m_watchBlockSidechainId) { if (block.m_merkleRoot == m_watchBlockMerkleRoot) {
const Wallet& w = m_pool->params().m_wallet; const Wallet& w = m_pool->params().m_wallet;
const char* who = (block.m_minerWallet == w) ? "you" : "someone else in this p2pool"; const char* who = (block.m_minerWallet == w) ? "you" : "someone else in this p2pool";
LOGINFO(0, log::LightGreen() << "BLOCK FOUND: main chain block at height " << m_watchBlock.height << " was mined by " << who << BLOCK_FOUND); LOGINFO(0, log::LightGreen() << "BLOCK FOUND: main chain block at height " << m_watchBlock.height << " was mined by " << who << BLOCK_FOUND);
m_watchBlockSidechainId = {}; m_watchBlockMerkleRoot = {};
data = m_watchBlock; data = m_watchBlock;
block_found = true; block_found = true;
@ -702,6 +702,7 @@ bool SideChain::add_block(const PoolBlock& block)
} }
m_blocksByHeight[new_block->m_sidechainHeight].push_back(new_block); m_blocksByHeight[new_block->m_sidechainHeight].push_back(new_block);
m_blocksByMerkleRoot.insert({ new_block->m_merkleRoot, new_block });
update_depths(new_block); update_depths(new_block);
@ -734,11 +735,23 @@ PoolBlock* SideChain::find_block(const hash& id) const
return nullptr; return nullptr;
} }
void SideChain::watch_mainchain_block(const ChainMain& data, const hash& possible_id) PoolBlock* SideChain::find_block_by_merkle_root(const hash& merkle_root) const
{
ReadLock lock(m_sidechainLock);
auto it = m_blocksByMerkleRoot.find(merkle_root);
if (it != m_blocksByMerkleRoot.end()) {
return it->second;
}
return nullptr;
}
void SideChain::watch_mainchain_block(const ChainMain& data, const hash& possible_merkle_root)
{ {
WriteLock lock(m_sidechainLock); WriteLock lock(m_sidechainLock);
m_watchBlock = data; m_watchBlock = data;
m_watchBlockSidechainId = possible_id; m_watchBlockMerkleRoot = possible_merkle_root;
} }
const PoolBlock* SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const const PoolBlock* SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const
@ -2104,6 +2117,15 @@ void SideChain::prune_old_blocks()
else { else {
LOGERR(1, "m_blocksByHeight and m_blocksById are inconsistent at height " << height << ". Fix the code!"); LOGERR(1, "m_blocksByHeight and m_blocksById are inconsistent at height " << height << ". Fix the code!");
} }
auto it3 = m_blocksByMerkleRoot.find(block->m_merkleRoot);
if (it3 != m_blocksByMerkleRoot.end()) {
m_blocksByMerkleRoot.erase(it2);
}
else {
LOGERR(1, "m_blocksByHeight and m_blocksByMerkleRoot are inconsistent at height " << height << ". Fix the code!");
}
return true; return true;
} }
return false; return false;

View file

@ -55,7 +55,8 @@ public:
void get_missing_blocks(unordered_set<hash>& missing_blocks) const; void get_missing_blocks(unordered_set<hash>& missing_blocks) const;
PoolBlock* find_block(const hash& id) const; PoolBlock* find_block(const hash& id) const;
void watch_mainchain_block(const ChainMain& data, const hash& possible_id); PoolBlock* find_block_by_merkle_root(const hash& merkle_root) const;
void watch_mainchain_block(const ChainMain& data, const hash& possible_merkle_root);
const PoolBlock* get_block_blob(const hash& id, std::vector<uint8_t>& blob) const; const PoolBlock* get_block_blob(const hash& id, std::vector<uint8_t>& blob) const;
bool get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const; bool get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const;
@ -117,6 +118,7 @@ private:
std::atomic<PoolBlock*> m_chainTip; std::atomic<PoolBlock*> m_chainTip;
std::map<uint64_t, std::vector<PoolBlock*>> m_blocksByHeight; std::map<uint64_t, std::vector<PoolBlock*>> m_blocksByHeight;
unordered_map<hash, PoolBlock*> m_blocksById; unordered_map<hash, PoolBlock*> m_blocksById;
unordered_map<hash, PoolBlock*> m_blocksByMerkleRoot;
uv_mutex_t m_seenWalletsLock; uv_mutex_t m_seenWalletsLock;
unordered_map<hash, uint64_t> m_seenWallets; unordered_map<hash, uint64_t> m_seenWallets;
@ -142,7 +144,7 @@ private:
difficulty_type m_curDifficulty; difficulty_type m_curDifficulty;
ChainMain m_watchBlock; ChainMain m_watchBlock;
hash m_watchBlockSidechainId; hash m_watchBlockMerkleRoot;
struct PrecalcJob struct PrecalcJob
{ {