mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-11 20:32:35 -03:00
Merge #18160: gui: Avoid Wallet::GetBalance in WalletModel::pollBalanceChanged
0933a37078
gui: Avoid Wallet::GetBalance in WalletModel::pollBalanceChanged (João Barbosa) Pull request description: Each 250ms the slot `WalletModel::pollBalanceChanged` is called which, at worst case, calls `Wallet::GetBalance`. This is a waste of resources since most of the time there aren't new transactions or new blocks. Fix this by early checking if cache is dirty or not. The actual balance computation can still hang the GUI thread but that is tracked in #16874 and should be fixed with a solution similar to #17135. ACKs for top commit: hebasto: ACK0933a37078
, I have not tested the code, but I have reviewed it and it looks OK, I agree it can be merged. jonasschnelli: utACK0933a37078
instagibbs: ACK0933a37078
ryanofsky: Code review ACK0933a37078
, but I would prefer (not strongly) for #17905 to be merged first. This PR can be simpler if it is based on #17905, so tryGetBalances can just be left alone instead of changing into to a more complicated tryGetBalancesIfNeeded function, and then getting changed back later when we want to optimize it out. jonatack: ACK0933a37078
based primarily on code review, despite a lot of manual testing with a large 177MB wallet. Tree-SHA512: 18db35bf33a7577666658c8cb0b57308c8474baa5ea95bf1468cd8531a69857d8915584f6ac505874717aa6aabeb1b506ac77630f8acdb6651afab89275e38a1
This commit is contained in:
commit
f2880e21ef
3 changed files with 15 additions and 14 deletions
|
@ -368,16 +368,17 @@ public:
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
bool tryGetBalances(WalletBalances& balances, int& num_blocks) override
|
bool tryGetBalances(WalletBalances& balances, int& num_blocks, bool force, int cached_num_blocks) override
|
||||||
{
|
{
|
||||||
auto locked_chain = m_wallet->chain().lock(true /* try_lock */);
|
auto locked_chain = m_wallet->chain().lock(true /* try_lock */);
|
||||||
if (!locked_chain) return false;
|
if (!locked_chain) return false;
|
||||||
|
num_blocks = locked_chain->getHeight().get_value_or(-1);
|
||||||
|
if (!force && num_blocks == cached_num_blocks) return false;
|
||||||
TRY_LOCK(m_wallet->cs_wallet, locked_wallet);
|
TRY_LOCK(m_wallet->cs_wallet, locked_wallet);
|
||||||
if (!locked_wallet) {
|
if (!locked_wallet) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
balances = getBalances();
|
balances = getBalances();
|
||||||
num_blocks = locked_chain->getHeight().get_value_or(-1);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
CAmount getBalance() override { return m_wallet->GetBalance().m_mine_trusted; }
|
CAmount getBalance() override { return m_wallet->GetBalance().m_mine_trusted; }
|
||||||
|
|
|
@ -201,8 +201,11 @@ public:
|
||||||
//! Get balances.
|
//! Get balances.
|
||||||
virtual WalletBalances getBalances() = 0;
|
virtual WalletBalances getBalances() = 0;
|
||||||
|
|
||||||
//! Get balances if possible without blocking.
|
//! Get balances if possible without waiting for chain and wallet locks.
|
||||||
virtual bool tryGetBalances(WalletBalances& balances, int& num_blocks) = 0;
|
virtual bool tryGetBalances(WalletBalances& balances,
|
||||||
|
int& num_blocks,
|
||||||
|
bool force,
|
||||||
|
int cached_num_blocks) = 0;
|
||||||
|
|
||||||
//! Get balance.
|
//! Get balance.
|
||||||
virtual CAmount getBalance() = 0;
|
virtual CAmount getBalance() = 0;
|
||||||
|
|
|
@ -78,12 +78,10 @@ void WalletModel::pollBalanceChanged()
|
||||||
// rescan.
|
// rescan.
|
||||||
interfaces::WalletBalances new_balances;
|
interfaces::WalletBalances new_balances;
|
||||||
int numBlocks = -1;
|
int numBlocks = -1;
|
||||||
if (!m_wallet->tryGetBalances(new_balances, numBlocks)) {
|
if (!m_wallet->tryGetBalances(new_balances, numBlocks, fForceCheckBalanceChanged, cachedNumBlocks)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(fForceCheckBalanceChanged || numBlocks != cachedNumBlocks)
|
|
||||||
{
|
|
||||||
fForceCheckBalanceChanged = false;
|
fForceCheckBalanceChanged = false;
|
||||||
|
|
||||||
// Balance and number of transactions might have changed
|
// Balance and number of transactions might have changed
|
||||||
|
@ -92,7 +90,6 @@ void WalletModel::pollBalanceChanged()
|
||||||
checkBalanceChanged(new_balances);
|
checkBalanceChanged(new_balances);
|
||||||
if(transactionTableModel)
|
if(transactionTableModel)
|
||||||
transactionTableModel->updateConfirmations();
|
transactionTableModel->updateConfirmations();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WalletModel::checkBalanceChanged(const interfaces::WalletBalances& new_balances)
|
void WalletModel::checkBalanceChanged(const interfaces::WalletBalances& new_balances)
|
||||||
|
|
Loading…
Reference in a new issue