Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: move CConnman::RelayInv{Filtered} to PeerManager, remove CConnman::RelayTransaction #5977

Merged
merged 7 commits into from
Apr 24, 2024

Conversation

kwvg
Copy link
Collaborator

@kwvg kwvg commented Apr 9, 2024

Additional information

Breaking Changes

None observed.

Checklist:

  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • I have added or updated relevant unit/integration/functional/e2e tests
  • I have made corresponding changes to the documentation (note: N/A)
  • I have assigned this pull request to a milestone (for repository code-owners and collaborators only)

src/coinjoin/context.cpp Outdated Show resolved Hide resolved
Copy link

This pull request has conflicts, please rebase.

@kwvg kwvg marked this pull request as ready for review April 18, 2024 10:04
Copy link
Collaborator

@knst knst left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

see comment about quorumInstantSendManager

CDeterministicMNManager& m_dmnman;
CEvoDB& m_evoDb;
const std::unique_ptr<PeerManager>& m_peerman;
Copy link
Collaborator

@knst knst Apr 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't like const std::unique_ptr<PeerManager>& spreading all over code base, but overall PR looks fine except quorumInstantSendManager case

@@ -43,7 +43,7 @@ LLMQContext::LLMQContext(CChainState& chainstate, CConnman& connman, CDeterminis
}()},
isman{[&]() -> llmq::CInstantSendManager* const {
assert(llmq::quorumInstantSendManager == nullptr);
llmq::quorumInstantSendManager = std::make_unique<llmq::CInstantSendManager>(*llmq::chainLocksHandler, chainstate, connman, *llmq::quorumManager, *sigman, *shareman, sporkman, mempool, mn_sync, unit_tests, wipe);
llmq::quorumInstantSendManager = std::make_unique<llmq::CInstantSendManager>(*llmq::chainLocksHandler, chainstate, connman, *llmq::quorumManager, *sigman, *shareman, sporkman, mempool, mn_sync, peerman, unit_tests, wipe);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

can you describe a situation when exactly does it happen?

ProcessPendingInstantSendLocks > ProcessPendingInstantSendLocks[1] >
ProcessInstantSendLock > RelayInvFiltered

The separate threads won't travel like that until no messages received -> so, peerman won't be nullptr

Copy link
Collaborator Author

@kwvg kwvg Apr 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Crashing was observed in feature_dip3_v19 and feature_llmq_evo without those changes (tested on d02dcb0)

2024-04-23T14:47:29.534746Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net_processing.cpp:5470] [operator()] SendMessages -- queued inv: qsigrec 7239135df98b46c8ab03e684ef15b90c4b6bd5fe8aa757b11105c9c880f347e0  index=0 peer=1
2024-04-23T14:47:29.534770Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net.cpp:4033] [PushMessage] sending inv (37 bytes) peer=1
2024-04-23T14:47:29.534845Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net_processing.cpp:5470] [operator()] SendMessages -- queued inv: qsigrec 7239135df98b46c8ab03e684ef15b90c4b6bd5fe8aa757b11105c9c880f347e0  index=0 peer=2
2024-04-23T14:47:29.534861Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net.cpp:4033] [PushMessage] sending inv (37 bytes) peer=2
2024-04-23T14:47:29.534956Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net_processing.cpp:5470] [operator()] SendMessages -- queued inv: qsigrec 7239135df98b46c8ab03e684ef15b90c4b6bd5fe8aa757b11105c9c880f347e0  index=0 peer=4
2024-04-23T14:47:29.534971Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net.cpp:4033] [PushMessage] sending inv (37 bytes) peer=4
2024-04-23T14:47:29.535221Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net_processing.cpp:3146] [ProcessMessage] received: inv (37 bytes) peer=2
2024-04-23T14:47:29.535239Z (mocktime: 2014-12-04T17:29:03Z) [   msghand] [net_processing.cpp:3670] [ProcessMessage] got inv: qsigrec 7239135df98b46c8ab03e684ef15b90c4b6bd5fe8aa757b11105c9c880f347e0  have peer=2
2024-04-23T14:47:29.566421Z (mocktime: 2014-12-04T17:29:03Z) [     isman] [llmq/instantsend.cpp:951] [ProcessPendingInstantSendLocks] CInstantSendManager::ProcessPendingInstantSendLocks -- verified locks. count=0, alreadyVerified=1, vt=0, nodes=0
2024-04-23T14:47:29.566439Z (mocktime: 2014-12-04T17:29:03Z) [     isman] [llmq/instantsend.cpp:996] [ProcessInstantSendLock] CInstantSendManager::ProcessInstantSendLock -- txid=62fd9a36bf4b11c4e7c0bfa9ffe80f6dc66fef54136c2d241a478daae1f880e6, islock=c2e83196cf1af12277b225ff043b4fd[...]
2024-04-23T14:47:29.566499Z (mocktime: 2014-12-04T17:29:03Z) [     isman] [llmq/instantsend.cpp:1226] [RemoveNonLockedTx] CInstantSendManager::RemoveNonLockedTx -- txid=62fd9a36bf4b11c4e7c0bfa9ffe80f6dc66fef54136c2d241a478daae1f880e6, retryChildren=1, retryChildrenCount=0
2024-04-23T14:47:29.566591Z (mocktime: 2014-12-04T17:29:03Z) [     isman] [stacktraces.cpp:528] [PrintCrashInfo] Posix Signal: Segmentation fault
No debug information available for stacktrace. You should add debug information and then run:
dashd -printcrashinfo=bvcgc43iinzgc43ijfxgm3ybaacwiyltnbscaudponuxqictnftw4ylmhiqfgzlhnvsw45dboruw63ramzqxk3duaaaa====

Copy link
Collaborator Author

@kwvg kwvg Apr 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

dash@db65c47c7824:/src/dash$ ./test/functional/test_runner.py
[...]
feature_asset_locks.py --legacy-wallet              | � Failed  | 55 s
feature_dip3_v19.py --legacy-wallet                 | � Failed  | 120 s
feature_llmq_chainlocks.py --legacy-wallet          | � Failed  | 362 s
feature_llmq_evo.py --legacy-wallet                 | � Failed  | 104 s
feature_llmq_is_cl_conflicts.py --legacy-wallet     | � Failed  | 96 s
feature_llmq_is_retroactive.py --legacy-wallet      | � Failed  | 96 s
feature_notifications.py --legacy-wallet            | � Failed  | 124 s
interface_zmq_dash.py --legacy-wallet               | � Failed  | 108 s
p2p_instantsend.py --legacy-wallet                  | � Failed  | 120 s
rpc_verifyislock.py --legacy-wallet                 | � Failed  | 111 s

ALL                                                 | � Failed  | 7909 s (accumulated)
Runtime: 2009 s

Copy link
Collaborator

@knst knst left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM cbdc34d

@PastaPastaPasta
Copy link
Member

Range diff here

 -:  ---------- >  1:  10a006e626 test: disable ipv6 tests for now
 -:  ---------- >  2:  6423f6bc5d Merge #21395: Net processing: Remove unused CNode.address member
 -:  ---------- >  3:  1a07e04a0e Merge #21370: Use C++11 member initializer in CNodeState
 -:  ---------- >  4:  666e6e2015 Merge #20406: util: Avoid invalid integer negation in FormatMoney and ValueFromAmount
 -:  ---------- >  5:  6ca0eb189e Merge #21007: bitcoind: Add -daemonwait option to wait for initialization
 -:  ---------- >  6:  99f09a0be6 Merge #20040: wallet: Refactor OutputGroups to handle fees and spending eligibility on grouping
 -:  ---------- >  7:  3325620ce1 Merge #21418: contrib: Make systemd invoke dependencies only when ready
 -:  ---------- >  8:  dd92322962 Merge #21447: Always add -daemonwait to known command line arguments
 -:  ---------- >  9:  b8aec5cb86 Merge #20197: p2p: protect onions in AttemptToEvictConnection(), add eviction protection test coverage
 -:  ---------- > 10:  daacafb539 Merge #21426: rpc: remove scantxoutset EXPERIMENTAL warning
 -:  ---------- > 11:  16ccb90bbb Merge bitcoin/bitcoin#21902: refactor: Remove useless extern keyword
 -:  ---------- > 12:  f3bc9535da Merge bitcoin/bitcoin#22187: test: Add sync_blocks in wallet_orphanedreward.py
 -:  ---------- > 13:  cc70886b4d Merge bitcoin/bitcoin#21795: fuzz: Terminate immediately if a fuzzing harness tries to perform a DNS lookup (belt and suspenders)
 -:  ---------- > 14:  b6dbd8bd7d Merge bitcoin/bitcoin#22092: test: convert documentation into type annotations
 -:  ---------- > 15:  2996daad4c (followup) bitcoin#19940
 -:  ---------- > 16:  348f4a8b9e Merge bitcoin/bitcoin#22121: doc: Various validation doc fixups
 -:  ---------- > 17:  26ff28a028 Merge bitcoin/bitcoin#21353: interfaces: Stop exposing wallet destdata to gui
 -:  ---------- > 18:  6c242da723 Merge bitcoin/bitcoin#21936: fuzz: Terminate immediately if a fuzzing harness tries to create a TCP socket (belt and suspenders)
 1:  818cca0780 = 19:  569efa0dd2 net: use ForEachNode instead of manually iterating through vNodes
 2:  a25b5df120 = 20:  fbb2748d58 net: move Relay{Inv, InvFiltered, Transaction} out of CConnman
 3:  82be8c308b = 21:  ff68ce3c47 net: retire CConnman::RelayTransaction, use PeerManager::RelayTransaction
 4:  7b5adc451b = 22:  7877aa05e6 trivial: cleanup unnecessary headers in context files
 5:  d02dcb0701 = 23:  b234a84358 net: move CConnman::RelayInv{Filtered} into PeerManager
 6:  6a86ebf425 = 24:  33c8f236a0 llmq: pass PeerManager to llmq::CInstantSendManager constructor
 7:  cbdc34d055 = 25:  11df052792 trivial: add `Asserts` for `m_peerman` pointer container uses

knst
knst previously approved these changes Apr 23, 2024
Copy link
Collaborator

@knst knst left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

utACK 11df052

Copy link

This pull request has conflicts, please rebase.

Copy link
Member

@PastaPastaPasta PastaPastaPasta left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

utACK 11df052

@PastaPastaPasta
Copy link
Member

range-diff

 -:  ---------- >  1:  c47e9e78ed bench: drop leftover `boost::lexical_cast` benches, drop header from list
 -:  ---------- >  2:  9ae39f9ba7 qt: drop leftover `boost::function` usage in Qt, drop header from list
 -:  ---------- >  3:  fbc6bc88cf init: use local ArgsManager variable instead of global when possible
 -:  ---------- >  4:  65585e68e6 merge bitcoin#25550: remove note on arm cross-compilation from build-unix.md
 -:  ---------- >  5:  3265b54a2f merge bitcoin#24624: Avoid potential -Wdeprecated-enum-enum-conversion warnings
 -:  ---------- >  6:  740d25c062 merge bitcoin#24406: Fix Wambiguous-reversed-operator compiler warnings
 -:  ---------- >  7:  7bcc56c9b6 Merge bitcoin/bitcoin#22138: script: fix spelling linter raising spuriously on "invokable"
 -:  ---------- >  8:  00b828c0f5 Merge bitcoin/bitcoin#21939: refactor: Replace memset calls with array initialization
 -:  ---------- >  9:  b8b3c4c289 Merge bitcoin-core/gui#163: Peer details: replace Direction with Connection Type
 -:  ---------- > 10:  4d20cb7173 Merge #20373: refactor, net: Increase CNode data member encapsulation
 -:  ---------- > 11:  366ca98b39 Merge bitcoin/bitcoin#22144: Randomize message processing peer order
 -:  ---------- > 12:  74b20eb309 Merge bitcoin/bitcoin#22013: net: ignore block-relay-only peers when skipping DNS seed
 -:  ---------- > 13:  751c9e66c4 Merge bitcoin/bitcoin#21719: refactor: Add and use EnsureConnman in rpc code
 -:  ---------- > 14:  18169f4957 Merge #20786: net: [refactor] Prefer integral types in CNodeStats
 1:  569efa0dd2 = 15:  d54ba447a7 net: use ForEachNode instead of manually iterating through vNodes
 2:  fbb2748d58 = 16:  0323c6ca17 net: move Relay{Inv, InvFiltered, Transaction} out of CConnman
 3:  ff68ce3c47 = 17:  c3f1ac2291 net: retire CConnman::RelayTransaction, use PeerManager::RelayTransaction
 4:  7877aa05e6 = 18:  313a7e9a50 trivial: cleanup unnecessary headers in context files
 5:  b234a84358 ! 19:  bfd33cd2b4 net: move CConnman::RelayInv{Filtered} into PeerManager
    @@ src/net.h: private:
     
      ## src/net_processing.cpp ##
     @@ src/net_processing.cpp: public:
    -     bool GetNodeStateStats(NodeId nodeid, CNodeStateStats& stats) override;
    +     bool GetNodeStateStats(NodeId nodeid, CNodeStateStats& stats) const override;
          bool IgnoresIncomingTxs() override { return m_ignore_incoming_txs; }
          void SendPings() override;
     +    void RelayInv(CInv &inv, const int minProtoVersion) override;
    @@ src/rpc/misc.cpp: static RPCHelpMan sporkupdate()
          }
      
          const NodeContext& node = EnsureAnyNodeContext(request.context);
    --    if (!node.connman) {
    -+    if (!node.peerman) {
    -         throw JSONRPCError(RPC_CLIENT_P2P_DISABLED, "Error: Peer-to-peer functionality missing or disabled");
    -     }
    +-    CConnman& connman = EnsureConnman(node);
    ++    PeerManager& peerman = EnsurePeerman(node);
      
    -@@ src/rpc/misc.cpp: static RPCHelpMan sporkupdate()
    +     // SPORK VALUE
          int64_t nValue = request.params[1].get_int64();
      
          // broadcast new spork
    --    if (node.sporkman->UpdateSpork(nSporkID, nValue, *node.connman)) {
    -+    if (node.sporkman->UpdateSpork(*node.peerman, nSporkID, nValue)) {
    +-    if (node.sporkman->UpdateSpork(nSporkID, nValue, connman)) {
    ++    if (node.sporkman->UpdateSpork(peerman, nSporkID, nValue)) {
              return "success";
          }
      
 6:  33c8f236a0 = 20:  35be4e2ebe llmq: pass PeerManager to llmq::CInstantSendManager constructor
 7:  11df052792 = 21:  f2fe39fadc trivial: add `Asserts` for `m_peerman` pointer container uses

Copy link
Member

@PastaPastaPasta PastaPastaPasta left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

re-utACK f2fe39f

Copy link

@UdjinM6 UdjinM6 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, utACK (assuming CI is happy too)

@knst
Copy link
Collaborator

knst commented Apr 23, 2024

Ranged diff:

$ gfd cbdc34d0553ed0a05c1d1456305f37806a30c3e3 f2fe39fadc96327cf0a93d018860a26a46ff57c1 
fp1=2dacfb08bdf02fdaf0740edac19435bfaa0e52d3
fp2=6194e454d7a9ed15b34bb75f9865005748b17b13
--- /dev/fd/63  2024-04-23 22:43:11.078103491 +0700
+++ /dev/fd/62  2024-04-23 22:43:11.078103491 +0700
@@ -1261,24 +1261,22 @@
      } else {
          throw JSONRPCError(RPC_INTERNAL_ERROR, "Error voting : " + exception.GetMessage());
 diff --git a/src/rpc/misc.cpp b/src/rpc/misc.cpp
-index dfb463eb3a..da6771c17b 100644
+index bbc2e4eec2..d011bb60f1 100644
 --- a/src/rpc/misc.cpp
 +++ b/src/rpc/misc.cpp
-@@ -213,7 +213,7 @@ static RPCHelpMan sporkupdate()
+@@ -214,13 +214,13 @@ static RPCHelpMan sporkupdate()
      }
  
      const NodeContext& node = EnsureAnyNodeContext(request.context);
--    if (!node.connman) {
-+    if (!node.peerman) {
-         throw JSONRPCError(RPC_CLIENT_P2P_DISABLED, "Error: Peer-to-peer functionality missing or disabled");
-     }
+-    CConnman& connman = EnsureConnman(node);
++    PeerManager& peerman = EnsurePeerman(node);
  
-@@ -221,7 +221,7 @@ static RPCHelpMan sporkupdate()
+     // SPORK VALUE
      int64_t nValue = request.params[1].get_int64();
  
      // broadcast new spork
--    if (node.sporkman->UpdateSpork(nSporkID, nValue, *node.connman)) {
-+    if (node.sporkman->UpdateSpork(*node.peerman, nSporkID, nValue)) {
+-    if (node.sporkman->UpdateSpork(nSporkID, nValue, connman)) {
++    if (node.sporkman->UpdateSpork(peerman, nSporkID, nValue)) {
          return "success";
      }

Copy link
Collaborator

@knst knst left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

utACK f2fe39f

kwvg added 7 commits April 23, 2024 16:06
ForEachNode is publicly available, which will help us extract the
functions from CConnman in a subsequent commit
Required to avoid crashes when calling RelayInvFiltered in situations
where the PeerManager* atomic hasn't been set (possible when ProcessMessage
isn't called, leaving the value unset, while a separate thread traverses
the ProcessPendingInstantSendLocks > ProcessPendingInstantSendLocks[1] >
ProcessInstantSendLock > RelayInvFiltered call chain).

[1] - There is a function with the exact same name but with multiple
      arguments
@PastaPastaPasta PastaPastaPasta merged commit 2b1c165 into dashpay:develop Apr 24, 2024
4 of 12 checks passed
PastaPastaPasta added a commit that referenced this pull request Apr 28, 2024
, bitcoin#23695, bitcoin#21160, bitcoin#24692, partial bitcoin#20196, bitcoin#25176, merge bitcoin-core/gui#526 (networking backports: part 4)

ab7ac1b partial bitcoin#25176: Fix frequent -netinfo JSON errors from null getpeerinfo#relaytxes (Kittywhiskers Van Gogh)
c89799d merge bitcoin#24692: Follow-ups to bitcoin#21160 (Kittywhiskers Van Gogh)
33098ae merge bitcoin#21160: Move tx inventory into net_processing (Kittywhiskers Van Gogh)
24205d9 partial bitcoin#20196: fix GetListenPort() to derive the proper port (Kittywhiskers Van Gogh)
7f72009 merge bitcoin-core/gui#526: Add address relay/processed/rate-limited fields to peer details (Kittywhiskers Van Gogh)
a9114f1 merge bitcoin#23695: Always serialize local timestamp for version msg (Kittywhiskers Van Gogh)
d936c28 merge bitcoin#23575: Rework FillNode (Kittywhiskers Van Gogh)
6f8c730 merge bitcoin#19499: Make timeout mockable and type safe, speed up test (Kittywhiskers Van Gogh)
43a82bd merge bitcoin#20769: fixes "advertised address where nobody is listening" (Kittywhiskers Van Gogh)

Pull request description:

  ## Additional Information

  * Dependent on #5978
  * Dependent on #5977

  ## Breaking Changes

  None observed.

  ## Checklist:

  - [x] I have performed a self-review of my own code
  - [x] I have commented my code, particularly in hard-to-understand areas **(note: N/A)**
  - [x] I have added or updated relevant unit/integration/functional/e2e tests
  - [x] I have made corresponding changes to the documentation **(note: N/A)**
  - [x] I have assigned this pull request to a milestone _(for repository code-owners and collaborators only)_

ACKs for top commit:
  PastaPastaPasta:
    utACK ab7ac1b

Tree-SHA512: 87bf5108bb80576c5bff8cd577add7800044da252fd18590e06a727f0bf70de94e2e9294b4412cdd9f1f6676472b0359902af361aaffc4c9ee299ad07d6af009
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants