wip: Only support shared validation interfaces #18791
pull promag wants to merge 1 commits into bitcoin:master from promag:2020-04-only-shared-validation-interface changing 15 files +64 −84-
promag commented at 11:41 pm on April 27, 2020: member
-
wip: Only support shared validation interfaces df4c642714
-
fanquake added the label Validation on Apr 28, 2020
-
ryanofsky commented at 0:34 am on April 28, 2020: member
I’m not sure this change is a good idea. I think it made sense to add shared_ptr support to the validation interface in #18338 because it only required 4 new lines of code in validationinterface.cpp, and because without that support it would have been more complicated to unload wallets safely, given the wallet was already using shared_ptr to share CWallet references between
vpwallet
vector, active RPC calls, and the GUI.But I don’t think the non-shared validation interface should be removed just because a shared_ptr interface is available. Or if this change is a good idea, we should figure out exactly what the goal is. I don’t think when we first switched to shared_ptr in the wallet we intended it to spread virally to unrelated classes like
BaseIndex
andPeerLogicValidation
-
promag commented at 0:45 am on April 28, 2020: member
@ryanofsky I’m on the same page. I’ve submitted this for 2 reasons:
- address same issue as #18742
- show the extent of the change
I’ll leave this open so others can weight in too.
-
ryanofsky commented at 0:51 am on April 28, 2020: memberMakes sense. This is good as an experiment to uncover other possible use-after-free bugs, and see what impact of removing the non-shared functions would be
-
DrahtBot commented at 4:20 am on April 28, 2020: member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
Reviewers, this pull request conflicts with the following ones:
- #18742 (miner: Avoid stack-use-after-return in validationinterface by MarcoFalke)
- #18531 (rpc: Assert that RPCArg names are equal to CRPCCommand ones by MarcoFalke)
- #13686 (ZMQ: Small cleanups in the ZMQ code by domob1812)
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.
-
MarcoFalke commented at 11:41 am on April 28, 2020: memberThe normal shutdown sequence stops and unregisters the interfaces before stopping them, so this shouldn’t be an issue.
-
promag closed this on May 13, 2020
-
promag deleted the branch on May 13, 2020
-
DrahtBot locked this on Feb 15, 2022
promag
ryanofsky
DrahtBot
MarcoFalke
Labels
Validation
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-10-24 18:13 UTC
More mirrored repositories can be found on mirror.b10c.me