Merge bitcoin/bitcoin#26888: net: simplify the call to vProcessMsg.splice()

dfc01ccd73 net: simplify the call to vProcessMsg.splice() (Vasil Dimov)

Pull request description:

  At the time when

  ```cpp
  pnode->vProcessMsg.splice(pnode->vProcessMsg.end(), pnode->vRecvMsg, pnode->vRecvMsg.begin(), it);
  ```

  is called, `it` is certainly `pnode->vRecvMsg.end()` which makes the call equivalent to:

  ```cpp
  pnode->vProcessMsg.splice(pnode->vProcessMsg.end(), pnode->vRecvMsg, pnode->vRecvMsg.begin(), pnode->vRecvMsg.end());
  ```

  which is equivalent to:

  ```cpp
  pnode->vProcessMsg.splice(pnode->vProcessMsg.end(), pnode->vRecvMsg);
  ```

  Thus, use the latter. Further, maybe irrelevant, but the latter has constant complexity while the original code is `O(length of vRecvMsg)`.

ACKs for top commit:
  theStack:
    Code-review ACK dfc01ccd73
  MarcoFalke:
    review ACK dfc01ccd73   🐑
  jonatack:
    Light review ACK dfc01ccd73

Tree-SHA512: 9f4eb61d1caf4af9a61ba2f54b915fcfe406db62c58ab1ec42f736505b6792e9379a83d0458d6cc04f289edcec070b7c962f94a920ab51701c3cab103152866f
This commit is contained in:
MarcoFalke 2023-02-01 09:42:38 +01:00
commit ba39ffe938
No known key found for this signature in database
GPG key ID: CE2B75697E69A548
2 changed files with 6 additions and 8 deletions

View file

@ -1305,15 +1305,14 @@ void CConnman::SocketHandlerConnected(const std::vector<CNode*>& nodes,
RecordBytesRecv(nBytes); RecordBytesRecv(nBytes);
if (notify) { if (notify) {
size_t nSizeAdded = 0; size_t nSizeAdded = 0;
auto it(pnode->vRecvMsg.begin()); for (const auto& msg : pnode->vRecvMsg) {
for (; it != pnode->vRecvMsg.end(); ++it) {
// vRecvMsg contains only completed CNetMessage // vRecvMsg contains only completed CNetMessage
// the single possible partially deserialized message are held by TransportDeserializer // the single possible partially deserialized message are held by TransportDeserializer
nSizeAdded += it->m_raw_message_size; nSizeAdded += msg.m_raw_message_size;
} }
{ {
LOCK(pnode->cs_vProcessMsg); LOCK(pnode->cs_vProcessMsg);
pnode->vProcessMsg.splice(pnode->vProcessMsg.end(), pnode->vRecvMsg, pnode->vRecvMsg.begin(), it); pnode->vProcessMsg.splice(pnode->vProcessMsg.end(), pnode->vRecvMsg);
pnode->nProcessQueueSize += nSizeAdded; pnode->nProcessQueueSize += nSizeAdded;
pnode->fPauseRecv = pnode->nProcessQueueSize > nReceiveFloodSize; pnode->fPauseRecv = pnode->nProcessQueueSize > nReceiveFloodSize;
} }

View file

@ -67,15 +67,14 @@ void ConnmanTestMsg::NodeReceiveMsgBytes(CNode& node, Span<const uint8_t> msg_by
assert(node.ReceiveMsgBytes(msg_bytes, complete)); assert(node.ReceiveMsgBytes(msg_bytes, complete));
if (complete) { if (complete) {
size_t nSizeAdded = 0; size_t nSizeAdded = 0;
auto it(node.vRecvMsg.begin()); for (const auto& msg : node.vRecvMsg) {
for (; it != node.vRecvMsg.end(); ++it) {
// vRecvMsg contains only completed CNetMessage // vRecvMsg contains only completed CNetMessage
// the single possible partially deserialized message are held by TransportDeserializer // the single possible partially deserialized message are held by TransportDeserializer
nSizeAdded += it->m_raw_message_size; nSizeAdded += msg.m_raw_message_size;
} }
{ {
LOCK(node.cs_vProcessMsg); LOCK(node.cs_vProcessMsg);
node.vProcessMsg.splice(node.vProcessMsg.end(), node.vRecvMsg, node.vRecvMsg.begin(), it); node.vProcessMsg.splice(node.vProcessMsg.end(), node.vRecvMsg);
node.nProcessQueueSize += nSizeAdded; node.nProcessQueueSize += nSizeAdded;
node.fPauseRecv = node.nProcessQueueSize > nReceiveFloodSize; node.fPauseRecv = node.nProcessQueueSize > nReceiveFloodSize;
} }