From 69aed5087e398ff2b29e2dfe8c29c13972108568 Mon Sep 17 00:00:00 2001 From: Gav Wood Date: Thu, 30 Jan 2014 16:35:36 +0000 Subject: [PATCH] Slightly more error resistant. --- libethereum/PeerNetwork.cpp | 54 +++++++++++++++++++++---------------- 1 file changed, 31 insertions(+), 23 deletions(-) diff --git a/libethereum/PeerNetwork.cpp b/libethereum/PeerNetwork.cpp index d6e8f9786..23cfb2d2f 100644 --- a/libethereum/PeerNetwork.cpp +++ b/libethereum/PeerNetwork.cpp @@ -341,33 +341,41 @@ void PeerSession::doRead() dropped(); else { - m_incoming.resize(m_incoming.size() + length); - memcpy(m_incoming.data() + m_incoming.size() - length, m_data.data(), length); - while (m_incoming.size() > 8) + try { - if (m_incoming[0] != 0x22 || m_incoming[1] != 0x40 || m_incoming[2] != 0x08 || m_incoming[3] != 0x91) + m_incoming.resize(m_incoming.size() + length); + memcpy(m_incoming.data() + m_incoming.size() - length, m_data.data(), length); + while (m_incoming.size() > 8) { - cout << "*** Out of alignment: skipping: " << hex << showbase << (int)m_incoming[0] << endl; - memmove(m_incoming.data(), m_incoming.data() + 1, m_incoming.size() - 1); - m_incoming.resize(m_incoming.size() - 1); - } - else - { - uint32_t len = fromBigEndian(bytesConstRef(m_incoming.data() + 4, 4)); -// cout << "Received packet of " << len << " bytes" << endl; - if (m_incoming.size() - 8 < len) - break; - - // enough has come in. - RLP r(bytesConstRef(m_incoming.data() + 8, len)); - if (!interpret(r)) - // error - break; - memmove(m_incoming.data(), m_incoming.data() + len + 8, m_incoming.size() - (len + 8)); - m_incoming.resize(m_incoming.size() - (len + 8)); + if (m_incoming[0] != 0x22 || m_incoming[1] != 0x40 || m_incoming[2] != 0x08 || m_incoming[3] != 0x91) + { + cout << "*** Out of alignment: skipping: " << hex << showbase << (int)m_incoming[0] << endl; + memmove(m_incoming.data(), m_incoming.data() + 1, m_incoming.size() - 1); + m_incoming.resize(m_incoming.size() - 1); + } + else + { + uint32_t len = fromBigEndian(bytesConstRef(m_incoming.data() + 4, 4)); + // cout << "Received packet of " << len << " bytes" << endl; + if (m_incoming.size() - 8 < len) + break; + + // enough has come in. + RLP r(bytesConstRef(m_incoming.data() + 8, len)); + if (!interpret(r)) + // error + break; + memmove(m_incoming.data(), m_incoming.data() + len + 8, m_incoming.size() - (len + 8)); + m_incoming.resize(m_incoming.size() - (len + 8)); + } } + doRead(); + } + catch (std::exception const& _e) + { + cout << std::setw(2) << m_socket.native_handle() << " | ERROR: " << _e.what() << endl; + dropped(); } - doRead(); } }); }