Skip PrecomputedTransactionData hashing for cache hits. #13233
pull TheBlueMatt wants to merge 2 commits into bitcoin:master from TheBlueMatt:2018-05-no-needless-precompute changing 4 files +83 −91-
TheBlueMatt commented at 5:48 pm on May 14, 2018: memberWe currently calculate PrecomputedTransactionData for all transactitons that appear in blocks, but this is entirely uneccessary on the vast majority of transactions near the tip due to the script cache. Thus, we move the calculation into CheckInputs after the script cache check. I played around with a number of refactors to CheckInputs to do this a bit cleaner but it seems rather difficult to do so, so I just stuck with the obvious version
-
Remove unused fScriptChecks parameter from CheckInputs
fScriptChecks = false just short-circuits the entire function, so passing it in is entirely useless.
-
Skip PrecomputedTransactionData hashing for cache hits. feda9b37de
-
in src/validation.cpp:1348 in 26a965c33e outdated
1342@@ -1343,83 +1343,72 @@ void InitScriptExecutionCache() { 1343 * 1344 * Non-static (and re-declared) in src/test/txvalidationcache_tests.cpp 1345 */ 1346-bool CheckInputs(const CTransaction& tx, CValidationState &state, const CCoinsViewCache &inputs, bool fScriptChecks, unsigned int flags, bool cacheSigStore, bool cacheFullScriptStore, PrecomputedTransactionData& txdata, std::vector<CScriptCheck> *pvChecks) 1347+bool CheckInputs(const CTransaction& tx, CValidationState &state, const CCoinsViewCache &inputs, unsigned int flags, bool cacheSigStore, bool cacheFullScriptStore, PrecomputedTransactionData& txdata, std::vector<CScriptCheck> *pvChecks) 1348 { 1349 if (!tx.IsCoinBase())
MarcoFalke commented at 5:56 pm on May 14, 2018:nit: since you re-indent the whole function body you might also remove this scope and put aif (tx.IsCoinBase()) return true;
in the first line.
promag commented at 7:57 pm on May 14, 2018:Yeah, I also prefer early return in these cases.promag commented at 7:57 pm on May 14, 2018: memberNice, concept ACK.in src/script/interpreter.cpp:1201 in feda9b37de
1194@@ -1195,10 +1195,10 @@ uint256 GetOutputsHash(const CTransaction& txTo) { 1195 1196 } // namespace 1197 1198-PrecomputedTransactionData::PrecomputedTransactionData(const CTransaction& txTo) 1199+void PrecomputedTransactionData::ComputeHashes(const CTransaction& txTo) 1200 { 1201 // Cache is calculated only for transactions with witness 1202- if (txTo.HasWitness()) { 1203+ if (!ready && txTo.HasWitness()) {
promag commented at 10:23 pm on May 14, 2018:It should not be possible to callComputeHashes
with different transactions right? I have verified that currently it’s the case, but maybe we should prevent invalid usage?gmaxwell commented at 6:54 pm on May 15, 2018: contributorNo benchmarks?MarcoFalke added the label Needs rebase on Jun 6, 2018TheBlueMatt closed this on Jun 14, 2018
fanquake referenced this in commit 6519be6054 on Sep 2, 2019sidhujag referenced this in commit aa78f3d3fe on Sep 3, 2019laanwj removed the label Needs rebase on Oct 24, 2019MarcoFalke locked this on Dec 16, 2021
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 15:12 UTC
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 15:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me
More mirrored repositories can be found on mirror.b10c.me