mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-26 11:13:23 -03:00
Merge bitcoin/bitcoin#24141: Rename message_command variables in src/net* and src/rpc/net.cpp
e71c51b27d
refactor: rename command -> message type in comments in the src/net* files (Shashwat)2b09593bdd
scripted-diff: Rename message command to message type (Shashwat) Pull request description: This PR is a follow-up to #24078. > a message is not a command, but simply a message of some type The first commit covers the message_command variable name and comments not addressed in the original PR in `src/net*` files. The second commit goes beyond the original `src/net*` limit of #24078 and does similar changes in the `src/rpc/net.cpp` file. ACKs for top commit: MarcoFalke: review ACKe71c51b27d
💥 Tree-SHA512: 24015d132c00f15239e5d3dc7aedae904ae3103a90920bb09e984ff57723402763f697d886322f78e42a0cb46808cb6bc9d4905561dc6ddee9961168f8324b05
This commit is contained in:
commit
0d080a183b
3 changed files with 32 additions and 32 deletions
32
src/net.cpp
32
src/net.cpp
|
@ -103,7 +103,7 @@ enum BindFlags {
|
||||||
// The sleep time needs to be small to avoid new sockets stalling
|
// The sleep time needs to be small to avoid new sockets stalling
|
||||||
static const uint64_t SELECT_TIMEOUT_MILLISECONDS = 50;
|
static const uint64_t SELECT_TIMEOUT_MILLISECONDS = 50;
|
||||||
|
|
||||||
const std::string NET_MESSAGE_COMMAND_OTHER = "*other*";
|
const std::string NET_MESSAGE_TYPE_OTHER = "*other*";
|
||||||
|
|
||||||
static const uint64_t RANDOMIZER_ID_NETGROUP = 0x6c0edd8036ef4036ULL; // SHA256("netgroup")[0:8]
|
static const uint64_t RANDOMIZER_ID_NETGROUP = 0x6c0edd8036ef4036ULL; // SHA256("netgroup")[0:8]
|
||||||
static const uint64_t RANDOMIZER_ID_LOCALHOSTNONCE = 0xd93e69e2bbfa5735ULL; // SHA256("localhostnonce")[0:8]
|
static const uint64_t RANDOMIZER_ID_LOCALHOSTNONCE = 0xd93e69e2bbfa5735ULL; // SHA256("localhostnonce")[0:8]
|
||||||
|
@ -643,12 +643,12 @@ void CNode::CopyStats(CNodeStats& stats)
|
||||||
X(m_bip152_highbandwidth_from);
|
X(m_bip152_highbandwidth_from);
|
||||||
{
|
{
|
||||||
LOCK(cs_vSend);
|
LOCK(cs_vSend);
|
||||||
X(mapSendBytesPerMsgCmd);
|
X(mapSendBytesPerMsgType);
|
||||||
X(nSendBytes);
|
X(nSendBytes);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
LOCK(cs_vRecv);
|
LOCK(cs_vRecv);
|
||||||
X(mapRecvBytesPerMsgCmd);
|
X(mapRecvBytesPerMsgType);
|
||||||
X(nRecvBytes);
|
X(nRecvBytes);
|
||||||
}
|
}
|
||||||
X(m_permissionFlags);
|
X(m_permissionFlags);
|
||||||
|
@ -684,19 +684,19 @@ bool CNode::ReceiveMsgBytes(Span<const uint8_t> msg_bytes, bool& complete)
|
||||||
bool reject_message{false};
|
bool reject_message{false};
|
||||||
CNetMessage msg = m_deserializer->GetMessage(time, reject_message);
|
CNetMessage msg = m_deserializer->GetMessage(time, reject_message);
|
||||||
if (reject_message) {
|
if (reject_message) {
|
||||||
// Message deserialization failed. Drop the message but don't disconnect the peer.
|
// Message deserialization failed. Drop the message but don't disconnect the peer.
|
||||||
// store the size of the corrupt message
|
// store the size of the corrupt message
|
||||||
mapRecvBytesPerMsgCmd.at(NET_MESSAGE_COMMAND_OTHER) += msg.m_raw_message_size;
|
mapRecvBytesPerMsgType.at(NET_MESSAGE_TYPE_OTHER) += msg.m_raw_message_size;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Store received bytes per message command
|
// Store received bytes per message type.
|
||||||
// to prevent a memory DOS, only allow valid commands
|
// To prevent a memory DOS, only allow known message types.
|
||||||
auto i = mapRecvBytesPerMsgCmd.find(msg.m_type);
|
auto i = mapRecvBytesPerMsgType.find(msg.m_type);
|
||||||
if (i == mapRecvBytesPerMsgCmd.end()) {
|
if (i == mapRecvBytesPerMsgType.end()) {
|
||||||
i = mapRecvBytesPerMsgCmd.find(NET_MESSAGE_COMMAND_OTHER);
|
i = mapRecvBytesPerMsgType.find(NET_MESSAGE_TYPE_OTHER);
|
||||||
}
|
}
|
||||||
assert(i != mapRecvBytesPerMsgCmd.end());
|
assert(i != mapRecvBytesPerMsgType.end());
|
||||||
i->second += msg.m_raw_message_size;
|
i->second += msg.m_raw_message_size;
|
||||||
|
|
||||||
// push the message to the process queue,
|
// push the message to the process queue,
|
||||||
|
@ -781,7 +781,7 @@ CNetMessage V1TransportDeserializer::GetMessage(const std::chrono::microseconds
|
||||||
// decompose a single CNetMessage from the TransportDeserializer
|
// decompose a single CNetMessage from the TransportDeserializer
|
||||||
CNetMessage msg(std::move(vRecv));
|
CNetMessage msg(std::move(vRecv));
|
||||||
|
|
||||||
// store command string, time, and sizes
|
// store message type string, time, and sizes
|
||||||
msg.m_type = hdr.GetCommand();
|
msg.m_type = hdr.GetCommand();
|
||||||
msg.m_time = time;
|
msg.m_time = time;
|
||||||
msg.m_message_size = hdr.nMessageSize;
|
msg.m_message_size = hdr.nMessageSize;
|
||||||
|
@ -792,7 +792,7 @@ CNetMessage V1TransportDeserializer::GetMessage(const std::chrono::microseconds
|
||||||
// We just received a message off the wire, harvest entropy from the time (and the message checksum)
|
// We just received a message off the wire, harvest entropy from the time (and the message checksum)
|
||||||
RandAddEvent(ReadLE32(hash.begin()));
|
RandAddEvent(ReadLE32(hash.begin()));
|
||||||
|
|
||||||
// Check checksum and header command string
|
// Check checksum and header message type string
|
||||||
if (memcmp(hash.begin(), hdr.pchChecksum, CMessageHeader::CHECKSUM_SIZE) != 0) {
|
if (memcmp(hash.begin(), hdr.pchChecksum, CMessageHeader::CHECKSUM_SIZE) != 0) {
|
||||||
LogPrint(BCLog::NET, "Header error: Wrong checksum (%s, %u bytes), expected %s was %s, peer=%d\n",
|
LogPrint(BCLog::NET, "Header error: Wrong checksum (%s, %u bytes), expected %s was %s, peer=%d\n",
|
||||||
SanitizeString(msg.m_type), msg.m_message_size,
|
SanitizeString(msg.m_type), msg.m_message_size,
|
||||||
|
@ -3053,8 +3053,8 @@ CNode::CNode(NodeId idIn, ServiceFlags nLocalServicesIn, std::shared_ptr<Sock> s
|
||||||
if (inbound_onion) assert(conn_type_in == ConnectionType::INBOUND);
|
if (inbound_onion) assert(conn_type_in == ConnectionType::INBOUND);
|
||||||
|
|
||||||
for (const std::string &msg : getAllNetMessageTypes())
|
for (const std::string &msg : getAllNetMessageTypes())
|
||||||
mapRecvBytesPerMsgCmd[msg] = 0;
|
mapRecvBytesPerMsgType[msg] = 0;
|
||||||
mapRecvBytesPerMsgCmd[NET_MESSAGE_COMMAND_OTHER] = 0;
|
mapRecvBytesPerMsgType[NET_MESSAGE_TYPE_OTHER] = 0;
|
||||||
|
|
||||||
if (fLogIPs) {
|
if (fLogIPs) {
|
||||||
LogPrint(BCLog::NET, "Added connection to %s peer=%d\n", m_addr_name, id);
|
LogPrint(BCLog::NET, "Added connection to %s peer=%d\n", m_addr_name, id);
|
||||||
|
@ -3100,7 +3100,7 @@ void CConnman::PushMessage(CNode* pnode, CSerializedNetMsg&& msg)
|
||||||
bool optimisticSend(pnode->vSendMsg.empty());
|
bool optimisticSend(pnode->vSendMsg.empty());
|
||||||
|
|
||||||
//log total amount of bytes per message type
|
//log total amount of bytes per message type
|
||||||
pnode->mapSendBytesPerMsgCmd[msg.m_type] += nTotalSize;
|
pnode->mapSendBytesPerMsgType[msg.m_type] += nTotalSize;
|
||||||
pnode->nSendSize += nTotalSize;
|
pnode->nSendSize += nTotalSize;
|
||||||
|
|
||||||
if (pnode->nSendSize > nSendBufferMaxSize) pnode->fPauseSend = true;
|
if (pnode->nSendSize > nSendBufferMaxSize) pnode->fPauseSend = true;
|
||||||
|
|
14
src/net.h
14
src/net.h
|
@ -252,8 +252,8 @@ struct LocalServiceInfo {
|
||||||
extern Mutex g_maplocalhost_mutex;
|
extern Mutex g_maplocalhost_mutex;
|
||||||
extern std::map<CNetAddr, LocalServiceInfo> mapLocalHost GUARDED_BY(g_maplocalhost_mutex);
|
extern std::map<CNetAddr, LocalServiceInfo> mapLocalHost GUARDED_BY(g_maplocalhost_mutex);
|
||||||
|
|
||||||
extern const std::string NET_MESSAGE_COMMAND_OTHER;
|
extern const std::string NET_MESSAGE_TYPE_OTHER;
|
||||||
typedef std::map<std::string, uint64_t> mapMsgCmdSize; //command, total bytes
|
using mapMsgTypeSize = std::map</* message type */ std::string, /* total bytes */ uint64_t>;
|
||||||
|
|
||||||
class CNodeStats
|
class CNodeStats
|
||||||
{
|
{
|
||||||
|
@ -274,9 +274,9 @@ public:
|
||||||
bool m_bip152_highbandwidth_from;
|
bool m_bip152_highbandwidth_from;
|
||||||
int m_starting_height;
|
int m_starting_height;
|
||||||
uint64_t nSendBytes;
|
uint64_t nSendBytes;
|
||||||
mapMsgCmdSize mapSendBytesPerMsgCmd;
|
mapMsgTypeSize mapSendBytesPerMsgType;
|
||||||
uint64_t nRecvBytes;
|
uint64_t nRecvBytes;
|
||||||
mapMsgCmdSize mapRecvBytesPerMsgCmd;
|
mapMsgTypeSize mapRecvBytesPerMsgType;
|
||||||
NetPermissionFlags m_permissionFlags;
|
NetPermissionFlags m_permissionFlags;
|
||||||
std::chrono::microseconds m_last_ping_time;
|
std::chrono::microseconds m_last_ping_time;
|
||||||
std::chrono::microseconds m_min_ping_time;
|
std::chrono::microseconds m_min_ping_time;
|
||||||
|
@ -315,7 +315,7 @@ public:
|
||||||
|
|
||||||
/** The TransportDeserializer takes care of holding and deserializing the
|
/** The TransportDeserializer takes care of holding and deserializing the
|
||||||
* network receive buffer. It can deserialize the network buffer into a
|
* network receive buffer. It can deserialize the network buffer into a
|
||||||
* transport protocol agnostic CNetMessage (command & payload)
|
* transport protocol agnostic CNetMessage (message type & payload)
|
||||||
*/
|
*/
|
||||||
class TransportDeserializer {
|
class TransportDeserializer {
|
||||||
public:
|
public:
|
||||||
|
@ -686,8 +686,8 @@ private:
|
||||||
CService addrLocal GUARDED_BY(m_addr_local_mutex);
|
CService addrLocal GUARDED_BY(m_addr_local_mutex);
|
||||||
mutable Mutex m_addr_local_mutex;
|
mutable Mutex m_addr_local_mutex;
|
||||||
|
|
||||||
mapMsgCmdSize mapSendBytesPerMsgCmd GUARDED_BY(cs_vSend);
|
mapMsgTypeSize mapSendBytesPerMsgType GUARDED_BY(cs_vSend);
|
||||||
mapMsgCmdSize mapRecvBytesPerMsgCmd GUARDED_BY(cs_vRecv);
|
mapMsgTypeSize mapRecvBytesPerMsgType GUARDED_BY(cs_vRecv);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -156,7 +156,7 @@ static RPCHelpMan getpeerinfo()
|
||||||
{RPCResult::Type::NUM, "msg", "The total bytes received aggregated by message type\n"
|
{RPCResult::Type::NUM, "msg", "The total bytes received aggregated by message type\n"
|
||||||
"When a message type is not listed in this json object, the bytes received are 0.\n"
|
"When a message type is not listed in this json object, the bytes received are 0.\n"
|
||||||
"Only known message types can appear as keys in the object and all bytes received\n"
|
"Only known message types can appear as keys in the object and all bytes received\n"
|
||||||
"of unknown message types are listed under '"+NET_MESSAGE_COMMAND_OTHER+"'."}
|
"of unknown message types are listed under '"+NET_MESSAGE_TYPE_OTHER+"'."}
|
||||||
}},
|
}},
|
||||||
{RPCResult::Type::STR, "connection_type", "Type of connection: \n" + Join(CONNECTION_TYPE_DOC, ",\n") + ".\n"
|
{RPCResult::Type::STR, "connection_type", "Type of connection: \n" + Join(CONNECTION_TYPE_DOC, ",\n") + ".\n"
|
||||||
"Please note this output is unlikely to be stable in upcoming releases as we iterate to\n"
|
"Please note this output is unlikely to be stable in upcoming releases as we iterate to\n"
|
||||||
|
@ -243,19 +243,19 @@ static RPCHelpMan getpeerinfo()
|
||||||
}
|
}
|
||||||
obj.pushKV("permissions", permissions);
|
obj.pushKV("permissions", permissions);
|
||||||
|
|
||||||
UniValue sendPerMsgCmd(UniValue::VOBJ);
|
UniValue sendPerMsgType(UniValue::VOBJ);
|
||||||
for (const auto& i : stats.mapSendBytesPerMsgCmd) {
|
for (const auto& i : stats.mapSendBytesPerMsgType) {
|
||||||
if (i.second > 0)
|
if (i.second > 0)
|
||||||
sendPerMsgCmd.pushKV(i.first, i.second);
|
sendPerMsgType.pushKV(i.first, i.second);
|
||||||
}
|
}
|
||||||
obj.pushKV("bytessent_per_msg", sendPerMsgCmd);
|
obj.pushKV("bytessent_per_msg", sendPerMsgType);
|
||||||
|
|
||||||
UniValue recvPerMsgCmd(UniValue::VOBJ);
|
UniValue recvPerMsgType(UniValue::VOBJ);
|
||||||
for (const auto& i : stats.mapRecvBytesPerMsgCmd) {
|
for (const auto& i : stats.mapRecvBytesPerMsgType) {
|
||||||
if (i.second > 0)
|
if (i.second > 0)
|
||||||
recvPerMsgCmd.pushKV(i.first, i.second);
|
recvPerMsgType.pushKV(i.first, i.second);
|
||||||
}
|
}
|
||||||
obj.pushKV("bytesrecv_per_msg", recvPerMsgCmd);
|
obj.pushKV("bytesrecv_per_msg", recvPerMsgType);
|
||||||
obj.pushKV("connection_type", ConnectionTypeAsString(stats.m_conn_type));
|
obj.pushKV("connection_type", ConnectionTypeAsString(stats.m_conn_type));
|
||||||
|
|
||||||
ret.push_back(obj);
|
ret.push_back(obj);
|
||||||
|
|
Loading…
Add table
Reference in a new issue